1

有以下适配器:

private class RepeatingAdapter extends ArrayAdapter<Repeatable> {

    private List<Repeatable> items;
    private LayoutInflater inflater;
    private int resource;

        public RepeatingAdapter(Context context, int resource,
                List<Repeatable> items) {
            super(context, resource, items);
            this.items=items;
            this.resource=resource;
            inflater=LayoutInflater.from(context);
        }

        @Override
        public View getView(int position, View view, ViewGroup group) {
            View item=(view==null) ? inflater.inflate(resource, null) : view;
            TextView title=(TextView)item.findViewById(R.id.listItemRepeatingTypeTitle);
            title.setText(items.get(position).getTitle());
            items.get(position).setCommand(new RedRectangleCommand(item));
            Log.e("view", item.toString());
            return item;
        }

        @Override
        public Repeatable getItem(int position) {
            return items.get(position);
        }
}

请注意,我们创建了新的 RedRectangleCommand 并将创建的 View 发送给它。所以,我们还做了以下事情:

    repeatingList.setAdapter(new RepeatingAdapter(this, 
        R.layout.list_item_repeating_type, types));
    repeatingList.setOnItemClickListener(new OnItemClickListener() {

        @Override
        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {
            ((Repeatable)parent.getItemAtPosition(position)).mark();
        }

    });

请注意,我们对选定的项目执行 mark() 方法(可重复的 Mark 方法执行命令的 mark() 方法)。一切都很好。最后的命令代码:

private class RedRectangleCommand extends Command {

    private View view;
    public RedRectangleCommand(View view) {
        this.view=view;
    }

        @Override
        public void mark() {
            ImageView image=(ImageView)view.findViewById(R.id.listItemRepeatingTypeImage);
            image.setBackgroundColor(Color.RED);
            image.invalidate();
        }

        @Override
        public void unmark() {
            ImageView image=(ImageView)view.findViewById(R.id.listItemRepeatingTypeImage);
            image.setBackgroundColor(Color.BLACK);
        }       
}

我需要通过单击从选定的视图中更改 ImageView 的颜色。但它不起作用!另外,我的日志显示,从 Command 中选择的项目和项目是不同的。这是怎么回事?

4

1 回答 1

0

也许你可以试试这个,看看有什么不同。它所做的是尝试通过将 RedRectangleCommand 对象设为自定义适配器的方法来直接引用它:

    RepeatingAdapter rAdapter = new RepeatingAdapter(this, 
            R.layout.list_item_repeating_type, types);

    repeatingList.setAdapter(rAdapter);
    repeatingList.setOnItemClickListener(new OnItemClickListener() {

        @Override
        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {

            rAdapter.markCommand(position);
        }

    });

然后在您的适配器中:

private class RepeatingAdapter extends ArrayAdapter {

        private List<Repeatable> items;
        private LayoutInflater inflater;
        private int resource;

        public RepeatingAdapter(Context context, int resource,
                List<Repeatable> items) {
            super(context, resource, items);
            this.items=items;

            // .... some code

        public void markCommand(int position) {
            items.get(position).mark();
        }
    }

我也认为一个真正的问题是你的getView中的那部分:

items.get(position).setCommand(new RedRectangleCommand(item));

因为到目前为止,它正在创建这些对象中的一个新对象,一遍又一遍地重新实例化,不管它是否被使用,只要 listView 行从视图中消失并再次出现。您可以想象这可能是多么浪费和麻烦,尤其是在尝试引用特定实例时。应该有几种方法可以解决这个问题。例如,如果该Repeater 还没有,您只能执行setCommand。也许制作一个布尔方法来检查它是否具有那些 RedRectangleCommand 之一或类似检查 convertView 是否为空的东西。我试图巩固的另一个想法是做一些构造函数,但需要一个参数View似乎很麻烦:

private View item;
public RepeatingAdapter(Context context, int resource,
            List<Repeatable> items) {
        super(context, resource, items);
        this.items=items;
        this.resource=resource;

        inflater=LayoutInflater.from(context);
        item = inflater.inflate(resource, null);

        for (int i = 0; i < items.size; i++) {
            items.get(i).setCommand(new RedRectangleCommand(item));
        }
于 2012-11-16T23:58:05.517 回答