0

我正在尝试从ListView.

中的每个元素ListView都是一个LinearLayout. 我可以添加和删除行,但是每当我这样做时,行的顺序都是混乱的,并且不一定要删除正确的行。我检查了ArrayList<LinearLayout> rows每次添加一行时我的大小都在增加,但调用getItem(position)始终为空。我认为这是导致问题的原因,但为什么要添加空布局rows

编辑:我将 ArrayAdapter 参数从 LinearList 更改为 Row,这是一个简单的对象,其中包含两个 EditText 字段的 getter 和 setter。这已经解决了 null 问题,但同样的问题仍然存在 - 随机行被删除。在getView()下面,Logcat 显示position = 0在我的删除按钮的每种情况下onClick()。Logcat 还显示 L​​istView 中的每个视图都被随机分配一个位置。

我的新适配器代码:

public class RowAdapter extends ArrayAdapter<Row>{

    private ArrayList<Row> rows;

    public RowAdapter(Context context, int textViewResourceId, ArrayList<Row> rows) {
        super(context, textViewResourceId, rows);
        this.rows = rows;
    }

    public Row getItem(int position){
        return rows.get(position);
    }

    public int getCount(){
        return rows.size();
    }

    public static class ViewHolder {
        public EditText name;
        public EditText value;
        public Button delete; 
    }

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

        if(v == null){
            LayoutInflater li = (LayoutInflater)getContext().
                    getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            v = li.inflate(R.layout.row, parent, false);

            viewHolder = new ViewHolder();

            viewHolder.name = (EditText)v.findViewById(R.id.editAttrName);
            viewHolder.value = (EditText)v.findViewById(R.id.editAttrValue);

            viewHolder.delete = (Button)v.findViewById(R.id.btnDelete);
            viewHolder.delete.setTag(position);
            viewHolder.delete.setOnClickListener(new AdapterView.OnClickListener() {
                @Override
                public void onClick(View v) {
                    int position = (Integer) v.getTag();
                    Log.e("RowAdapter", "position = " + position);
                    Row row = getItem(position);
                    rows.remove(row);
                    notifyDataSetChanged();
                }   
            });

            v.setTag(viewHolder);
        } else {
            viewHolder = (ViewHolder)v.getTag();
        }
        Log.e("RowAdapter", "row " + v.toString() + ", position = " + position);    
        Row row = getItem(position);

        if(row != null) {

            EditText editText1 = (EditText)v.findViewById(R.id.editAttrName);
            EditText editText2 = (EditText)v.findViewById(R.id.editAttrValue);

            String text1 = editText1.getText().toString();
            String text2 = editText2.getText().toString();
            if(viewHolder.name != null) {
                viewHolder.name.setText(text1);
            }
            if(viewHolder.value != null) {
                viewHolder.value.setText(text2);
            }

        }

        return v;
    }
}
4

2 回答 2

1

我认为您不需要创建一个函数public Row getItem(int position),因为ArrayAdapter<T>它提供了一个名为getItemAtPosition(int position). 还要确保当您调用getItemAtPosition(int position)活动视图时是列表视图,或者您拥有列表视图的句柄,以便您可以这样做view.getItemAtPosition(position),否则您会得到null.

于 2012-04-04T06:51:51.713 回答
1

您的问题可能是 Adapters 旨在包含模型列表,而不是视图列表。视图应该由您的getView()方法生成。所以你真正想要的是创建一个Row代表一行的类,然后你可以在getView().

于 2012-04-03T23:56:35.647 回答