Я хотел бы знать, есть ли способ сохранить изображения (типа .gif) в sqllite-database. Если да, то как должен выглядеть мой DatabaseAdapter
.
Также есть проблема с производительностью?
Я хотел бы знать, есть ли способ сохранить изображения (типа .gif) в sqllite-database. Если да, то как должен выглядеть мой DatabaseAdapter
.
Также есть проблема с производительностью?
Вы должны использовать BLOB
в своей базе данных:
Отметьте этот учебник...
Но я думаю, вы должны скачать и сохранить изображение в HashMap, что упростит его.
код:
Stroring
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;
}
}
Надеюсь, это поможет вам.
Нет ничего особенного в сохранении образа в SQLite. Просто создайте таблицу с типом записи BLOB и сделайте smth вроде:
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 (на самом деле не помню сколько)
Отметьте tutorial, он должен показать вам, что вам нужно.
Еще одна полезная ссылка .