使用带有微调器的setOnItemSelectedListener和onNothingSelected

时间:2016-02-14 15:35:08

标签: java android drop-down-menu spinner android-spinner

我只是想知道是否有人可以帮我解决我目前面临的问题,因为我正在尝试使用微调器实现setOnItemSelectedListener和onNothingSelected事件。

一旦用户从微调器中选择选项,它将向他们显示谷歌地名,然后当用户点击一个地方时,它将显示另一个名为details.java的页面,其中包含该地点和mapview的详细信息。

我认为我错误地使用了这两个特定选项,因此请有人帮忙并建议我吗?

public class PlaceActivity extends AppCompatActivity implements
        AdapterView.OnItemSelectedListener {

    public ArrayList<GetterSetter> myArrayList;
    private Toolbar toolbar;
    private Spinner spinner;
    ListView myList;
    private String[] places;
    ProgressDialog dialog;
    TextView nodata;
    PlaceAdapter adapter;
    GetterSetter addValues;


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

        if (!isNetworkAvailable()) {
            Toast.makeText(getApplicationContext(), "Enable internet connection and RE-LAUNCH!!",
                    Toast.LENGTH_LONG).show();
            return;
        }

        myList = (ListView) findViewById(R.id.myList);
        toolbar = (Toolbar) findViewById(R.id.tool_bar);
        places = getResources().getStringArray(R.array.places);

        setSupportActionBar(toolbar);
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        setTitle("Title");

        spinner  = (Spinner) findViewById(R.id.spinnerplaces);


        // Create an ArrayAdapter using the string array and a default spinner
        ArrayAdapter<CharSequence> listAdapter = ArrayAdapter
                .createFromResource(this, R.array.places,
                        android.R.layout.simple_spinner_item);

        // Specify the layout to use when the list of choices appears
        listAdapter
                .setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

        // Apply the adapter to the spinner
        spinner.setAdapter(listAdapter);
        ArrayAdapter<CharSequence> list = ArrayAdapter.createFromResource(PlaceActivity.this, R.array.places,android.R.layout.simple_spinner_item);
        list.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);

        spinner.setOnItemSelectedListener(this);
    }


    private boolean isNetworkAvailable() {
        ConnectivityManager connectivityManager = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
        NetworkInfo activeNetworkInfo = connectivityManager.getActiveNetworkInfo();
        return activeNetworkInfo != null;
    }

    @Override
    public void onItemSelected(AdapterView<?> parent, View view,  int itemPosition, long itemId) {
        dialog = ProgressDialog.show(this, "", "Please wait", true);
        // Google Places Access key and location values.
        new readFromGooglePlaceAPI()
                .execute("https://maps.googleapis.com/maps/api/place/nearbysearch/json?"
                        + "location=53.795984,-1.759398&radius=900&sensor=true&"
                        + "key=AIzaSyA7CzOa10AOfBAU9FvaIrVlVyCKzXxiCc0&types="
                        + places[itemPosition]);
        myList.OnItemSelectedListener(this);
        return true;


    }

    public class readFromGooglePlaceAPI extends AsyncTask<String, Void, String> {
        @Override protected String doInBackground(String... param) {
            return readJSON(param[0]);
        }

        protected void onPostExecute(String str) {
            myArrayList = new ArrayList<GetterSetter>();
            try {
                JSONObject root = new JSONObject(str);
                JSONArray results = root.getJSONArray("results");
                for (int i = 0; i < results.length(); i++) {
                    JSONObject arrayItems = results.getJSONObject(i);
                    JSONObject geometry = arrayItems.getJSONObject("geometry");
                    JSONObject location = geometry.getJSONObject("location");
                    addValues = new GetterSetter();
                    addValues.setLat(location.getString("lat"));
                    addValues.setLon(location.getString("lng"));
                    addValues.setName(arrayItems.getString("name").toString());
                    addValues.setRating(arrayItems.getString("rating").toString());
                    addValues.setVicinity(arrayItems.getString("vicinity").toString());
                    myArrayList.add(addValues);

                    Log.d("Before", myArrayList.toString());

                }

            } catch (Exception e) {

            }
            System.out
                    .println("############################################################################");
            Log.d("After:", myArrayList.toString());
            nodata = (TextView) findViewById(R.id.nodata);
            nodata.setVisibility(View.GONE);
            adapter = new PlaceAdapter(PlaceActivity.this, R.layout.list_row, myArrayList);
            myList.setAdapter(adapter);
            adapter.notifyDataSetChanged();
            dialog.dismiss();
        }

    }

    public String readJSON(String URL) {
        StringBuilder sb = new StringBuilder();
        HttpGet httpGet = new HttpGet(URL);
        HttpClient client = new DefaultHttpClient();

        try {
            HttpResponse response = client.execute(httpGet);
            StatusLine statusLine = response.getStatusLine();
            if (statusLine.getStatusCode() == 200) {
                HttpEntity entity = response.getEntity();
                InputStream content = entity.getContent();
                BufferedReader reader = new BufferedReader(new InputStreamReader(content));
                String line;

                while ((line = reader.readLine()) != null) {
                    sb.append(line);
                }
            } else {
                Log.e("JSON", "Couldn't find JSON file");
            }
        } catch (ClientProtocolException e) {
            e.printStackTrace();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return sb.toString();
    }
    @Override
    public void onNothingSelected(AdapterView<?> parent) {
        // no-op
    }

我在哪里放下以下代码。

 @Override public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
        Intent details = new Intent(MainActivity.this, Details.class);
        details.putExtra("name", myArrayList.get(arg2).getName());
        details.putExtra("rating", myArrayList.get(arg2).getRating());
        details.putExtra("vicinity", myArrayList.get(arg2).getVicinity());
        details.putExtra("lat", myArrayList.get(arg2).getLat());
        details.putExtra("lon", myArrayList.get(arg2).getLon());
        startActivity(details);
    }

2 个答案:

答案 0 :(得分:1)

你的方向正确。现在你有了必要的方法,但是你已经让你的类实现OnItemSelectedListener并将它设置为你的微调器的监听器:

公共类PlaceActivity扩展了AppCompatActivity  实现OnItemSelectedListener {     ... }

然后将类设置为侦听器,您可以在以下后面添加以下行:spinner =(Spinner)findViewById(R.id.spinnerplaces);

spinner.setOnItemSelectedListener(this);

答案 1 :(得分:0)

我建议这样的事情:

spinner.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {

    @Override
    public void onItemSelected(AdapterView<?> parent, View view, 
                               int pos, long id) {
//If you're wondering, int pos is the position of the item selected (starting with 0)
// what you want onClick
}

您的代码:

 @Override public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
        Intent details = new Intent(MainActivity.this, Details.class);
        details.putExtra("name", myArrayList.get(arg2).getName());
        details.putExtra("rating", myArrayList.get(arg2).getRating());
        details.putExtra("vicinity", myArrayList.get(arg2).getVicinity());
        details.putExtra("lat", myArrayList.get(arg2).getLat());
        details.putExtra("lon", myArrayList.get(arg2).getLon());
        startActivity(details);
    }

可以低于微调器的初始化。

希望它有所帮助!祝你好运!