listview利用SimpleCursorAdapter显示sqlit数据库中的图片
在listview利用SimpleCursorAdapter显示sqlit数据库列表中介绍了利用SimpleCursorAdapter在列表中显示sqlite查询的数据,但是没有解决图片的显示。通过查询相关的资料,已经解决了图片的显示问题,前提是图片要保存到sqlite数据库中,操作结果如图所示:
其中的图片是存储在数据库中的数据。其中还利用sqlite的limite实现了分页功能。
下面是图片显示的代码:
public class MySimpleCursorAdapter extends SimpleCursorAdapter {
private Cursor _cursor;
private Context _context;
public MySimpleCursorAdapter(Context context, int layout, Cursor c,
String[] from, int[] to) {
super(context, layout, c, from, to);
_cursor = c;
_context = context;
}
public void bindView(View view, Context context, Cursor cursor) {
ImageView imageView = (ImageView) view.findViewById(R.id.img);
ByteArrayInputStream stream = new ByteArrayInputStream(
_cursor.getBlob(2));
imageView.setImageDrawable(Drawable.createFromStream(stream, "img"));
super.bindView(view, context, cursor);
}
}
黑体部分是显示数据库中图片的信息。其中在Activity中显示数据内如下:
//显示相应的数据
public void display()
{
ContactsService contactsService = new ContactsService(this);
Cursor cursor = contactsService.getScrollDataCursor(firstnumber*2, 2);
MySimpleCursorAdapter adapter=new MySimpleCursorAdapter(this,R.layout.userinfo,cursor,new String[]{"name","ename"},new int[]{R.id.name,R.id.age});
firstnumber++;
//获取listview
listView.setAdapter(adapter);
}
源代码:http://easymorse-android.googlecode.com/svn/trunk/SqliteDemo