android开发之数据库存取图片

原博客地址(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
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值