Android: 使用AutoCompleteTextView中选定的项来填充另一个字段

5
我是一名有用的助手,可以为您翻译文本。
我正在尝试构建一个应用程序,其中员工的姓名存储在表中。在特定页面上,用户可以在自动完成文本视图中输入员工的姓名并选择弹出的建议之一。根据所选内容,我想在屏幕上填充其他字段。为此,我从读取的SQL Lite数据库返回一个二维字符串数组,其中包含数组名称、部门、设计等。名称数组提供自动完成视图。
现在问题在于onClickItemlistener方法返回的索引。返回的索引对应于最终显示的列表,在单击特定项之前,而不是传递的原始名称数组。
例如,如果我有以下2D数组:
    name            department             designation
   Abc1234            Dept1                   desg1
   Def1234            D2                       d2
   Abcxyz             D3                        d3
   Defabc             D4                       D5
   Abcdef             D6                       D6

现在,如果我在AutoCompleteTextView中输入“Abc”,只显示3个条目,如果我选择“Abcdef”,则返回的位置和id是2,而原始数组中的索引是5。我希望以某种方式返回这个5,这样我就可以得到相应的D6部门和职位值。
希望我的表述足够清晰。这是我学习安卓编程的第二周,请温柔一些。我已经在网上搜索了很多,但没有找到答案。
编辑:我最终创建了自定义适配器,但仍有一个问题存在......当按键时,我不知何故失去了CustomAdapter类中ArrayList对象的值。因此,在performFiltering方法的for循环中,“orig.size() > 0”的条件从未成功,自动完成不能正常工作......
下面是我设置适配器的方式...
      ArrayList<Part_Mstr_Info> mAllParts = partMstrDbHelper.getAll();
    if (mAllParts != null) {
    /*  ac_part_id = mAllParts.get_part_id();
        ac_name = mAllParts.get_name();
        ac_desg = mAllParts.get_desg();
        ac_org = mAllParts.get_org();
        ac_dept = mAllParts.get_dept();*/
        adapter = new CustomAdapter(this, R.layout.ac_name_list, mAllParts);
        mName.setAdapter(adapter);
        mName.setOnItemClickListener(new OnItemClickListener(){
        @Override
            public void onItemClick(AdapterView<?> adapter, View view, int index, long id) {

            Part_Mstr_Info part_mstr_info = (Part_Mstr_Info) adapter.getItemAtPosition(index);
            mPartMstrID = part_mstr_info.get_part_id();
            name = part_mstr_info.get_name();
            mName.setText(name);
            desg = part_mstr_info.get_desg();
            mDesg.setText(desg);
            org = part_mstr_info.get_org();
            mOrg.setText(org);
            dept = part_mstr_info.get_dept();
            mDept.setText(dept);
        }
        });

以下是我的自定义适配器的编写方式...
package com.meeting.minutes;

import java.util.ArrayList;

import android.app.Activity;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.Filter;
import android.widget.Filterable;
import android.widget.TextView;

import com.meeting.minutes.PartMstrDbAdapater.Part_Mstr_Info;

public class CustomAdapter extends ArrayAdapter<Part_Mstr_Info> implements Filterable{
    private ArrayList<Part_Mstr_Info> entries, 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;
        orig = this.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;
    }


    private class ArrayFilter extends Filter {
        @Override
        protected FilterResults performFiltering(CharSequence constraint) {
            if (orig == null)
                orig = entries;
            if (constraint != null) {
                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));
                    }
                }
                FilterResults results = new FilterResults();
                results.values = resultsSuggestions;
                results.count = resultsSuggestions.size();
                return results;
            }
            else {
                return new FilterResults();
            }
        }

        @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();
                }   
            }    

        }

    }
}

我创建了这个项目,参考了不同的网站和消息帖子以及Array Adapter的源代码...但是我无法理解为什么其他人都说这段代码可以运行,而我的却出现问题...非常感谢任何帮助...

2个回答

1

你可以为你的AutoCompleteTextView创建一个自定义适配器,该适配器包含所有信息,比如你有一个People类(姓名,部门,职位)。

像这样:

autoCompleteTextView.setAdapter(new CustomAdapter<People>(getBaseContext(),  android.R.layout.simple_list_item_1, "a list of all your people"))

那么您的意思是,我应该使用这个自定义适配器,而不是使用Array Adapter。我确实有一个类定义为People,就像您在这里提到的一样。让我尝试这个选项,并回复您结果。 - Sriman
1
似乎自定义适配器需要编写大量代码。 考虑其他解决方案(尽管不像这个那么优雅)... - Sriman
我尝试了自定义适配器但出现了问题。请看原始帖子中的修改并帮助我……感谢您的时间。 - Sriman

0
我找到问题了...它是因为在performFiltering方法中缺少了一段代码...当用于过滤列表的约束(或前缀)为空时,我们只需要将整个列表返回...一旦在约束的空检查的else中添加了这个,过滤就像黄金一样运作...
            ArrayList <Part_Mstr_Info> list = new ArrayList <Part_Mstr_Info>(orig);
            results.values = list;
            results.count = list.size();

你是如何返回与所选项对应的其他数据以填充其他字段的?我遇到了一个类似的问题,但我不知道如何返回JSON数组的其他值以填充其他字段。我是初学者。 - carefree
你需要定义一个包含所有所需数据的类。在我的情况下,Part_Mstr_Info是一个类,它包含了Name、Desg、Dept和Org字段。当你从下拉菜单中选择一个名称时,相关的职位、部门和组织信息将被获取并填充到屏幕上。 - Sriman

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接