我正在尝试为每种类型的行(4种类型的行)设置一个包含四种不同布局的列表视图,我正在使用ViewHolder。
但是我遇到了一个奇怪的问题,我无法解决这个问题。
我的观点(全部4个),有一个CheckBox,一些CheckBox必须被标记和禁用,当我有这个列表视图有很多行并且我滚动它时,我的CheckBox被检查和取消选中,启用和禁用...
我相信我的问题与回收意见有关,但我没有得到它可以是什么。
在这里,我发布了一些代码:
class MyAdapter extends BaseAdapter {
private FragmentActivity activity;
private List<Extra> data;
private static LayoutInflater inflater=null;
private ManifestData manifest;
private Context context;
final List<ExtraRow> rows;
MyAdapter(List<Extra> extras, FragmentActivity activity, Context context) {
rows = new ArrayList<ExtraRow>();
this.activity = activity;
this.context = context;
for (Extra e : extras) {
if (e.getPriceType()==1) {
rows.add(new ExtraRowType1(LayoutInflater.from(context), e, activity));
} else if (e.getPriceType()==2){
rows.add(new ExtraRowType2(LayoutInflater.from(context), e, activity));
} else if (e.getPriceType()==3){
rows.add(new ExtraRowType3(LayoutInflater.from(context), e, activity));
} else if (e.getPriceType()==4){
rows.add(new ExtraRowType4(LayoutInflater.from(context), e, activity));
}
}
}
@Override
public int getViewTypeCount() {
return 4;
}
@Override
public int getItemViewType(int position) {
return rows.get(position).getViewType();
}
public int getCount() {
return rows.size();
}
public Object getItem(int position) {
return position;
}
public long getItemId(int position) {
return position;
}
public View getView(int position, View convertView, ViewGroup parent) {
return rows.get(position).getView(convertView);
}
}
我的一行(其他行非常相似,但有一些UI更改):
public class ExtraRowType3 implements ExtraRow{
private final Extra extra;
private final LayoutInflater inflater;
final FragmentActivity activity;
private ViewHolder holder;
public ExtraRowType3(LayoutInflater inflater, Extra extra, FragmentActivity activity) {
this.extra = extra;
this.inflater = inflater;
this.activity = activity;
}
@Override
public View getView(View convertView) {
View view;
if (convertView == null) {
ViewGroup viewGroup = (ViewGroup)inflater.inflate(R.layout.reservas_extras_3, null);
holder = new ViewHolder((TextView)viewGroup.findViewById(R.id.reservas_extras_titulo),
(CheckBox)viewGroup.findViewById(R.id.reservas_extras_3_checkbox),
(TextView)viewGroup.findViewById(R.id.reservas_extras_total));
viewGroup.setTag(holder);
view = viewGroup;
} else {
holder = (ViewHolder)convertView.getTag();
view = convertView;
}
holder.title.setText(extra.getNombre());
if(extra.isObligatorio()){
holder.checkBox.setChecked(true);
holder.checkBox.setClickable(false);
}else{
Disponibilidad d = Disponibilidad.getInstance();
if(d.getExtraReserva(extra.getId())!=null){
holder.checkBox.setChecked(true);
}else{
holder.checkBox.setChecked(false);
holder.checkBox.setClickable(true);
}
}
holder.checkBox.setOnCheckedChangeListener(new OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
ExtraReserva extraReserva = new ExtraReserva(extra.getId(), "", -1, -1, 1, extra.isSuplemento());
Disponibilidad d = Disponibilidad.getInstance();
if(isChecked){
d.addExtra(extraReserva);
}
else d.deleteExtra(extraReserva.getIdExtra());
}
});
return view;
}
@Override
public int getViewType() {
return extra.getTipoPrecio();
}
private static class ViewHolder {
final TextView title;
final CheckBox checkBox;
final TextView total;
private ViewHolder(TextView title, CheckBox checkBox, TextView total) {
this.title = title;
this.checkBox = checkBox;
this.total = total;
}
}
}
提前感谢您的帮助。
答案 0 :(得分:0)
此代码是否已更新?因为当你回答我的问题时,你说你没有回收你的观点。但是在这里我看到你将convertView传递给ExtraRow实现的getView方法,并且在getView中你正常做如果null - &gt;膨胀,否则getTag。
答案 1 :(得分:0)
您的观点会像他们留下的状态一样被回收。因此,如果在离开屏幕时检查了一个视图,系统将在系统重新使用它时(convertView)进行检查,因此必须明确重新初始化。
可能导致问题的另一件事是您定义ViewHolder的地方。它应该是getView()中的局部变量,而不是类字段。我猜它会用setOnCheckedChangeListener
创建奇怪的行为。