我有一个使用SimpleCursorAdapter实现ListView的活动。 ListView列出了SQLite数据库中的项目。问题是我按下MainActivity按钮即可完成此活动。如果此时数据库中没有元素,则应用程序崩溃,显示错误“无法恢复活动”。但是,如果数据库中至少有一个元素,则此活动可以正常工作。我想知道如何解决这个问题。
这是完整的活动代码。请帮助。
注意:我在其他一个应用程序中做了完全相同的事情,除了你在这里看到的行的替代着色并且工作正常。
package com.tintin.scheduler_3;
import android.app.ListActivity;
import android.content.Intent;
import android.database.Cursor;
import android.graphics.Color;
import android.os.Bundle;
import android.support.v4.widget.SimpleCursorAdapter;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ListView;
public class List_Course extends ListActivity {
DatabaseHelper db;
SimpleCursorAdapter dataAdapter;
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.course_list);
Button add = (Button) findViewById(R.id.add);
add.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
startActivity(new Intent(List_Course.this, Add_Course.class));
}
});
Log.v("Button", "On Click Done");
db = new DatabaseHelper(List_Course.this);
Log.v("Button", "On Click Done2");
displayList();
Log.v("Button", "On Click Done3");
db.close();
}
public void onResume(){
Cursor newCursor = db.getAllCourses();
dataAdapter.changeCursor(newCursor);
super.onResume();
db.close();
}
public void displayList(){
Cursor cursor = db.getAllCourses();
if(cursor.getCount() == 0)return;
String from [] = new String[] {db.colName,db.colDisplay};
int to[] = new int[] {R.id.textView1, R.id.textView2};
dataAdapter = new SimpleCursorAdapter(this, R.layout.listitem, cursor, from, to, 0){
public View getView(int position, View convertView, ViewGroup parent){
final View row = super.getView(position, convertView, parent);
if(position % 2 == 0)
row.setBackgroundColor(Color.parseColor("#D8D8D8"));
else
row.setBackgroundColor(Color.parseColor("#D0D0D0"));
return row;
}
};
ListView lv = getListView();
lv.setAdapter(dataAdapter);
registerForContextMenu(lv);
cursor.close();
db.close();
}
}
答案 0 :(得分:0)
在您的onresume mtd super.onResume();
来电必须首先
Cursor newCursor = db.getAllCourses();
dataAdapter.changeCursor(newCursor);
可能需要更多时间才能执行,所以首先调用 super.onresume(),然后调用游标code.hope。