[英]How to save images into Database
我想知道是否有办法将图像(.gif 类型)保存到 sqllite 数据库。 如果是,我的DatabaseAdapter
应该是什么样子。
还有性能问题吗?
您应该在数据库中使用BLOB
:
检查本教程...
但是我认为你应该在HashMap中下载并存储图像,这样会更简单。
代码:
努力
var imageMap = new HashMap<String, byte[]>();
var imageUrl = "http://i.stack.imgur.com/TLjuP.jpg";
var imagedata = GetImage(imageUrl);
imageMap.put("img",imagedata);
检索
var imageData = imageMap.get("img");
var imageStream = new ByteArrayInputStream(imageData);
var image = BitmapFactory.decodeStream(imageStream);
获取图像
private byte[] GetImage(String url)
{
try
{
var imageUrl = new URL(url);
var urlConnection = imageUrl.openConnection();
var inputStream = urlConnection.getInputStream();
var bufferedInputStream = new BufferedInputStream(inputStream);
var byteArrayBuffer = new ByteArrayBuffer(500);
int current = 0;
while ((current = bis.read()) != -1)
{
byteArrayBuffer.append((byte)current);
}
return byteArrayBuffer.toByteArray();
}
catch (Exception e)
{
Log.d("ImageManager", "Error: " + e.toString());
return null;
}
}
希望对你有帮助。
将图像存储到 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 大小(真的不记得有多少)
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.