AutoCompleteTextView принудительно показывает все элементы ИЛИ отключает фильтрацию

Я управляю AutoCompleteTextView, который должен давать все города (деревни), найденные в моей БД, в соответствии с 4 первыми буквами, которые я ввел.

Async task работает хорошо и получает правильные данные.

Моя проблема в том, что DropDownList отображает НЕ все элементы. Часто только 1, 2, 3 или 4 из 20 возвращаемых БД.

Итак, я понял, что в самом ACTV должна быть какая-то автоматическая фильтрация! Я проверяю много тем здесь, на SO, чтобы обновить свой код, но мне это не удалось.... :-(

Я продолжаю получать ошибки, не зная точно, в чем проблема! :-(

Итак, вот мой код:

class MyActivity extends Activity implements AdapterView.OnItemClickListener
{
        static class Ville 
        {
            String id;
            String name;

            @Override
            public String toString() { return this.name; }
        };

        ArrayAdapter<Ville>    villeAdapter;
        String                 villeAdapterFilter;
        VilleUpdateTask        villeAdapterUpdateTask;
        AutoCompleteTextView   villeText;
        Ville                  selectedVille;

        final TextWatcher textChecker = new TextWatcher() {

            public void afterTextChanged(Editable s) {}

            public void beforeTextChanged(CharSequence s, int start, int count, int after) {}

            public void onTextChanged(CharSequence s, int start, int before, int count)
            { 
                  MyActivity.this.setAdapterFilter(s.toString());
            }

        };

        public void onCreate(Bundle bundle)
        {
             super.onCreate(bundle);
             setContentView(R.layout.main);

             this.villeAdapter = new ArrayAdapter<Ville>(this,android.R.layout.simple_dropdown_item_1line, new Ville[0]);
             this.villeText = (AutoCompleteTextView ) findViewById(R.id.villeSelector);
             this.villeText.setAdapter(this.villeAdapter);
             this.villeText.setThreshold(THRESHOLD_DROPDOWN); 
             this.villeText.setOnItemClickListener(this);
             this.villeText.addTextChangedListener(textChecker);
        }

        public void onDestroy() { stopVilleAdapterUpdate(); 


        public void setAdapterFilter(String filter)
        {
             if (filter == null) {
                 // clearing the adapter
                 this.villeAdapterFilter = null;
                 this.villeAdapter.clear();
                 this.villeAdapter.notifyDataSetChanged();
                 Log.d("MyActivity","Clearing ville filter !");
             } else if (filter.length() > THRESHOLD_QUERY) {
                  if (this.villeAdapterFilter == null) {
                      Log.d("MyActivity","Ville Adapter Filter defined to:"+filter);
                      this.villeAdapterFilter = filter;
                      startVilleAdapterUpdate();
                  } else {
                      Log.d("MyActivity","Already filtered with:"+this.villeAdapterFilter);
                  }
             } else {
                  Log.d("MyActivity","Resetting filter (not enough data)");
                  this.villeAdapterFilter = null;
                 this.villeAdapter.clear();
                 this.villeAdapter.notifyDataSetChanged();
             }
        }

        public synchronized void onItemClick(ViewAdapter<?> ad, View v, int position, long id)
        {
             this.selectedVille = this.villeAdapter.getItemAtPosition(position);
             Log.d("MyActivity","Ville selected: "+this.selectedVille);
        }

        public synchronized void startVilleAdapterUpdate()
        {
              stopVilleAdapterUpdate();
              Log.d("MyActivity","Starting Update of Villes with "+this.villeAdapterFilter);
              this.villeAdapterUpdateTask = new VilleUpdateTask();
              this.villeAdapterUpdateTask.execute(this.villeAdapterFilter);
        }

        public synchronized void stopVilleAdapterUpdate()
        {
             if (this.villeAdapterUpdateTask != null) {
                 Log.d("MyActivity","Stopping current update of villes");
                 this.villeAdapterUpdateTask.cancel(true);
                 this.villeAdapterUpdateTask = null;
             }
        }

        public synchronized void onVilleAdapterUpdateResult(Ville[] data)
        {
             this.villeAdapterUpdateTask = null;
             if (data != null) {
                 Log.d("MyActivity","Received "+data.length+" villes from update task");
                 this.villeAdapter.clear();
                 this.villeAdapter.addAll(data);
                 this.villeAdapter.notifyDataSetChanged(); // mise à jour du drop down...
            }
        } 

        class VilleUpdateTask extends AsyncTask<String,Void,Ville[]>
        {
              public Ville[] doInBackground(String ... filters)
              {
                  ArrayList<Ville> values = new ArrayList<Ville>();
                  try  {
                       HttpClient httpclient = new DefaultHttpClient();
                       ....
                       ....
                       for(int i=0;i<json_array.length();i++) {
                           JSONObject json_ligne = json_array.getJSONObject(i);   
                           try {
                               Ville v = new Ville();
                               v.name = json_ligne.getString("NAME_VILLE");
                               v.id = json_ligne.getString("ID_VILLE");
                               values.add(v);
                           } catch (Exception ex) {
                               Log.w("VilleUpdateTask","Invalid value for Ville at index #"+i,ex);
                           }
                       }
                  } catch (Exception ex) {
                       Log.e("VilleUpdateTask","Failed to retrieve list of Ville !",ex);
                  }
                  return values.toArray(new Ville[values.size()]);
             }

             public void onPostExecute(Ville[] data)
             {
                 MyActivity.this.onVilleAdapterUpdateResult(data);
             }
        }

}

РЕДАКТИРОВАТЬ 1: да, извините, мой ACTV - это базовый TextView, это не проблема прокрутки, потому что в лучшем случае я вижу 10 элементов в списке, а последняя позиция случайна

РЕДАКТИРОВАТЬ 2: не могли бы вы просто помочь мне адаптировать мой существующий код к данным решениям из двух приведенных выше URL-адресов?

(1) в соответствии с этим решением AutoCompleteTextView - отключить фильтрацию

Я должен:

  • создайте мой класс ClassMyACArrayAdapter, который совпадает с данным, только его имя меняется

  • изменить мою декларацию с

    ArrayAdapter villeAdapter;

to

List<ClassMyACArrayAdapter> villeAdapter;
  • но в onCreate что должно заменить исходное

    this.villeAdapter = новый ArrayAdapter
    (this,android.R.layout.simple_dropdown_item_1line, новый Ville[0]);


person Steph68    schedule 17.12.2012    source источник


Ответы (2)


Просто позвоните autoCompleteTextView.showDropDown() всякий раз, когда вам это нужно..... ура :)

person Melbourne Lopes    schedule 06.02.2014
comment
Спасибо, действительно помогло выйти из тупика после часа. - person Deven; 30.11.2019

Является ли ваш AutoCompleteTextView TextView, LinearLayout или ListView? Код в вашей активности выглядит нормально, поэтому я предполагаю, что проблема может быть в макете (возможно, вы не используете прокрутку, поэтому видите только первые значения).

Кроме того, значения, которые вы видите, всегда являются первыми в возвращаемом списке или они находятся в случайных позициях?

person Aballano    schedule 17.12.2012