NiP*_*Pfi 18 database android listview simplecursoradapter
我正在编写一个Android应用程序,应该使用数据库来存储数据并从中读取数据.使用本教程(在archive.org上)我得到了创建数据库的应用程序,我可以创建新条目,但是,我不知道,如何读取数据库以获取ListView中存储的数据.我知道这个网站上有很多类似的问题,但似乎没有一个适用于这种方式,教程中的数据库也适用.
码:
import java.util.Calendar;
import maturarbeit.nicola_pfister.studenttools.database.DBAdapter;
import android.app.AlertDialog.Builder;
import android.app.ListActivity;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;
import android.database.Cursor;
import android.os.Bundle;
import android.support.v4.widget.SimpleCursorAdapter;
import android.view.Menu;
import android.view.MenuInflater;
import android.view.MenuItem;
import android.widget.ListView;
public class Marks extends ListActivity {
DBAdapter db = new DBAdapter(this);
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.marks);
}
@Override
protected void onPause() {
    super.onPause();
    db.close();
}
@Override
protected void onResume() {
    super.onResume();
    db.open();
    getData();
}
@SuppressWarnings("deprecation")
private void getData() {
    SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, 
            android.R.layout.simple_list_item_1, 
            db.getAllMarks(), 
            new String[] { "value" }, 
            new int[] { android.R.id.text1 });
    ListView listView = (ListView) findViewById(R.id.marks_list);
    listView.setAdapter(adapter);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    MenuInflater inflater = getMenuInflater();
    inflater.inflate(R.menu.marks, menu);
    return true;
}
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
    case R.id.menu_add:
        Calendar cal = Calendar.getInstance();
        int day = cal.get(Calendar.DAY_OF_MONTH);
        int month = cal.get(Calendar.MONTH);
        final String date = day + "." + month;
        Builder builder = new Builder(this);
        builder
            .setTitle(R.string.dialog_addmarks)
            .setItems(R.array.markslist, new OnClickListener() {
                public void onClick(DialogInterface dialog, int which) {
                    @SuppressWarnings("unused")
                    long id;
                    String selection = getResources().getStringArray(R.array.markslist)[which];
                    id = db.insertMark(date, "Default", selection);
                    }
            })
            .show();
        getData();
        break;
    case R.id.menu_delete:
            //Deleting function yet to be implemented.
        break;
    }
    return super.onOptionsItemSelected(item);
}
}
Run Code Online (Sandbox Code Playgroud)
编辑:ListView ID错误,因为它必须是android:list.
Sam*_*Sam 59
在您链接到本教程使用的数据库格式,每行有_id,isbn,title,和publisher.现在让我们假设您要在ListView中显示每个标题:
db = new DBAdapter(this);
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, 
        android.R.layout.simple_list_item_1, 
        db.getAllTitles(), 
        new String[] { "title" }, 
        new int[] { android.R.id.text1 });
ListView listView = (ListView) findViewById(R.id.list);
listView.setAdapter(adapter);
Run Code Online (Sandbox Code Playgroud)
(您不需要自己遍历Cursor,适配器可以为您工作!)
SimpleCursorAdapter构造函数中的最后两个参数是您缺少的.它们是"from"和"to"参数:
title,这是我们从"获取"信息的地方.android.R.id.text1是android.R.layout.simple_list_item_1布局中的TextView .(您可以自己浏览SDK并查看simple_list_item_1.xml文件,或者暂时相信我.)现在"from"和"to"参数都是数组,因为我们可以传递多列信息,也可以尝试使用此适配器:
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, 
        android.R.layout.simple_list_item_2, 
        db.getAllTitles(), 
        new String[] { "title", "publisher" }, 
        new int[] { android.R.id.text1, android.R.id.text2 });
Run Code Online (Sandbox Code Playgroud)
使用此适配器,其数据库中的书籍将按标题显示,然后显示为发布者.我们所要做的就是使用一个带有android.R.layout.simple_list_item_2两个字段的布局,并定义哪些列转到哪些TextViews.
我希望这有点帮助.还有很多东西需要学习,但也许这会给你一些基础知识.
最后的评论
在我的脑海中,添加新数据后刷新ListView试试这个:
public void onClick(DialogInterface dialog, int which) {
    String selection = getResources().getStringArray(R.array.markslist)[which];
    db.insertMark(date, "Default", selection);
    cursor.requery();
    adapter.notifyDataSetChanged();
}
Run Code Online (Sandbox Code Playgroud)
你必须定义adapter和创建一个变量,cursor但这很简单:
public class Marks extends ListActivity {
    SimpleCursorAdapter adapter;
    Cursor cursor;
    DBAdapter db = new DBAdapter(this);
    ...
Run Code Online (Sandbox Code Playgroud)
并相应地更改getData():
private void getData() {
    cursor = db.getAllMarks();
    adapter = new SimpleCursorAdapter(this, 
            android.R.layout.simple_list_item_1, 
            cursor, 
            new String[] { "value" }, 
            new int[] { android.R.id.text1 });
    ...
}
Run Code Online (Sandbox Code Playgroud)
祝好运!
|   归档时间:  |  
           
  |  
        
|   查看次数:  |  
           71011 次  |  
        
|   最近记录:  |