Android从mysql JSON数据填充微调器

时间:2017-12-03 00:40:44

标签: php android mysql json

我有两个旋转器,一个用于省,另一个用于城市。但他们互相依赖。如果我在省旋转器中选择豪登,第二个旋转器必须显示约翰内斯堡,比勒陀利亚,百夫长,如果我在省选择KZN,我希望第二个旋转器显示Petermaritsburg,Durban,Ulundi。

这是我的代码。我可以从我的mysql数据库填充微调器,但我不能创建其他

的依赖项

第一个微调器JSON数据:

   "Provinces": [
    {
        "provinceid": "1",
        "provincename": "A"
    },
    {
        "provinceid": "2",
        "provincename": "B"
    }
]}

第二个微调JSON数据:(我的php和db中的省份有关。

//获取列出城市的值  $ provinceid = $ _POST ['provinceid'];)

{
"Cities": [
    {
        "cityid": "1",
        "cityname": "AA"
    },
    {
        "cityid": "2",
        "cityname": "BB"
    }
]}

这是我的java代码。

private ArrayList<String> province;
private ArrayList<String> city;
private JSONArray provinces;

String ilceid;

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

                ilce = new ArrayList<String>();

                //Initializing Spinner
                spinner = (Spinner) findViewById(R.id.spinner);
                spinner2 = (Spinner) findViewById(R.id.spinner2);


                //Adding an Item Selected Listener to our Spinner
                //As we have implemented the class Spinner.OnItemSelectedListener to this class iteself we are passing this to setOnItemSelectedListener
                spinner.setOnItemSelectedListener(WelcomeActivity.this);
                spinner2.setOnItemSelectedListener(WelcomeActivity.this);
                getData();

}


private void getData(){
    //Creating a string request
    StringRequest stringRequest = new StringRequest(SharedPrefManager.DATA_URL,
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    JSONObject j = null;
                    try {
                        //Parsing the fetched Json String to JSON Object
                        j = new JSONObject(response);

                        //Storing the Array of JSON String to our JSON Array
                        provinces= j.getJSONArray(SharedPrefManager.JSON_ARRAY);


                        getProvinces(provinces);
                    } catch (JSONException e) {
                        e.printStackTrace();
                    }
                }
            },
            new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {

                }
            });

    //Creating a request queue
    RequestQueue requestQueue = Volley.newRequestQueue(this);

    //Adding request to the queue
    requestQueue.add(stringRequest);
}
private void getProvinces(JSONArray j){
    //Traversing through all the items in the json array
    for(int i=0;i<j.length();i++){
        try {
            //Getting json object
            JSONObject json = j.getJSONObject(i);


            province.add(json.getString(SharedPrefManager.TAG_PROVINCENAME));
        } catch (JSONException e) {
            e.printStackTrace();
        }
    }

    //Setting adapter to show the items in the spinner
    spinner.setAdapter(new ArrayAdapter<String>(WelcomeActivity.this, android.R.layout.simple_spinner_dropdown_item, province));
}
private String getProvinceId(int position){
    String provid="";
    try {
        JSONObject json = provinces.getJSONObject(position);
        course = json.getString(SharedPrefManager.TAG_PROVINCEID);
    } catch (JSONException e) {
        e.printStackTrace();
    }
    return provid;
}


@Override
public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
}

@Override
public void onNothingSelected(AdapterView<?> parent) {
}}

在这种情况下,第一个微调器工作。但是我如何根据第一个微调器填充spinner2?

1 个答案:

答案 0 :(得分:0)

您甚至不需要从数据库获取数据,它们对所有用户都是相同的,并且无法更改,因此您可以将这些数据放入应用程序中。但是如果你真的需要它,那么当你选择第一个选项而不是你需要将它发布到db然后获得该选项的选项时,你就会分开。如果我理解你真正需要的东西,我认为没有别的办法了。