0

これは、スピナーにデータを入力するコードです。

コード:

String[] rcs = new String[review_cycles.length];
for (int i = 0; i < review_cycles.length; i++)
    rcs[i] = review_cycles[i].ReviewCycleName;
ArrayAdapter<String> rc_spinnerAdapter = new ArrayAdapter<String>(
        ActivityManagementReview.this,
        R.layout.simple_spinner_item, 
        rcs);
sp_review_cycle.setAdapter(rc_spinnerAdapter);
sp_review_cycle.setOnItemSelectedListener(new OnItemSelectedListener() {
    @Override
    public void onItemSelected(AdapterView<?> parentView, View selectedItemView, int position, long id) {
        DtoMrReviewCycleVersion selected_review_cycle_version = review_cycles[position];
        if (selected_review_cycle_version != latest_review_cycle_version) {
            latest_review_cycle_version = selected_review_cycle_version;
            int mr_version_id = latest_review_cycle_version.MrdVersionId;
            _URL_version = _url_base + "MrVersion/" + Integer.toString(mr_version_id);
            new GetMrVersionInfoAsyncTask().execute();
        }
    }

    @Override
    public void onNothingSelected(AdapterView<?> parentView) {
        return;
    }
});

スピナーから値を選択すると、コードが 2 回実行されます。選択した直後に、リストの最初の項目が再び実行され、開始した場所に戻ります。

どうすればこれを防ぐことができますか?

ありがとう。

4

1 に答える 1

1

スピナーから値を選択すると、コードが2回実行されます。

コメントで思い出したように、スピナーonItemSelected()はデフォルト値をロードするときに呼び出します。この機能は、知っている場合に便利ですが、平均的な開発者が期待するものではないため、問題もあります。

ユーザーが現在の値を再選択したときにもスピナーが呼び出さonItemSelected()れます...これらの誤ったアラームの両方を回避したい場合は、次のようなものを使用します。

spinner.setOnItemSelectedListener(new OnItemSelectedListener() {
    int previous = -1;
    @Override
    public void onItemSelected(AdapterView<?> parent, View view, int position, long id) {
        if(previous != position && previous < -1) {
            Log.v("Example", "Selected: " + position);
            // Do something
        }
        previous = position;
    }

    @Override
    public void onNothingSelected(AdapterView<?> parent) {}
});
于 2013-01-01T22:37:05.690 に答える