Подтвердить что ты не робот

Оптимизация привязки CursorAdapter

При переопределении ArrayAdapter я знаю правильно, используя шаблон, подобный этому:

if(view != null){
   ...create new view setting fields from data 
}else
  return view; //reuse view

тоже верно, используя этот шаблон с помощью CursorAdapters? Моя проблема заключается в том, что у меня есть цвет текста, который может быть красным или синим в соответствии с полем курсора, поэтому я не хочу никаких ошибок, таких как красный цвет в ячейке, где есть поле, требующее синего цвета. Мой код bindView выглядит примерно так:

if(c.getString(2).equals("red"))
      textView.setTextColor(<red here>);
   else
      textView.setTextColor(<blue here>);

Если я повторно использую представление, могу ли я быть уверенным, что красный загорается красным, а синий - синим?

4b9b3361

Ответ 1

В CursorAdapter вы получите макет в newView и привяжите данные в bindView. CursorAdapter уже сделать шаблон повторного использования в getView, чтобы не нужно было повторять его снова. Ниже приведен исходный исходный код getView.

  public View getView(int position, View convertView, ViewGroup parent) {
    if (!mDataValid) {
        throw new IllegalStateException("this should only be called when the cursor is valid");
    }
    if (!mCursor.moveToPosition(position)) {
        throw new IllegalStateException("couldn't move cursor to position " + position);
    }
    View v;
    if (convertView == null) {
        v = newView(mContext, mCursor, parent);
    } else {
        v = convertView;
    }
    bindView(v, mContext, mCursor);
    return v;
}

Если вы хотите продолжить оптимизацию с помощью ViewHolder Pattern, вот пример: Создать тег в newView и получить в bindView

    public class TimeListAdapter extends CursorAdapter {
     private LayoutInflater inflater;
     private    static  class   ViewHolder  {
         int    nameIndex;
         int    timeIndex;
         TextView   name;
         TextView   time;
    }
  public TimeListAdapter(Context context, Cursor c, int flags) {
    super(context, c, flags);
  this.inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  }
  @Override
  public void bindView(View view, Context context, Cursor cursor) {
         ViewHolder holder  =   (ViewHolder)    view.getTag();
         holder.name.setText(cursor.getString(holder.nameIndex));
         holder.time.setText(cursor.getString(holder.timeIndex));
  }
  @Override
  public View newView(Context context, Cursor cursor, ViewGroup  
  p parent) {
         View   view    =   inflater.inflate(R.layout.time_row, null);
         ViewHolder holder  =   new ViewHolder();
         holder.name    =   (TextView)  view.findViewById(R.id.task_name);
         holder.time    =   (TextView)  view.findViewById(R.id.task_time);
     holder.nameIndex   =   cursor.getColumnIndexOrThrow    
         p (TaskProvider.Task.NAME);
         holder.timeIndex   =   cursor.getColumnIndexOrThrow    
         p (TaskProvider.Task.DATE);
         view.setTag(holder);
    return view;
  }
}

Ответ 2

Да, getView находится в Adapter и не зависит от ArrayAdapter и CursorAdapter.

рециркуляция всегда является хорошей практикой. Убедитесь, что ваш код задает цвет в каждой ситуации.