Android: использование элемента, выбранного в AutoCompleteTextView, для заполнения другого поля - PullRequest
5 голосов
/ 24 февраля 2012

Я пытаюсь создать приложение, в котором имена сотрудников хранятся в таблице. На определенной странице пользователь может ввести имя сотрудника в текстовое представление автозаполнения и выбрать одно из всплывающих предложений. Основываясь на том, что было выбрано, я хочу заполнить другие поля на экране. Для этого я возвращаю двумерный строковый массив из базы данных SQL Lite для чтения, содержащий имена массивов, dept, desg и т. Д. ... Массив имен подается в представлении «Автозаполнение».

Теперь проблема связана с индексом, который возвращается в методе onClickItemlistener. Возвращаемый индекс соответствует списку, который был окончательно отображен до нажатия на конкретный элемент, а не тому массиву исходных имен, который был прошло.

Например, если у меня есть массив 2d, например:

    name            department             designation
   Abc1234            Dept1                   desg1
   Def1234            D2                       d2
   Abcxyz             D3                        d3
   Defabc             D4                       D5
   Abcdef             D6                       D6

Теперь, если я набираю Abc в AutoCompleteTextView, отображаются только 3 элемента, и если я выбираю Abcdef, возвращаемая позиция и идентификатор равны 2, тогда как индекс в исходном массиве равен 5. Я хочу, чтобы эти 5 возвращались как-то так, чтобы я можно получить соответствующие значения dept и desg для D6 ..

Надеюсь, я достаточно ясен .. Это моя вторая неделя программирования для Android .. поэтому, пожалуйста, будьте осторожны .. Я уже достаточно искал в Интернете, но не смог найти ответ на этот вопрос ..

EDIT ::: Я наконец-то закончил тем, что создал Customer Adapter, но осталась еще одна проблема ... Я почему-то теряю значение объекта ArrayList в классе CustomAdapter при нажатии клавиши .. Так что, по сути, условие «orig.size ()> 0» в цикле for метода executeFiltering никогда не завершается успешно, и автозаполнение не работает ...

Ниже показано, как я настраиваю адаптер ...

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

        }

    }
}

Я создал это, видя различные веб-сайты и различные сообщения, а также исходный код адаптера массива ... Не могу понять, где у меня дела идут не так, когда несколько других людей отметили, что тот же код работает для них .... Любая помощь с благодарностью ....

Ответы [ 2 ]

0 голосов
/ 25 февраля 2012

Я обнаружил проблему .... Это было из-за отсутствующего фрагмента кода в методе executeFiltering ... Когда ограничение (или префикс), по которому должен фильтроваться список, является нулевым, нам просто нужно вернутьвесь список обратно .... После того, как это было добавлено в else для проверки на ноль ограничений, фильтрация работает как золотая ....

            ArrayList <Part_Mstr_Info> list = new ArrayList <Part_Mstr_Info>(orig);
            results.values = list;
            results.count = list.size();
0 голосов
/ 24 февраля 2012

Вы можете создать собственный адаптер для вашего AutoCompleteTextView, который содержит всю информацию, например, у вас есть класс People (имя, отдел, назначение).

Что-то вроде

autoCompleteTextView.setAdapter(new CustomAdapter<People>(getBaseContext(),  android.R.layout.simple_list_item_1, "a list of all your people"))
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...