我正在使用SimpleCursorAdapter
来管理我对数据库的查询,然后在ListView
中显示结果。
这是我的代码:
database.open();
ListView listContent = (ListView)findViewById(android.R.id.list);
Cursor c = database.getData();
startManagingCursor(c);
String[] from = new String[]{Database._GROUP_NAME};
int[] to = new int[]{android.R.id.text1};
SimpleCursorAdapter adapter = new SimpleCursorAdapter(this, android.R.layout.simple_list_item_1, query, from, to);
listContent.setAdapter(adapter);
database.close();
虽然,初看起来,它按预期工作,我认为这不应该是继续进行的方式,因为CursorAdapter
。
我知道这是一个noob问题,但自从刚刚开始编程Android以来我仍然不太了解。
如何将此SimpleCursorAdapter
传递给CursorAdapter
?
已经在互联网上搜索过,但无法理解如何做到这一点。
不要仅仅向某些方向询问代码。
由于
favolas
更新以下主题评论
database.open();
ListView listContent = (ListView)findViewById(android.R.id.list);
Cursor c = database.getData();
MyAdapt cursorAdapter = new MyAdapt(this, query);
listContent.setAdapter(adapter);
database.close();
MyAdapt课程:
public class MyAdapt extends CursorAdapter {
private final LayoutInflater mInflater;
public MyAdapt(Context context, Cursor c) {
super(context, c);
mInflater = LayoutInflater.from(context);
mContext = context;
}
@Override
public void bindView(View view, Context context, Cursor cursor) {
TextView groupName = (TextView) view.findViewById(android.R.id.text1);
groupName.setText(cursor.getString(cursor
.getColumnIndex(Database._GROUP_NAME)));
}
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
final View view = mInflater.inflate(
android.R.layout.simple_list_item_1, parent, false);
return view;
}
}
这是正确的方法吗?
favolas
答案 0 :(得分:2)
SimpleCursorAdapter是可用于自定义适配器的最简单的适配器形式。 您应该只在不需要任何自定义时使用SimpleCursorAdapter。