sqlite 如何将图像保存到数据库中

h43kikqp  于 2023-04-21  发布在  SQLite
关注(0)|答案(2)|浏览(442)

我想知道是否有一种方法可以将图像(.gif类型)保存到sqllite数据库中。如果有,我的DatabaseAdapter应该是什么样子?
是否也存在性能问题?

js81xvg6

js81xvg61#

您应该在数据库中使用BLOB
检查this tutorial ...
但我认为你应该下载并存储图像在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;
    }       
}

希望对你有帮助。

oxosxuxt

oxosxuxt2#

将图像存储到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大小(不记得有多少)

相关问题