现在的位置: 首页 > 综合 > 正文

listview利用SimpleCursorAdapter显示sqlit数据库中的图片

2013年02月01日 ⁄ 综合 ⁄ 共 1406字 ⁄ 字号 评论关闭

listview利用SimpleCursorAdapter显示sqlit数据库中的图片

By 王军, 2010年03月29日 5:03 下午

listview利用SimpleCursorAdapter显示sqlit数据库列表中介绍了利用SimpleCursorAdapter在列表中显示sqlite查询的数据,但是没有解决图片的显示。通过查询相关的资料,已经解决了图片的显示问题,前提是图片要保存到sqlite数据库中,操作结果如图所示:

   image

其中的图片是存储在数据库中的数据。其中还利用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

抱歉!评论已关闭.