Как сохранить изображения в базу данных - PullRequest
13 голосов
/ 22 сентября 2011

Я хотел бы знать, есть ли способ сохранить изображения (типа .gif) в базу данных sqllite. Если да, то как должен выглядеть мой DatabaseAdapter.

Также есть проблема с производительностью?

Ответы [ 3 ]

20 голосов
/ 22 сентября 2011

Вы должны использовать BLOB в вашей базе данных:

Отметьте этот урок ...

Но я думаю, что вы должны загрузить и сохранить изображение в HashMap,сделает это проще.

Код:

Удушение

Map<String, byte[]> hh = new HashMap<String, byte[]>();

 String hi = "http://i.stack.imgur.com/TLjuP.jpg";
          byte[] logoImagedata = getLogoImage(hi);       

hh.put("img",logoImagedata); 

Получение

byte[] imageByteArray = hh.get("img");

ByteArrayInputStream imageStream = new ByteArrayInputStream(imageByteArray);
        Bitmap theImage= BitmapFactory.decodeStream(imageStream);

getLogoImage ()

private byte[] getLogoImage(String url){
           try {
                   URL imageUrl = new URL(url);
                   URLConnection ucon = imageUrl.openConnection();

                   InputStream is = ucon.getInputStream();
                   BufferedInputStream bis = new BufferedInputStream(is);

                   ByteArrayBuffer baf = new ByteArrayBuffer(500);
                   int current = 0;
                   while ((current = bis.read()) != -1) {
                           baf.append((byte) current);
                   }

                   return baf.toByteArray();
           } catch (Exception e) {
                   Log.d("ImageManager", "Error: " + e.toString());
                   return null;
           }

      }

Надеюсь, это поможет вам.

6 голосов
/ 22 сентября 2011

Нет ничего особенного в сохранении изображения в SQLite. Просто создайте таблицу с типом записи BLOB и выполните что-то вроде:

protected long saveBitmap(SQLiteDatabase database, Bitmap bmp)
{
    int size = bmp.getRowBytes() * bmp.getHeight(); 
    ByteBuffer b = ByteBuffer.allocate(size); bmp.copyPixelsToBuffer(b); 
    byte[] bytes = new byte[size];
    b.get(bytes, 0, bytes.length);
    ContentValues cv=new ContentValues();
    cv.put(CHUNK, bytes);
    this.id= database.insert(TABLE, null, cv);
}

Возможно, вы хотите сохранить фрагмент изображения по фрагменту, так как есть ограничения / рекомендуемый размер BLOB (не помню, сколько)

2 голосов
/ 22 сентября 2011

Проверьте этот учебник , он должен показать вам, что вам нужно. Еще одна полезная ссылка .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...