【问题标题】:Spinners are empty微调器是空的
【发布时间】:2013-07-29 08:44:25
【问题描述】:

我正在尝试使用来自 MySQL 的数据填充微调器(我必须行),但它们保持为空。此外,这些微调器应该相互依赖。任何想法为什么?当我在本地主机中调用 url 时,它返回正确的值,因此 PHP 工作正常(PHP 中的一行示例:[{"Grad":"Beograd","Predmet":"matematika"}...],我我更担心将这些行放在列表中。

public class IzboraGrada extends Activity {
    Spinner spinner1, spinner2;
    private Button button,izlaz;
    static String str_grad,str_predmet,url;

    InputStream is=null;
    String result=null;
    String line=null;
    String[] grad, predmet;   


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_izbora_grada);

        spinner1=(Spinner) findViewById(R.id.spinner1);
        spinner2=(Spinner) findViewById(R.id.spinner2);

        final List<String> list1=new ArrayList<String>();
        final List<String> list2=new ArrayList<String>();

        Button b=(Button) findViewById(R.id.button);

        b.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View v) {
                // TODO Auto-generated method stub

                try
                {
                HttpClient httpclient = new DefaultHttpClient();
                HttpPost httppost = new HttpPost("http://192.168.1.14/test/spinner1.php");
                HttpResponse response = httpclient.execute(httppost);
                Log.e("Fail 1", "3");

                HttpEntity entity = response.getEntity();
                Log.e("Fail 1", "4");

                is = entity.getContent();
                Log.e("Pass 1", "connection success ");
                }
                catch(Exception e)
                {
                Log.e("Fail 1", e.toString());
                Toast.makeText(getApplicationContext(), "Invalid IP Address",Toast.LENGTH_LONG).show();
                finish();
                } 

                try
                {
                BufferedReader reader = new BufferedReader(new InputStreamReader(is,"iso-8859-1"),8);
                StringBuilder sb = new StringBuilder();
                while ((line = reader.readLine()) != null)
                {
                sb.append(line + "\n");
                }
                is.close();
                result = sb.toString();
                }
                catch(Exception e)
                {
                Log.e("Fail 2", e.toString());
                }    

                try
                {
                JSONArray JA=new JSONArray(result);
                JSONObject json= null;
                grad = new String[JA.length()];       
                predmet = new String[JA.length()];

                for(int i=0;i<JA.length();i++)
                {
                json=JA.getJSONObject(i);
                grad[i] = json.getString("Grad");
                predmet[i]=json.getString("Predmet");
                }
                Toast.makeText(getApplicationContext(), "sss",Toast.LENGTH_LONG).show();

                for(int i=0;i<grad.length;i++)
                {
                list1.add(grad[i]);
                list2.add(predmet[i]);
                }

                spinner_fn();

                }
                catch(Exception e)
                {

                Log.e("Fail 3", e.toString());
                //login.this.finish();

                }
            }
        });
    }

    private void spinner_fn() {
        // TODO Auto-generated method stub

        ArrayAdapter<String> dataAdapter1 = new ArrayAdapter<String>(getApplicationContext(),
                                    android.R.layout.simple_spinner_item, grad);
    dataAdapter1.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
    spinner1.setAdapter(dataAdapter1);



        ArrayAdapter<String> dataAdapter2 = new ArrayAdapter<String>(getApplicationContext(),
                                    android.R.layout.simple_spinner_item, predmet);
    dataAdapter2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
    spinner2.setAdapter(dataAdapter2);   

        spinner1.setOnItemSelectedListener(new OnItemSelectedListener()
        {
        public void onItemSelected(AdapterView<?> arg0, View arg1,int position, long id)
        {
        // TODO Auto-generated method stub

        spinner2.setSelection(position);

        }

        @Override
        public void onNothingSelected(AdapterView<?> arg0)
        {
        // TODO Auto-generated method stub
        }

        });


        spinner2.setOnItemSelectedListener(new OnItemSelectedListener() {

        public void onItemSelected(AdapterView<?> arg0, View arg1,int position, long arg3) {
        // TODO Auto-generated method stub

        spinner1.setSelection(position);

        }

        public void onNothingSelected(AdapterView<?> arg0) {
        // TODO Auto-generated method stub
        }
        });

        }   
}

还有PHP代码:

$con = mysqli_connect($host, $user, $pwd, $db);

if(mysqli_connect_errno($con)) {
    die("Failed to connect to MySQL: " . mysqli_connect_error());
} 


$sql = "SELECT Grad, Predmet FROM lista";
$result = mysqli_query($con, $sql);

$rows = array();

while($row = mysqli_fetch_array($result, MYSQLI_ASSOC)) {

        $rows[] = $row; 

}

mysqli_close($con);

echo json_encode($rows);

【问题讨论】:

  • php 是否返回任何东西?
  • 当您从 uri 读取行时,您能在调试模式下看到这些值吗?
  • PHP 返回:[{"Grad":"Beograd","Predmet":"matematika"},{"Grad":"Novi_Sad","Predmet":"matematika"}.. ..]
  • 检查这个stackoverflow.com/a/17745490/1140237需要传递你的值而不是这个ans示例代码中传递的字母......“grad”和“predmet”列表你需要传递..&它会更好对ws调用过程使用异步任务...

标签: android


【解决方案1】:

您没有填充您的微调器,请查看您的代码的一部分;

ArrayAdapter<String> dataAdapter1 = new ArrayAdapter<String>(getApplicationContext(),
dataAdapter2.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

Android 将其作为一行读取,没有对正确数据的有效引用。请替换为以下内容,

// adapter for spinner
ArrayAdapter<String> dataAdapter1 = new ArrayAdapter<String>(getApplicationContext(), $$$, list1);
// set layout
dataAdapter1.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

将 $$$ 替换为 XML 布局中的微调器 item-id。对 spinner2 执行相同操作

【讨论】:

  • 由于某种原因它没有复制那部分代码。我会编辑我的帖子。几分钟后看看。
  • 将 dataAdapter-code sn-p 中的“grad”替换为“list1”,将“predmet”替换为“list2”,因为最后一个参数应该来自 List 类型。
  • 我按照你说的做了,但是 list1 无法解析为变量。然后你移动了 final List list1=new ArrayList();退出 onCreat 并将其留在 IzboraGrada 类中,但它没有帮助。看起来返回的数据确实是一个 JSON 对象,而不是 JSON 数组; JSON 数组嵌套在外部对象中
  • 我在stackoverflow.com/questions/15442861/… 上发现了一个非常相似的问题,但我不知道如何在我的代码中使用它,以及要更改什么。请你帮帮我。
猜你喜欢
  • 2016-08-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-02-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2015-12-03
相关资源
最近更新 更多