12

AutoCompleteTextView でカスタム アダプターを使用しています。エミュレーターとタブレットで正常に動作します。ただし、携帯電話を横向きにすると問題が発生します。このモードで表示されるオートコンプリートのヒントは、テキストではなくオブジェクト情報です。ただし、アイテムを選択すると、フィールドにはそれぞれのフィールドにテキストが正しく入力されます。

Android Stock Array Adapter に基づく他のフィールドのオートコンプリートは正常に機能します。

カスタム アダプタでこれを行う必要がありますか? SOで同様の質問を1つだけ見ました。その質問に対する回答の 1 つは、toString メソッドをオーバーライドすることについて話していましたが、自分のコードに実装するには十分に理解できませんでした。

ガイダンスをいただければ幸いです。さらに情報が必要な場合はお知らせください。

編集: カスタム アダプターのソース コードを追加しました....

  public class Part_Mstr_Info
  {
    private long part_id;
    private String name, desg, org, dept;

    public Part_Mstr_Info(long part_id, String name, String desg, String org, String dept)
    {
        this.part_id = part_id;
        this.name = name;
        this.desg = desg;
        this.org = org;
        this.dept = dept;
    }
    public long get_part_id() { return part_id; }
    public String get_name() { return name; }
    public String get_desg() { return desg; }
    public String get_org() { return org; }
    public String get_dept() { return dept; }
}

public class CustomAdapter extends ArrayAdapter<Part_Mstr_Info> implements Filterable{
   private List<Part_Mstr_Info> entries;
   private ArrayList<Part_Mstr_Info> orig;
   private Activity activity;
   private ArrayFilter myFilter;

   public CustomAdapter(Activity a, int textViewResourceId, ArrayList<Part_Mstr_Info> entries) {
    super(a, textViewResourceId, entries);
    this.entries = entries;
    this.activity = a;
}

public static class ViewHolder{
    public TextView tv_ac_name;
    public TextView tv_ac_desg;
    public TextView tv_ac_org;
    public TextView tv_ac_dept;
}

@Override
public int getCount(){
      return entries!=null ? entries.size() : 0;
}

@Override
public Part_Mstr_Info getItem(int index) {
    return entries.get(index);
}

@Override
public View getView(int position, View convertView, ViewGroup parent) {
    View v = convertView;
    ViewHolder holder;
    if (v == null) {
        LayoutInflater vi =
            (LayoutInflater)activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        v = vi.inflate(R.layout.ac_name_list, null);
        holder = new ViewHolder();
        holder.tv_ac_name = (TextView) v.findViewById(R.id.ac_name);
        holder.tv_ac_desg = (TextView) v.findViewById(R.id.ac_desg);
        holder.tv_ac_org = (TextView) v.findViewById(R.id.ac_org);
        holder.tv_ac_dept = (TextView) v.findViewById(R.id.ac_dept);
        v.setTag(holder);
    }
    else
        holder=(ViewHolder)v.getTag();

    final Part_Mstr_Info custom = entries.get(position);
    if (custom != null) {
        holder.tv_ac_name.setText(custom.get_name());
        holder.tv_ac_desg.setText(custom.get_desg());
        holder.tv_ac_org.setText(custom.get_org());
        holder.tv_ac_dept.setText(custom.get_dept());
    }
    return v;
}

@Override
public Filter getFilter() {
    if (myFilter == null){
        myFilter = new ArrayFilter();
    }
    return myFilter;
}

@Override
public String toString() {
    String temp = getClass().getName();
    return temp;
}

private class ArrayFilter extends Filter {
    @Override
    protected FilterResults performFiltering(CharSequence constraint) {
        FilterResults results = new FilterResults();
        if (orig == null)
            orig = new ArrayList<Part_Mstr_Info>(entries);
        if (constraint != null && constraint.length() != 0) {
            ArrayList<Part_Mstr_Info> resultsSuggestions = new ArrayList<Part_Mstr_Info>();
            for (int i = 0; i < orig.size(); i++) {
                if(orig.get(i).get_name().toLowerCase().startsWith(constraint.toString().toLowerCase())){
                    resultsSuggestions.add(orig.get(i));
                }
            }

            results.values = resultsSuggestions;
            results.count = resultsSuggestions.size();

        }
        else {
            ArrayList <Part_Mstr_Info> list = new ArrayList <Part_Mstr_Info>(orig);
            results.values = list;
            results.count = list.size();
        }
        return results;
    }

