我的列表视图发生了一件非常奇怪的事情。我正在创建一个带有按钮和 editText 的 ListView。
它的配置是这样的:[Button] [EditText] [Button],这些按钮的作用类似于“增量器”和“减量器”,每次单击以 1 个单位更新 EditText 的数值。问题是,当我单击一个按钮时,几乎每次更改另一个列表视图元素的editText(单击项的editText 也会更改)。如果我单击这个错误更改项的按钮,它也会更改第一个的editText。它们基本上具有相同的按钮和editText引用,尽管它们具有带有数据的textViews,并且这些数据在它们之间是不同的。
为此,我创建了自定义适配器:
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if(convertView == null) {
convertView = mInflater.inflate(R.layout.lastproduct_row, null);
holder = new ViewHolder();
holder.btnAddQtd = (Button) convertView.findViewById(R.lastproduct_row.btn_add_qtd);
holder.btnSubQtd = (Button) convertView.findViewById(R.lastproduct_row.btn_sub_qtd);
holder.etQuantidade = (EditText) convertView.findViewById(R.lastproduct_row.et_quantidade);
TextView tv;
holder.tvList = new TextView[PRODUCTROW_INT_KEY.length];
for(int i = 0; i < PRODUCTROW_INT_KEY.length; i++) {
tv = (TextView) convertView.findViewById(PRODUCTROW_INT_KEY[i]);
holder.tvList[i] = tv;
}
convertView.setTag(holder);
}
else {
holder = (ViewHolder) convertView.getTag();
}
HashMap<String, String> hm = productsList.get(position);
String key = hm.get(CODIGO_KEY);
for(int i = 0; i < PRODUCTROW_INT_KEY.length; i++) {
holder.tvList[i].setText(hm.get(PRODUCTROW_STR_KEY[i]));
}
holder.btnAddQtd.setTag(key+QTD_FLAG+ADD_ACTION);
holder.btnSubQtd.setTag(key+QTD_FLAG+SUB_ACTION);
holder.btnAddQtd.setOnClickListener(handle);
holder.btnSubQtd.setOnClickListener(handle);
if(novosEstoques.containsKey(key)) {
holder.etQuantidade.setText(MyParseFunctions.parseCentesimal(novosEstoques.get(key).getQuantidade()));
}
return convertView;
}
class ViewHolder {
private TextView []tvList;
private Button btnAddQtd, btnSubQtd;
private Button btnAddQtVol, btnSubQtVol;
private EditText etQuantidade, etQtVolume;
}
我将 onClick 侦听器添加到按钮,使用我的 listView 元素 ID(与其他信息连接)设置它们的标签。然后在我的事件监听器中,我只需获取按钮父视图(一个 LinearLayout)并使用 getViewAt() 从中获取 EditText:
@Override
public void onClick(View v) {
String tag = (String) v.getTag();
if(tag.contains(QTD_FLAG)) {
String []info = ((String) v.getTag()).split(QTD_FLAG);
float qtd;
LinearLayout ll = (LinearLayout) v.getParent();
ll.setBackgroundColor(Color.rgb(0, 128, 30));
EditText et = (EditText) ll.getChildAt(2);
qtd = Float.parseFloat(et.getText().toString().replace(",", "."));
if(info[1].equals(ADD_ACTION)) {
qtd++;
}
else if(info[1].equals(SUB_ACTION)) {
if(qtd > 0)
qtd--;
}
Log.d("TESTE", "MODIFICAR KEY = "+info[0]);
et.setText(qtd+"");
}
}
我在此示例中使用 setBackgroundColor 来确认 LinearLayout 实例在 lisView 中重复。当我单击一个按钮时,它会被绘制在 2 个不同的列表视图项中。
任何人都可以指出我可能会这样做吗?我发现有人有重复的 ListView 项目,我不知道这是不是我的情况,因为我的 ListView 中有 TextView,而且它们不相等,只有带有按钮和 editText 的 LinearLayout 部分是“共享的”。
我对我的 getView 方法进行了一些更改,它现在可以工作了!似乎每次调用 getView 方法时,我根本无法保证我的 editTexts 将被正确填充,我没有意识到这一点。因此,我进行的每个 getView 调用都设置了 editText 值,如果用户编辑 ET 值,我将其存储在 HashMap 中以在 getView 中恢复,如果 HashMap 中没有给定 editText 的条目,则将其设置为默认值值(零):
...
if(convertView == null) {
holder = new ViewHolder();
holder.btnAddQtd = (Button) convertView.findViewById(R.lastproduct_row.btn_add_qtd);
holder.btnSubQtd = (Button) convertView.findViewById(R.lastproduct_row.btn_sub_qtd);
holder.etQuantidade = (EditText) convertView.findViewById(R.lastproduct_row.et_quantidade);
//Now it is easier to get etQuantidade reference in button
//click handle, I just have to do:
// public onClick(View v) {
// EditText etButtonAssociated = (EditText) v.getTag();
// ...
// }
holder.btnAddQtd.setTag(holder.etQuantidade);
holder.btnSubQtd.setTag(holder.etQuantidade);
holder.btnAddQtd.setOnClickListener(handle);
holder.btnSubQtd.setOnClickListener(handle);
...
}
else {
...
}
holder.etQuantidade.setTag(key);
if(novosEstoques.containsKey(key)) {
holder.etQuantidade.setText(MyParseFunctions.parseCentesimal(novosEstoques.get(key).getQuantidade()));
}
else {
holder.etQuantidade.setText("0");
}
return convertView;