无法从android中的sqlite数据库加载图像

时间:2013-08-02 05:02:44

标签: android database sqlite blob

我尝试从数据库加载图像但图像未加载,logcat显示为null 是我用我编程的方式simethinf ..

imgdisplay = (ImageView) findViewById(R.id.imgIcon);
myDB = this.openOrCreateDatabase("hello", MODE_PRIVATE, null);

Cursor c = myDB.rawQuery(
    "SELECT image  FROM employee_details WHERE name= 'vv'", null);

if (c.getCount() > 0) {
    c.moveToFirst();
    do {
        byte[] blob = c.getBlob(c.getColumnIndex("image"));
        ImageView iv = (ImageView) findViewById(R.id.imgIcon);
        iv.setImageBitmap(BitmapFactory.decodeByteArray(blob, 0,blob.length));
    } while (c.moveToNext());
}
c.close();
myDB.close();

Logcat错误是......

08-02 04:51:25.471: D/skia(8433): --- SkImageDecoder::Factory returned null

3 个答案:

答案 0 :(得分:2)

尝试以下代码..

byte[] Image_bytes = cursor.getBlob(cursor.getColumnIndex("image"));
ImageView iv = (ImageView) findViewById(R.id.imgIcon);
iv.setImageBitmap(new ImageConversation().convertArrayToBmp(Image_bytes));

...

public Bitmap convertArrayToBmp(byte[] array) {
    Bitmap bitmap = BitmapFactory.decodeByteArray(array, 0, array.length);
    return bitmap ;
}

使用以下循环

c.moveToFirst();
while(!c.isAfterLast()) {
    byte[] blob = c.getBlob(c.getColumnIndex("image"));
    ImageView iv = (ImageView) findViewById(R.id.imgIcon);
    iv.setImageBitmap(BitmapFactory.decodeByteArray(blob, 0,blob.length));
    c.moveToNext()
}

答案 1 :(得分:0)

尝试做这样的事情 -

如果您将图像存储为数据库中的字符串

 if(image.isEmpty())
  {
   System.out.println("is empty image");

  }
  else
  {
   byte[] decodedByte = Base64.decode(image, 0);
   Bitmap bm = BitmapFactory.decodeByteArray(decodedByte, 0,
     decodedByte.length);
   iv.setImageBitmap(bm);
  }

答案 2 :(得分:0)

我没有找到将图像保存到数据库的方法,所以我开始将图像直接保存到内部存储器中,这不是问题的答案,但可能会给其他人提供一些想法有任何想法......

保存到内部存储器......

   File fileWithinMyDir = getApplicationContext().getFilesDir();  
    try 
          {
              StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder()
              .permitAll().build();
          StrictMode.setThreadPolicy(policy); 
           URL url = new URL("http://t2.gstatic.com  /images?q=tbn:ANd9GcQjZgUffqqe2mKKb5VOrDNd-ZxD7sJOU7WAHlFAy6PLbtXpyQZYdw");
           File file = new File( fileWithinMyDir.getAbsolutePath()  + "/" +"sun.jpg");
           URLConnection ucon = url.openConnection();
           InputStream is = ucon.getInputStream();
           BufferedInputStream bis = new BufferedInputStream(is);
           ByteArrayBuffer baf = new ByteArrayBuffer(50);
           int current = 0;
           while ((current = bis.read()) != -1) 
           {
            baf.append((byte) current);
           }

           FileOutputStream fos = new FileOutputStream(file);
           fos.write(baf.toByteArray());
           fos.close();
        } 
        catch (IOException e) 
        {
            Log.e("download", e.getMessage());
        }

从内存中加载图像..

 StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder()
          .permitAll().build();
           StrictMode.setThreadPolicy(policy); 
          mImgView1 = (ImageView) findViewById(R.id.mImgView1); 

          Bitmap bitmap = BitmapFactory.decodeFile(fileWithinMyDir.getAbsolutePath()  + "/" +"sunn"+".file extension");
          mImgView1.setImageBitmap(bitmap);

这是因为“android.os.networkonmainthreadexception”而显示错误的较新的android?

如果你想解决问题,你也可以使用AsyncTask ...