ListView爲了優化滑動速度,防止內存泄露,經常涉及到控件重用的問題,已經選中的CheckBox在滑動消失之後,會導致最新出現的Item由於複用的問題,與消失的Item中CheckBox選中狀態一致,也變爲選中狀態(實際未選中)。
爲什麼會出現這種問題呢?
因爲我們在convertView複用的時候,雖然減少了不必要的View的創建,但是也複用了CheckBox的選擇狀態,所以當然會出現這種問題了
我們一般通過設置一個list列表用來存儲選中item的對象的唯一標識符(可以爲id或者position),在getView()中判斷list中是否存在當前的id或者position。存在則設置它的狀態爲true,否則設置爲false。
1.首先在實體類Item的裏
private boolean checked;
2.其次:用list爲item賦個默認值
for (int i = 0; i <25; i++) { item = new Item(); item.setChecked(false); item.setTime("2016年3月10號"); list.add(item); }
3.在自定義的adapter適配器中
方法一:
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = null;
if (convertView == null) {
view = View.inflate(context, R.layout.adapter_main_item, null);
final ViewHolder viewHolder = new ViewHolder();
viewHolder.text = (TextView) view.findViewById(R.id.adapter_main_tv_name);
viewHolder.checkbox = (CheckBox) view.findViewById(R.id.adapter_main_cb);
viewHolder.checkbox.setOnCheckedChangeListener(new Compounon.OnCheckedChangeListener() {
@Override
public void onCheckedChanged(Compounon buttonView,boolean isChecked) {
Bean element = (Bean) viewHolder.checkbox.getTag();
element.setCheck(buttonView.isChecked());
}
});
view.setTag(viewHolder);
viewHolder.checkbox.setTag(list.get(position));
} else {
view = convertView;
((ViewHolder) view.getTag()).checkbox.setTag(list.get(position));
}
ViewHolder holder = (ViewHolder) view.getTag();
holder.text.setText(list.get(position).getName());
holder.checkbox.setChecked(list.get(position).isCheck());
return view;
}
方法二:
@Override
public View getView(final int position, View convertView, ViewGroup parent) {