我正在构建一个任务列表应用程序。对于每个任务,都会创建一个 RelativeLayout,其中包含一个 CheckBox 和一个带有任务名称的 TextView。然后将其添加到预先存在的 LinearLayout 中。那部分一切正常。
我添加了一个调用方法 deleteTask(View view) 的“删除任务”ImageButton。deleteTask() 从数据库中删除任务。当我尝试运行时,我得到“java.lang.IllegalStateException:无法执行活动的方法”以及一堆其他错误。
01-16 13:15:48.975: E/AndroidRuntime(16881): FATAL EXCEPTION: main
01-16 13:15:48.975: E/AndroidRuntime(16881): java.lang.IllegalStateException: Could not execute method of the activity
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.view.View$1.onClick(View.java:3591)
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.view.View.performClick(View.java:4084)
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.view.View$PerformClick.run(View.java:16966)
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.os.Handler.handleCallback(Handler.java:615)
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.os.Handler.dispatchMessage(Handler.java:92)
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.os.Looper.loop(Looper.java:137)
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.app.ActivityThread.main(ActivityThread.java:4931)
01-16 13:15:48.975: E/AndroidRuntime(16881): at java.lang.reflect.Method.invokeNative(Native Method)
01-16 13:15:48.975: E/AndroidRuntime(16881): at java.lang.reflect.Method.invoke(Method.java:511)
01-16 13:15:48.975: E/AndroidRuntime(16881): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
01-16 13:15:48.975: E/AndroidRuntime(16881): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:558)
01-16 13:15:48.975: E/AndroidRuntime(16881): at dalvik.system.NativeStart.main(Native Method)
01-16 13:15:48.975: E/AndroidRuntime(16881): Caused by: java.lang.reflect.InvocationTargetException
01-16 13:15:48.975: E/AndroidRuntime(16881): at java.lang.reflect.Method.invokeNative(Native Method)
01-16 13:15:48.975: E/AndroidRuntime(16881): at java.lang.reflect.Method.invoke(Method.java:511)
01-16 13:15:48.975: E/AndroidRuntime(16881): at android.view.View$1.onClick(View.java:3586)
01-16 13:15:48.975: E/AndroidRuntime(16881): ... 11 more
01-16 13:15:48.975: E/AndroidRuntime(16881): Caused by: java.lang.ClassCastException: android.widget.ImageView cannot be cast to android.widget.CheckBox
01-16 13:15:48.975: E/AndroidRuntime(16881): at com.rook.todolist.MainActivity.deleteTask(MainActivity.java:177)
01-16 13:15:48.975: E/AndroidRuntime(16881): ... 14 more
这是我的代码。试图包含我认为相关的内容,如果需要,显然可以包含更多内容。
由 ImageButton 调用的deleteTask() :
public void deleteTask (View view) {
// instantiate dbhandler
DatabaseHandler db = new DatabaseHandler(this);
// get tasks
List<Task> tasks = db.getAllTasks();
for(Task t : tasks) {
CheckBox cb = (CheckBox) findViewById(t.getID() + 10000);
if(cb.isChecked()) { db.deleteTask(t); }
}
buildTaskList();
}//end deleteTask()
当我创建 CheckBoxes 时,它们需要有一个我可以为 LayoutParams 引用的 id,所以我将它们的 id 设置为 10,000 + 任务的 id。只是容易记住的东西。
buildTaskList() 只是从主 LinearLayout 中删除所有视图,并根据数据库中的任务重新构建它们。
如果选中 CheckBox,则调用deleteTask(Task task) 。
// Deleting single task
public void deleteTask (Task task) {
SQLiteDatabase db = this.getWritableDatabase();
db.delete(TABLE_TASKS, KEY_ID + " =?", new String[] { String.valueOf(task.getID()) });
}
删除操作仍在执行。当我重新加载应用程序时,要删除的任务消失了。此外,我在第一次创建 deleteTask() 时对其进行了测试,并且它有效。
编辑
正如许多人指出的那样,该行findViewById(t.getID() + 10000);
返回的是 ImageView 而不是复选框。但是我输入了日志语句以在创建它们的方法和 deleteTask() 方法中吐出 id,并且 id 是相同的! 分配给视图的 id 是否发生了变化?