如何在安卓模拟器的图库中取出照片,存入SQLite中,再从SQLite中拿取出使用

楼主是一名安卓小菜鸟,这个问题是我之前做作业遇到了,当时查看了很多回答,答案类似,但不完整,现在我把它整理了一番,希望能帮到有同样困难的朋友,大神勿进。
首先我们要弄清楚,在调用系统图库的图片时,ContentProvider(内容提供者):将应用中的数据暴露供其他应用使用;ContentResolver(内容解析者):解析使用其他应用提供的数据。我们最后得到的结果是统一资源标识(Uri)。安卓的UI线程中可以直接设置图片的Uri,显示图片。但是如何将Uri存入轻量级数据库,然后取出来呢,当然不能直接的对Uri进行toString,这里饶了两个弯。

1、将Uri转换成String类型,存入数据库

前面说了Uri不能直接toString,我们先将Uri转换为Bitmap类型,再将BitMap转换为String,BitMap也不能直接toString。`

bitmap= MediaStore.Images.Media.getBitmap(this.getContentResolver(),uri); //将Uri转换为BitMap类型
                ByteArrayOutputStream baos=new ByteArrayOutputStream();
                bitmap.compress(Bitmap.CompressFormat.PNG,100,baos);    //将BitMap压缩转换成字节数组输出流
                byte[] appicon=baos.toByteArray();
                path=Base64.encodeToString(appicon,Base64.DEFAULT); //这里的path是String类型

接下来,String 就能存入数据了。

2、将存入数据库中的字符串显示为图片

从SQLite中取出字段值我就不说了,用cursor很简单的。将字符串显示为图片与步骤1的逆向过程,将String 转换为BitMap即可,这是后就能直接显示图片。


    Bitmap bitmap=null;
        byte[] bitmparry;
        bitmparry=Base64.decode(path,Base64.DEFAULT);
        bitmap=BitmapFactory.decodeByteArray(bitmparry,0,bitmparry.length);
        image.setImageBitmap(bitmap);

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值