ArrayAdapter上的视图持有人缓存模式具有连锁反应



我一直在遵循代码下方的listView的视图持有人模式。实际上它运行良好 - 但是我有问题。

我的适配器中的项目具有以下布局:

================================================================
|    Item title                    |AddIcon|RemoveIcon|EditIcon|
================================================================

问题是:当我单击删除措施时,代码运行后,我希望emovericon更改颜色。我在下面的代码的第二层线中使用setimageresource做到这一点。现在这也可以正常工作 - 图标更改。但是现在,当我滚动时,在每个特定的间隔(在我的手机上是8个项目)时,图标也会更改。看起来像是在这里踢了吗?

问题:

  1. 当布局本质上是每个项目的个体时,我可以使用此缓存吗?
  2. 如果我也许不能,可以使用未接近的布局并为每个项目重复它吗?目前,我可能有大约100个项目。有更好的方法吗?

    public class ItemListAdapter extends ArrayAdapter<StoreItem> {
        static class ViewHolder {
            public TextView title;
            public ImageButton more;
            public ImageButton less;
            public ImageButton edit;
        }
    
        @Override
        public View getView(final int position, View convertView, ViewGroup parent) {
            View rowView = convertView;
            // reuse views
            if (rowView == null) {
                LayoutInflater inflater = mContext.getLayoutInflater();
                rowView = inflater.inflate(R.layout.item_layout, parent, false);
                ViewHolder viewHolder = new ViewHolder();
                viewHolder.title = (TextView) rowView.findViewById(R.id.title);
                viewHolder.more = (ImageButton) rowView.findViewById(R.id.item_mas);
                viewHolder.less = (ImageButton) rowView.findViewById(R.id.item_menos);
                viewHolder.edit = (ImageButton) rowView.findViewById(R.id.item_edit);
                rowView.setTag(viewHolder);
            }
            final ViewHolder holder = (ViewHolder) rowView.getTag();
            final StoreItem item = mItems.get(position);
            holder.title.setText(item.getTitle());
            holder.less.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    //dialog is a confirmation dialog, initialization omittted for brevity
                    dialog.setConfirmClickListener(new View.OnClickListener() {
                        @Override
                        public void onClick(View v) {
                            removeItem(item, v);
                            holder.less.setImageResource(R.drawable.x_ok);
                            dialog.getDialog().cancel();
                        }
                    });
                }
            });
    

项目的颜色是一种状态。当使用任何类型的缓存模式(例如视图持有人模式)时,您必须确保在设置视图时表示该状态。

这里的问题不是您在单击时将可绘制的绘制更改为 R.drawable.x_ok,问题是您不考虑初始设置中未点击的状态。

首先,将状态保存在您的持有器对象中

public void onClick(View v) {
    removeItem(item, v);
    holder.setLessClicked(true);
    holder.less.setImageResource(R.drawable.x_ok);
    dialog.getDialog().cancel();
}

现在,每当您通过GetView方法时,都会正确应用该状态:

final ViewHolder holder = (ViewHolder) rowView.getTag();
final StoreItem item = mItems.get(position);
holder.title.setText(item.getTitle());
if(holder.isLessClicked()){
    holder.less.setImageResource(R.drawable.x_ok);
}
else{
    holder.less.setImageResource(R.drawable.x_normal);
}

要记住的重要部分是其他条件。您现在正确设置了两个状态,单击并为每一行打开。而之前,除了单击一个单元外,您没有适当地处理所有其他单元的未点亮状态。

最新更新