当前位置: 代码迷 >> Android >> 在我的游标适配器中刷新ListView?
  详细解决方案

在我的游标适配器中刷新ListView?

热度:42   发布时间:2023-08-04 10:02:22.0

长时间潜伏 - 第一篇文章:

问题:当我单击图像按钮(基本上只是复选框)时,它们将正确更新我的数据库行并将图像更改为正确的布尔值。 但是,当我再次单击它们时 - 它不会重新更新并发出相同的消息。

我认为问题是:我对Android很新,但我很确定我的数据库正确更新时我的bindview变量不是吗?

我的光标适配器BindView:

        @Override
public void bindView(View view, final Context context, final Cursor cursor) {
    final String id = cursor.getString(cursor.getColumnIndex(DBHELPER.WISHLIST_COLUMN_ID));
    final String name2 = cursor.getString(cursor.getColumnIndex(DBHELPER.WISHLIST_COLUMN_NAME));
    final String gift = cursor.getString(cursor.getColumnIndex(DBHELPER.WISHLIST_COLUMN_GIFT));
    final String specs = cursor.getString(cursor.getColumnIndex(DBHELPER.WISHLIST_COLUMN_SPECIFICS));
    final String store = cursor.getString(cursor.getColumnIndex(DBHELPER.WISHLIST_COLUMN_STORE));
    final String url = cursor.getString(cursor.getColumnIndex(DBHELPER.WISHLIST_COLUMN_URL));
    final String status = cursor.getString(cursor.getColumnIndex(DBHELPER.WISHLIST_COLUMN_STATUS));

    ImageButton checkBoxImage = (ImageButton) view.findViewById(R.id.ID_ROW_CHECKBOX);

    if(status.equals("true"))
    {
        checkBoxImage.setImageResource(R.drawable.icon_yes);
    } else {
        checkBoxImage.setImageResource(R.drawable.icon_no);
    }

    checkBoxImage.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if(status.equals("true"))
            {
                ContentValues values = new ContentValues();
                values.put(DBHELPER.WISHLIST_COLUMN_NAME, name2);
                values.put(DBHELPER.WISHLIST_COLUMN_GIFT, gift);
                values.put(DBHELPER.WISHLIST_COLUMN_SPECIFICS, specs);
                values.put(DBHELPER.WISHLIST_COLUMN_STORE, store);
                values.put(DBHELPER.WISHLIST_COLUMN_URL, url);
                values.put(DBHELPER.WISHLIST_COLUMN_STATUS, "false");

                DBHELPER dbhelper = new DBHELPER(context);
                SQLiteDatabase db = dbhelper.getWritableDatabase();

                db.update(DBHELPER.WISHLIST_TABLE_NAME, values,"_ID " + "='" + id + "'", null);
                Message.message(context, "FALSE UPDATED");

                ImageButton checkBoxImage = (ImageButton) v.findViewById(R.id.ID_ROW_CHECKBOX);
                checkBoxImage.setImageResource(R.drawable.icon_no);

                db.close();
            } else {
                DBHELPER dbhelper = new DBHELPER(context);
                SQLiteDatabase db = dbhelper.getWritableDatabase();
                ContentValues values = new ContentValues();
                values.put(DBHELPER.WISHLIST_COLUMN_NAME, name2);
                values.put(DBHELPER.WISHLIST_COLUMN_GIFT, gift);
                values.put(DBHELPER.WISHLIST_COLUMN_SPECIFICS, specs);
                values.put(DBHELPER.WISHLIST_COLUMN_STORE, store);
                values.put(DBHELPER.WISHLIST_COLUMN_URL, url);
                values.put(DBHELPER.WISHLIST_COLUMN_STATUS, "true");

                ImageButton checkBoxImage = (ImageButton) v.findViewById(R.id.ID_ROW_CHECKBOX);
                checkBoxImage.setImageResource(R.drawable.icon_yes);

                System.out.println("BEFORE : " + status);
                db.update(DBHELPER.WISHLIST_TABLE_NAME, values,"_ID " + "='" + id + "'", null);
                 Message.message(context, "TRUE UPDATED");


                db.close();
            }
        }
    });

