Android-просмотр списка XML с фильтром

1

Андроид для меня новый. Я пытаюсь разработать программу на платформе 1.5, но все еще в процессе, PLZ руководство меня.

У меня есть некоторая информация в следующем формате

"item1","description1"
"item2","description2"
"item3","description3"
"item4","description4"
.
.
.
.

Я хочу показать их на экране, я не знаю, какой из них рекомендуется делать. После google я нашел 2 метода. но я не смог успешно реализовать ни один из них.

Метод 1

Я разбиваю данные обоих столбцов на 2 разных массива, затем заполняю listactivity с массивом столбца 1, включить фильтр и событие с кликом. Я хочу поднять предупреждение, которое должно показывать текст, нажатый в тильте и desc из второго массива, как тело msg, основанное на позиции. Но вот проблема, если использование индекса фильтра будет повторно инициализироваться:-(, и там не нашел другого способа получить текст этой строки.


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

   setListAdapter(new ArrayAdapter<String>(this, 
                               android.R.layout.simple_list_item_1, Names));    
   getListView().setTextFilterEnabled(true);

} 

public void onListItemClick(ListView parent, View v, int position, long id) {

    Builder builder = new AlertDialog.Builder(this);
    builder.setTitle(Names[position]); 
    builder.setMessage(description[position] + " -> " + position );
    builder.setPositiveButton("ok", null);
    builder.show();
}

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<TextView 
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="@string/hello"
    />
</LinearLayout>

