AutoCompleteTextView使用小結

gcd8 9年前發布 | 1K 次閱讀 Java Android

AutoCompleteTextView這個控件用于輸入框的自動完成提示,非常適合搜索框等。它本質上是個EditText,實際上它也是從EditText繼承的,使用起來也十分簡單。

使用要點如下:

  1. 利用ListAdapter(一般使用ArrayAdapter)為AutoCompleteTextView提供數據,若有需要還可以重載getView()以自定義列表項的顯示方式。這一步同ListView
  2. 如果需要根據輸入內容進行動態提示,那么adapter需要實現Filterable接口,重載getFilter()函數實現提示算法。getFilter()需返回Filter對象,該對象包含至少兩個方法:performFiltering()在后臺執行過濾,publishResults()在UI線程執行,負責將過濾結果顯示到列表中。還有第三個方法convertResultToString()可以控制用戶點擊提示時要填充至輸入框的文本內容。

示例代碼大致如下。

AutoCompleteTextView autoComplete = new AutoCompleteTextView(context);
autoComplete.setThreshold(2);      // 設置最少幾個字符觸發自動完成
MyAdapter adapter = new MyAdapter(context);
autoComplete.setAdapter(adapter);

/**

  • Adapter定義 */ class MyAdapter extends ArrayAdapter<MyObject> implements Filterable{

    @Override public View getView(int position, View convertView, ViewGroup parent) {

     // define your list item view here 在此處定義列表項的視圖
    

    }

    /**

    • 實現自動完成的過濾算法 */ @Override public Filter getFilter() { Filter filter = new Filter() {

       /**
        * 本方法在后臺線程執行,定義過濾算法
        */
       @Override
       protected FilterResults performFiltering(CharSequence constraint) {
           String keyword = String.valueOf(constraint).toLowerCase();
           // 此處實現過濾
      
           // 過濾后利用FilterResults將過濾結果返回
           FilterResults filterResults = new FilterResults();
           filterResults.values = results;   // results是上面的過濾結果
           filterResults.count = results.size();  // 結果數量
      
           return filterResults;
       }
      
       /**
        * 本方法在UI線程執行,用于更新自動完成列表
        */
       @Override
       protected void publishResults(CharSequence constraint, FilterResults results) {
           if (results != null && results.count > 0) {
               // 有過濾結果,顯示自動完成列表
               MyAdapter.this.clear();   // 清空舊列表
               MyAdapter.this.addAll((List<MyObject>)results.values);
               notifiDataSetChanged();
           } else {
               // 無過濾結果,關閉列表
               notifyDataSetInvalidated();
           }
       }
      
       /**
        * 如果需要控制提示文本的顯示方式,重載此函數
        */
       @Override
       public CharSequence convertResultToString(Object resultValue) {
           MyObject obj = (MyObject) resultValue;
           return obj.name;
       }
      
      

      }; } }</pre>

 本文由用戶 gcd8 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!