我有一个任务提醒,允许您将信息存储在数据库中,然后稍后编辑或检索它们(如记事本)。每当启动应用程序然后进入活动时,它将显示已保存的项目,但如果您尝试选择并删除一项,则会崩溃。您甚至可以单击它来查看它,而不是删除它。如果您首先添加另一个项目,那么您可以删除所有项目。如果我切换到另一个应用程序并返回它,那很好。只有当应用程序在返回删除之前完全关闭时,它才会导致问题。
我完全被难住了。
这是显示项目的开头
@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 中。这是我删除提醒警报的地方。它最初设置在另一个活动中,这里是我删除它的地方。真正令人困惑的是,如果该应用程序一直在运行,并且我保存了另一个提醒我可以删除它们。如果我启动应用程序并直接提醒删除它,它会崩溃。