не выбирает правильный элемент из позиции, если используется фильтр:-(, plz guide Вы можете поделиться исходным кодом этого

Метод B

Здесь я попытался сгенерировать строку списка из XML, но дал ошибку, что файл 1.5 jar не разрешил модификацию: - (


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

            /*       
            ViewInflate inflater=context.getViewInflate();
            View row=inflater.inflate(R.layout.row, null, null);
            */

            View row = (View) convertView;

            if (row==null) {
                LayoutInflater  inflater=context.getLayoutInflater();
            //    LayoutInflater inflater = (LayoutInflater)  context.getSystemService(context.LAYOUT_INFLATER_SERVICE);
                  row = inflater.inflate(R.layout.row,null);
            }

            TextView label=(TextView)row.findViewById(R.id.label);
            label.setText(items[position]);

            TextView description=(TextView)row.findViewById(R.id.description);
            description.setText(items[position]);

            //    ImageView icon=(ImageView)row.findViewById(R.id.icon);
            //    icon.setImageResource(R.drawable.delete);


            return(row);
        }

Plz предложит, что это правильный путь, чтобы приспособиться к этому, поэтому приложение может показывать desc of item, также имеет фильтр. Plz share Если у вас есть код shouce для этого

Теги:

1 ответ

7

Решение, которое вы выбираете, строго зависит от ваших потребностей. Я постараюсь собрать требования и предоставить вам реализацию, которая, по моему мнению, является наиболее подходящей.
Итак, давайте перечислим некоторые требования:

  • должен быть настраиваемый макет для элемента списка
  • есть пользовательские данные, в вашем случае это две строки: "item" и "description
  • должна быть возможность отфильтровать список
  • список элементов может быть очень длинным

Стоит упомянуть:
- Если у вас есть пользовательские данные, которые вам нужно отображать, и это не просто вектор строк, тогда хорошая идея - предоставить свой собственный тип данных. Достаточно удобно хранить все данные строк в одном месте, даже если некоторые данные не отображаются в списке. Отражая ваш пример: у вас есть "элемент" и "описание" - вы можете отображать только "элемент", но вы хотите иметь возможность получить описание. Храните это, например, в одном классе. В приведенном ниже примере это класс RowData. См. Класс RowData.

- Если вы хотите создать собственный макет, и это не просто TextView, тогда вы должны реализовать свой собственный адаптер - возможно, подкласс ArrayAdapter. Ознакомьтесь с классом CustomAdapter.

- Если вам нужно отфильтровать список, и вы используете пользовательский тип данных - укажите метод toString() для вашего типа. Благодаря этому методу вы сможете использовать встроенный класс Filter. Его ответственность - отфильтровать элементы из списка, который не соответствует введенному вами тексту. Он просто принимает текстовое представление элементов из вашего адаптера и использует его с фильтром. См. Метод toString() из класса RowData.

- Если список элементов может быть длинным, хорошей идеей было бы повторно использовать представления строк и использовать шаблон оболочки. См. Метод getView() и класс ViewHolder.



public class CustomList extends ListActivity {
    private LayoutInflater mInflater;
    private Vector data;

 /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);        
        mInflater = (LayoutInflater) getSystemService(Activity.LAYOUT_INFLATER_SERVICE);
        data = new Vector();
        RowData rd = new RowData("aaa", "description1");
        data.add(rd);
        rd = new RowData("bbb", "description2");
        data.add(rd);
        rd = new RowData("ccc", "description3");
        data.add(rd);

        CustomAdapter adapter = new CustomAdapter(this, R.layout.custom_row,R.id.item, data);
        setListAdapter(adapter);
        getListView().setTextFilterEnabled(true);
    }


    public void onListItemClick(ListView parent, View v, int position, long id) {
     CustomAdapter adapter = (CustomAdapter) parent.getAdapter();
  RowData row = adapter.getItem(position);  
     Builder builder = new AlertDialog.Builder(this);
     builder.setTitle(row.mItem); 
     builder.setMessage(row.mDescription + " -> " + position );
     builder.setPositiveButton("ok", null);
     builder.show();
 }

    /**
     * Data type used for custom adapter. Single item of the adapter.      
     */
    private class RowData {
     protected String mItem;
  protected String mDescription;

  RowData(String item, String description){
      mItem = item;
      mDescription = description;      
     }

  @Override
  public String toString() {
   return mItem + " " +  mDescription;
  }
    }

    private class CustomAdapter extends ArrayAdapter {

  public CustomAdapter(Context context, int resource,
    int textViewResourceId, List objects) {
   super(context, resource, textViewResourceId, objects);

  }

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
   ViewHolder holder = null;

   //widgets displayed by each item in your list
   TextView item = null;
   TextView description = null;

   //data from your adapter
   RowData rowData= getItem(position);


   //we want to reuse already constructed row views...
   if(null == convertView){
    convertView = mInflater.inflate(R.layout.custom_row, null);
    holder = new ViewHolder(convertView);
    convertView.setTag(holder);
   }
   // 
   holder = (ViewHolder) convertView.getTag();
   item = holder.getItem();
   item.setText(rowData.mItem);

   description = holder.getDescription();  
   description.setText(rowData.mDescription);

   return convertView;
  }
    }

    /**
     * Wrapper for row data.
     *
     */
    private class ViewHolder {     
     private View mRow;
     private TextView description = null;
     private TextView item = null;

  public ViewHolder(View row) {
      mRow = row;
  }

  public TextView getDescription() {
   if(null == description){
    description = (TextView) mRow.findViewById(R.id.description);
   }
   return description;
  }

  public TextView getItem() {
   if(null == item){
    item = (TextView) mRow.findViewById(R.id.item);
   }
   return item;
  }     
    }
}

Макет пользовательского элемента:

<TextView android:text="text" android:id="@+id/item"
    android:layout_width="wrap_content" android:layout_height="wrap_content"
    android:layout_toRightOf="@+id/button" android:paddingRight="10dip"
    android:paddingLeft="10dip"></TextView>

<TextView android:text="text" android:id="@+id/description"
    android:layout_width="wrap_content" android:layout_height="wrap_content"
    android:layout_toRightOf="@+id/item" android:paddingLeft="10dip"
    android:paddingRight="10dip"></TextView>

Ещё вопросы

Сообщество Overcoder
Наверх
Меню