android开发之数据库存取图片
来源:互联网 发布:centos中文man手册 编辑:程序博客网 时间:2024/04/30 16:56
转自:http://www.cnblogs.com/cuixiaodong427/archive/2013/06/22/3149868.html
Android数据库中存取图片通常使用两种方式,一种是保存图片所在路径,二是将图片以二进制的形式存储(sqlite3支持BLOB数据类型)。对于两种方法的使用,好像第二种方法不如第一种方法更受程序员欢迎,他们认为,在很多数据库语言里,处理大字段都是不容易的,像图片这样的文件放在数据库里会有问题:对数据库的读写速度永远赶不上文件系统的处理速度,使数据库变得巨大;但也有很多人认为像图片这样的数据存放在数据库中也有好处:易于备份,且备份速度绝对比备份文件快,比较容易数据迁移等等。其实这两种方法都有优缺点,具体使用哪种方法要视情况而定。个人倾向于使用数据库存取图片,因为个人认为存到数据库里的数据不会因外部数据的变化而丢失改变,比如你拍照获得一张图片,如果是将路径存到数据库,当这张照片被删除之后,下次读取数据库就得不到想要的结果了。接下来详细介绍数据库存取图片的方法:
1.从资源中获取Bitmap对象
1 Resources res = getResources();2 Bitmap bmp = BitmapFactory.decodeResource(res, R.drawable.icon);
2.把图片转换成字节
1 public byte[] img(int id)2 {3 ByteArrayOutputStream baos = new ByteArrayOutputStream();4 Bitmap bitmap = ((BitmapDrawable) getResources().getDrawable(id)).getBitmap();5 bitmap.compress(Bitmap.CompressFormat.PNG, 100, baos);6 return baos.toByteArray();7 }
3.在数据库中插入图片
//在数据库创建时,图片字段的数据类型存储为 BLOB数据库插入操作public void onCreate(SQLiteDatabase db){ String sql = "create table " + TB_NAME + " ( " + ID + " integer primary key , " + IMAGE + " BLOB ) "; db.execSQL(sql);} //将图片一字节形式存储数据库读取操作public long insert(byte[] img) { SQLiteDatabase db = getWritableDatabase(); ContentValues cv = new ContentValues(); cv.put(IMAGE, img); long result = db.insert(TB_NAME, null, cv); return result;}
4.获取存入数据库的图片(Bitmap)
public Bitmap getBmp(int position) { SQLiteDatabase db = getReadableDatabase(); Cursor cursor = select(TB_NAME); cursor.moveToPosition(position); byte[] in = cursor.getBlob(cursor.getColumnIndex(IMAGE)); Bitmap bmpout = BitmapFactory.decodeByteArray(in, 0, in.length); return bmpout;}
//imgView.setImageBitmap(bm);
5.转换获取的图片(Bitmap)为Drawable
1 public Drawable chage_to_drawable(Bitmap bp)2 {3 //因为BtimapDrawable是Drawable的子类,最终直接使用bd对象即可。4 Bitmap bm=bp; 5 BitmapDrawable bd= new BitmapDrawable(getResource(), bm); 6 return bd;7 }
0 0
- android开发之数据库存取图片
- android开发之数据库存取图片
- android开发之数据库存取图片
- android开发之数据库存取图片
- android开发之数据库存取图片
- android开发之数据库存取图片
- Android 数据库存取图片
- Android 数据库存取图片
- Android 数据库存取图片
- Android 数据库存取图片
- Android 数据库存取图片
- Android 数据库存取图片
- Android-sqlite数据库存取图片信息
- Android-sqlite数据库存取图片信息
- 数据库存取图片
- 数据库中存取图片
- 数据库存取图片
- C#数据库存取图片
- javascript 常用对象与函数 列表
- 拼接html字符串,onClick传递两个参数写法
- UIActivityIndicatorView 进度条(小菊花)-> 后面也可以自定义一个进度条
- redhat下安装gcc(转)
- Linux系统网络设备启动和禁止“ifconfig eth0 up/down”命令的跟踪
- android开发之数据库存取图片
- 山大工大联谊1007 combinatorial mathematics once more 【斯特灵数,贝尔数】
- uvalive 5052
- 第四周【项目1-三角形类的构造函数】(1)
- 编写一个函数,将一个数字字符串转换成该字符串对应的数字(包括正整数、负整数) 例如:“12“ 返回12 “-123“ 返回-123 函数原型:int my_atoi(char *str) {}
- Java基础-22
- 图 深度优先遍历 广度优先遍历 非递归遍历 图解算法过程
- WebMatrix3 启动报KeyNotFoundException错误解决方法
- css 常用属性索引