如何在SQLite数据库上显示存储为BLOB的图像

问题描述 投票:0回答:1

我是android studio的新手,我对此有困难。我在android studio上的SQLite数据库中存储了一个图像:

public void onCreate(SQLiteDatabase db){
        db.execSQL(create_table);
    }

private static final String create_table = "create table if not exists Test ("+
            "EntryID integer primary key autoincrement, "+
            "Description string,"+
            "Picture blob"+
            ")";

我将数据硬编码到数据库中,如下所示:

ContentValues cv5 = new ContentValues();
    cv5.put("EntryID",1);
    cv5.put("Description","The club was founded in 1885";
    cv5.put("Picture","club.png");
    sdb.insert("Test",null,cv5);

在另一个类中,我试图显示这个存储的图像,我遇到了很多麻烦。我之前从未遇到过BLOB。

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    Drawable myDrawable = getResources().getDrawable(R.drawable.club);
    image.setImageDrawable(myDrawable);
}

当我尝试在这个类中设置图像时,我得到一个错误,预计会有一个drawable。就像我说的那样,我对此很新

java android sqlite imageview blob
1个回答
1
投票

cv5.put( “图片”, “club.png”); //这是一个错误的方式

您需要先将图像转换为BLOB,就像这样

ByteArrayOutputStream outStreamArray = new ByteArrayOutputStream();  
    Bitmap bitmap = ((BitmapDrawable)getResources().getDrawable(R.drawable.common)).getBitmap();
    bitmap.compress(Bitmap.CompressFormat.PNG, 100, outStrea);   
    byte[] photo = outStreamArray.toByteArray();cv5.put("Picture", photo)

之后,您需要解码BLOB到图像

  byte[] photo=cursor.getBlob(index of blob cloumn);
ByteArrayInputStream imageStream = new ByteArrayInputStream(photo);
Bitmap bitmap= BitmapFactory.decodeStream(imageStream);
image.setImageBitmap(bitmap);
最新问题
© www.soinside.com 2019 - 2025. All rights reserved.