    @Override
    @SuppressWarnings("unchecked")
    protected void publishResults(CharSequence constraint, FilterResults results) {
        clear();
        ArrayList<Part_Mstr_Info> newValues = (ArrayList<Part_Mstr_Info>) results.values;
        if(newValues !=null) {
            for (int i = 0; i < newValues.size(); i++) {
                add(newValues.get(i));
            }
            if(results.count>0) {
                notifyDataSetChanged();
            } else {
                notifyDataSetInvalidated();
            }   
        }    

    }

}
4

5 に答える 5

10

これを行う正しい方法は、ArrayFilter プライベート クラスでメソッドFilter#convertResultToString(Object)をオーバーライドすることです。

Androidのドキュメントで述べたように

public CharSequence convertResultToString (Object resultValue)

フィルター処理されたセットの値を CharSequence に変換します。サブクラスは、このメソッドをオーバーライドして結果を変換する必要があります。デフォルトの実装では、null 値の場合は空の文字列、または値のデフォルトの文字列表現が返されます。

あなたの場合、それは次のようなものでなければなりません:

private class ArrayFilter extends Filter {
    @Override
    public CharSequence convertResultToString(Object resultValue) {
        return ((Part_Mstr_Info) resultValue).get_name();
    }

このメソッドを追加すると、オブジェクト参照またはデフォルトの toString の代わりに、AutoCompleteTextView が正しいヒントを (横向きビューで) 提供できるようになります。

于 2015-05-06T11:38:18.927 に答える
9

はい、POJO で toString() メソッドをオーバーライドするだけです。

public class MyObject {
    ...

    @Override
    public String toString() {
        return showThisStringOnAdapter;
    }
}
于 2012-10-02T01:14:36.490 に答える
3

を拡張するカスタム クラスを作成します<AutoCompleteTextView />。例えば:

package lt.irisas.akcija.utils;

import lt.irisas.akcija.data.ItemsModel;
import android.content.Context;
import android.database.Cursor;
import android.util.AttributeSet;
import android.widget.AutoCompleteTextView;

/** Customizing AutoCompleteTextView to return Cursor column info as String
*/
public class CustomAutoCompleteTextView extends AutoCompleteTextView {

    public CustomAutoCompleteTextView(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
    /* Overriding this method and returning String type solves the problem */
    @Override
    protected CharSequence convertSelectionToString(Object selectedItem) {
        Cursor c = (Cursor) selectedItem;

        return c.getString(c.getColumnIndex("COLUMN_NAME"));
    }
}

ただし、代わりに<AutoCompleteTextView/>カスタムのものを使用する必要があります。例えば:

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal" >

        <lt.irisas.akcija.utils.CustomAutoCompleteTextView
            android:id="@+id/search_field"
            android:layout_width="0dip"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:singleLine="true"
            android:imeOptions="actionSearch" >
        </lt.irisas.akcija.utils.CustomAutoCompleteTextView>
</LinearLayout>

それが役に立てば幸い。少なくとも私にとってはそうでした。

于 2012-10-17T12:54:12.140 に答える
0

前回答えを見つけました。同じ問題があり、オートコンプリートはnewView()およびbindView()メソッドの代わりにランドスケープモードでconvertToString()メソッドを使用しているようです。アイテムがソフトキーボード上に水平に表示されるように、すべてのカーソルデータを「\n」なしの単一の文字列に戻す必要があります。

AutoCompleteTextViewAdapterの例で、次のメソッドを追加します。

        @Override
    public CharSequence convertToString(Cursor cursor) {


        String name = cursor.getString(0);
        String number = cursor.getString(1);


        return name+" : "+number;
    }

私は自分の携帯電話XperiaUと別のGalaxyNoteでそれをテストしました、そしてそれは動作します。とても簡単です。もちろん、表示する内容に応じて、このメソッドにデータを入力します。

于 2013-01-25T10:10:50.243 に答える