楼主是一名安卓小菜鸟,这个问题是我之前做作业遇到了,当时查看了很多回答,答案类似,但不完整,现在我把它整理了一番,希望能帮到有同样困难的朋友,大神勿进。
首先我们要弄清楚,在调用系统图库的图片时,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);