0

我有一个任务提醒,允许您将信息存储在数据库中,然后稍后编辑或检索它们(如记事本)。每当启动应用程序然后进入活动时,它将显示已保存的项目,但如果您尝试选择并删除一项,则会崩溃。您甚至可以单击它来查看它,而不是删除它。如果您首先添加另一个项目,那么您可以删除所有项目。如果我切换到另一个应用程序并返回它,那很好。只有当应用程序在返回删除之前完全关闭时,它才会导致问题。

我完全被难住了。

这是显示项目的开头

@Override
public void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);

    mDbHelper = new RemindersDbAdapter(this);
    mDbHelper.open();
    fillData();
    setContentView(R.layout.meds);
    registerForContextMenu(getListView());
}

private void fillData() {
    Cursor remindersCursor = mDbHelper.fetchAllReminders();
    startManagingCursor(remindersCursor);
    String[] from = new String[] { RemindersDbAdapter.KEY_TITLE };
    int[] to = new int[] { R.id.text1 };
    SimpleCursorAdapter reminders = new SimpleCursorAdapter(this,
            R.layout.reminder_row, remindersCursor, from, to);
    setListAdapter(reminders);
}

以及用于删除的上下文菜单

@Override
public void onCreateContextMenu(ContextMenu menu, View v, ContextMenuInfo menuInfo) {
    super.onCreateContextMenu(menu, v, menuInfo);
    MenuInflater mi = getMenuInflater();
    mi.inflate(R.menu.list_menu_item_longpress, menu);


}

@Override
public boolean onContextItemSelected(MenuItem item) {
    if (item.getItemId() == R.id.menu_delete) {
        AdapterContextMenuInfo info = (AdapterContextMenuInfo) item
                .getMenuInfo();
        long mRowId = info.id;
cancelReminder();
mDbHelper.deleteReminder(info.id);
        fillData();

        return true;
    }
    return super.onContextItemSelected(item);
}    

我不认为它在数据库中,因为如果应用程序已经存储了其他内容,它将很好地删除。

编辑 我一直在尝试调试这个问题,并在方法 cancelReminder 中找到了错误的位置

public void cancelReminder() {

    alarmid = Integer.parseInt(malarmid);
    Log.e(TAG2, "meds screen alarmid " + alarmid);

    Intent i = new Intent(ReminderManager.mContext, OnAlarmReceiver.class);
    PendingIntent pi = PendingIntent.getBroadcast(ReminderManager.mContext,
            alarmid, i, PendingIntent.FLAG_UPDATE_CURRENT);

    ReminderManager.mAlarmManager.cancel(pi);

}

由于某种原因,错误在 Intent 中。这是我删除提醒警报的地方。它最初设置在另一个活动中,这里是我删除它的地方。真正令人困惑的是,如果该应用程序一直在运行,并且我保存了另一个提醒我可以删除它们。如果我启动应用程序并直接提醒删除它,它会崩溃。

4

1 回答 1

0

找到了问题的答案......

尝试取消此活动的重复警报将不起作用,因为它无法获取上下文。相反,我将警报的字符串信息传递给了我的 alarmManager 类并将其删除。

@Override
public boolean onContextItemSelected(MenuItem item) {
    switch (item.getItemId()) {

    case R.id.menu_delete:

        AdapterContextMenuInfo info = (AdapterContextMenuInfo) item.getMenuInfo();

        long mRowId = info.id;

        Cursor reminder = mDbHelper.fetchReminder(mRowId);
        startManagingCursor(reminder);

        malarmid = reminder.getString(reminder
                        .getColumnIndexOrThrow(RemindersDbAdapter.KEY_RANDOM));
        Log.e(TAG2, "meds screen malarmid " + malarmid);

        mDbHelper.deleteReminder(info.id);
        fillData();

        new ReminderManager(this).cancelReminder(info.id, malarmid);
        return true;
    }
    return super.onContextItemSelected(item);
}

和提醒管理器类

public void cancelReminder(long mRowId, String malarmid) {


    int alarmid = Integer.parseInt(malarmid);
    Log.e(TAG2, "Reminder Manager Cancel Reminder convert from malarm to alarmid " + alarmid);
    Intent i = new Intent(mContext, OnAlarmReceiver.class);
    PendingIntent pi = PendingIntent.getBroadcast(mContext,
            alarmid, i, PendingIntent.FLAG_UPDATE_CURRENT);

    ReminderManager.mAlarmManager.cancel(pi);

}
于 2013-05-17T19:56:41.620 回答