如何在ListView上显示同一个表中的多个列数据?

时间:2012-12-29 19:12:00

标签: android sqlite android-listview

我的ListView目前只能显示一个列数据。我希望它显示两列数据。

以下是我的ListView的代码:

public class ProjectExplorer extends ListActivity {

private projectdatabase database;
protected Cursor cursor;
protected ListAdapter adapter;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    database = new projectdatabase(ProjectExplorer.this);

    getinfo();
}

private void getinfo() {

    database.open();
    cursor = database.getDataforDisplay();
    adapter = new SimpleCursorAdapter(this, android.R.layout.simple_list_item_1, cursor, new String[] {"project_name"}, new int[] { android.R.id.text1 }, 0);
    setListAdapter(adapter);

}

@Override
public void onListItemClick(ListView parent, View view, int position, long id) {

    super.onListItemClick(parent, view, position, id);

    Cursor c = ((SimpleCursorAdapter)parent.getAdapter()).getCursor();
      c.moveToPosition(position);

      // get project name here

      String str_projectname= c.getString(c.getColumnIndex("project_name"));

      Toast.makeText(this, str_projectname, Toast.LENGTH_LONG).show();


}      

这是数据库类中返回游标的方法:

public Cursor getDataforDisplay () {    

    String[] columns = new String[] {KEY_ROWID, PROJECT_NAME, PROJECT_FINISH_DATE, PROJECT_DIFFICULTY, PROJECT_STATUS};
    Cursor c = projectDatabase.query(DATABASE_TABLE, columns, null, null, null, null, null);

    projectDatabase.query(DATABASE_TABLE, columns, null, null, null, null, null);

    c.moveToFirst();
    return c;

}

我还想显示定义为_id

的KEY_ROWID

2 个答案:

答案 0 :(得分:3)

您可以使用android.R.layout.simple_list_item_2指定表中的第2列,从中可以检索数据并指定位置,借助它可以在Activity上显示 - android.R.id.text2

  adapter = new SimpleCursorAdapter(this, android.R.layout.simple_list_item_2, cursor, new String[] {"project_name","column_no2"}, new int[] { android.R.id.text1, andriod.R.id.text2 }, 0);

您还可以创建自定义适配器,指定您自己的Listview并从头开始创建并自定义所有内容。

答案 1 :(得分:1)

至少在我看来,实现这一目标的最佳方法是为ListView创建自定义适配器,在这种情况下,您可以设置自己的设计单个listview元素的外观。只需使用Cursor填充一些数组,然后将它们设置为自定义适配器。