我已经为此搜索了多个问题,但仍然没有找到实现我正在寻找的方法的方法。我有一个简单的自定义 cursorAdapter,它的形式是
|文本视图复选框|
滚动复选框时,回收时会丢失状态。我曾尝试使用 arrayList 来存储布尔值,但是在检查它们时,它似乎永远不会恢复为真。
public class BrowseCardsAdapter extends CursorAdapter {
private LayoutInflater mInflater = null;
private Context mContext;
public DataBaseHelper myDbHelper = null;
public BrowseCardsAdapter(Context context, Cursor cursor) {
super(context, cursor, true);
mInflater = LayoutInflater.from(context);
mContext = context;
myDbHelper = new DataBaseHelper(mContext);
try {
myDbHelper.openDataBaseForUpdate();
} catch (SQLException sqle) {
throw sqle;
}
}
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
return mInflater.inflate(R.layout.list_cards, parent, false);
}
@Override
public void bindView(final View view, final Context context, final Cursor cursor) {
final CheckBox cb_have = (CheckBox) view.findViewById(R.id.cb_have);
TextView cardNumber = (TextView) view.findViewById(R.id.tv_cardnumber);
final String cardNumberText = cursor.getString(cursor.getColumnIndex("CardNumber"));
final String have = cursor.getString(cursor.getColumnIndex("Have"));
cardNumber.setText(cardNumberText);
if (have.compareTo("true") == 0)
cb_have.setChecked(true);
else
cb_have.setChecked(false);
cb_have.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
if (cb_have.isChecked()) {
myDbHelper.addHaveToDatabase(cardNumberText, true);
cb_have.setChecked(true);
}
else {
myDbHelper.addHaveToDatabase(cardNumberText, false);
cb_have.setChecked(false);
}
myDbHelper.close();
});
}
我将拥有状态存储在数据库中,然后我想检查拥有状态以设置复选框。这样,当用户进入活动时,他们将看到他们之前选择的项目,以及任何新的选择。除了在屏幕外滚动视图会丢失新选择的项目的状态之外,这非常有效。有人可以给我一些关于如何保存状态的指示吗?