我尝试过的:所以我点击一个图像,它将从“已检查”变为“未经检查”或反之亦然,但只允许一次,除非我重新加载列表。

我尝试过的事情:Requery一直在上升,但现在被认为是过时的,应该避免。 我看到一些帖子谈论换掉一个新的查询,但我一直得到一个空错误,所以我不确定这是不是答案,我只是误解了什么或什么。

谢谢,谢谢你们。

if OnClickListener内部的语句没有使用状态列的最新值进行检查。 您需要在OnClickListener再次读取它。 改变这样的代码:

checkBoxImage.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {

        DBHELPER dbhelper = new DBHELPER(context);
        SQLiteDatabase db = dbhelper.getWritableDatabase();

        ContentValues values = new ContentValues();

        String[] columns = new String[]{DBHELPER.WISHLIST_COLUMN_NAME, DBHELPER.WISHLIST_COLUMN_GIFT, DBHELPER.WISHLIST_COLUMN_SPECIFICS, DBHELPER.WISHLIST_COLUMN_STORE, DBHELPER.WISHLIST_COLUMN_URL, DBHELPER.WISHLIST_COLUMN_STATUS};
        Cursor cursor2 =  db.query(DBHELPER.WISHLIST_TABLE_NAME, columns, null, null, null, null, null);

        String status2 = cursor2.getString(cursor2.getColumnIndex(DBHELPER.WISHLIST_COLUMN_STATUS));

        if("true".equals(status2)) {
            values.put(DBHELPER.WISHLIST_COLUMN_NAME, name2);
            values.put(DBHELPER.WISHLIST_COLUMN_GIFT, gift);
            values.put(DBHELPER.WISHLIST_COLUMN_SPECIFICS, specs);
            values.put(DBHELPER.WISHLIST_COLUMN_STORE, store);
            values.put(DBHELPER.WISHLIST_COLUMN_URL, url);
            values.put(DBHELPER.WISHLIST_COLUMN_STATUS, "false");

            db.update(DBHELPER.WISHLIST_TABLE_NAME, values,"_ID " + "='" + id + "'", null);
            Message.message(context, "FALSE UPDATED");

            ImageButton checkBoxImage = (ImageButton) v.findViewById(R.id.ID_ROW_CHECKBOX);
            checkBoxImage.setImageResource(R.drawable.icon_no);
        } else {
            values.put(DBHELPER.WISHLIST_COLUMN_NAME, name2);
            values.put(DBHELPER.WISHLIST_COLUMN_GIFT, gift);
            values.put(DBHELPER.WISHLIST_COLUMN_SPECIFICS, specs);
            values.put(DBHELPER.WISHLIST_COLUMN_STORE, store);
            values.put(DBHELPER.WISHLIST_COLUMN_URL, url);
            values.put(DBHELPER.WISHLIST_COLUMN_STATUS, "true");

            ImageButton checkBoxImage = (ImageButton) v.findViewById(R.id.ID_ROW_CHECKBOX);
            checkBoxImage.setImageResource(R.drawable.icon_yes);

            System.out.println("BEFORE : " + status2);
            db.update(DBHELPER.WISHLIST_TABLE_NAME, values,"_ID " + "='" + id + "'", null);
            Message.message(context, "TRUE UPDATED");
        }

        db.close();
    }
});

以下代码应放在onClick方法中:

 if(status.equals("true"))
    {
        checkBoxImage.setImageResource(R.drawable.icon_yes);
    } else {
        checkBoxImage.setImageResource(R.drawable.icon_no);
    }

顺便说一下,你的代码应该更干净。 values的声明必须在if statement之外

  相关解决方案