android 图片的缩放,bitmap的用法

本文介绍在Android中如何按需求缩放图片,并提供Bitmap的使用方法,包括从资源、文件及网络加载图片的方式。此外,还详细解释了android:scaleType属性的不同选项及其效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、将图片按自己的要求缩放

// 图片源
    Bitmap bm = BitmapFactory.decodeStream(getResources()
      .openRawResource(R.drawable.dog));
    // 获得图片的宽高
    int width = bm.getWidth();
    int height = bm.getHeight();
    // 设置想要的大小
    int newWidth = 320;
    int newHeight = 480;
    // 计算缩放比例
    float scaleWidth = ((float) newWidth) / width;
    float scaleHeight = ((float) newHeight) / height;
    // 取得想要缩放的matrix参数
    Matrix matrix = new Matrix();
    matrix.postScale(scaleWidth, scaleHeight);
    // 得到新的图片
    Bitmap newbm = Bitmap.createBitmap(bm, 0, 0, width, height, matrix,
      true);
    // 放在画布上
    canvas.drawBitmap(newbm, 0, 0, paint);

相关知识链接:http://www.eoeandroid.com/thread-3162-1-1.html

二、bitmap的用法

BitmapFactory.Options option = new BitmapFactory.Options();
   option.inSampleSize = 2; //将图片设为原来宽高的1/2,防止内存溢出
   Bitmap bm = BitmapFactory.decodeFile("",option);//文件流

URL url = new URL("");
   InputStream is = url.openStream();
   Bitmap bm = BitmapFactory.decodeStream(is);

 

android:scaleType:

  android:scaleType是控制图片如何resized/moved来匹对ImageView的size。ImageView.ScaleType / android:scaleType值的意义区别:

  CENTER /center 按图片的原来size居中显示,当图片长/宽超过View的长/宽,则截取图片的居中部分显示

  CENTER_CROP / centerCrop 按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽)

  CENTER_INSIDE / centerInside 将图片的内容完整居中显示,通过按比例缩小或原来的size使得图片长/宽等于或小于View的长/宽

  FIT_CENTER / fitCenter 把图片按比例扩大/缩小到View的宽度,居中显示

  FIT_END / fitEnd 把图片按比例扩大/缩小到View的宽度,显示在View的下部分位置

  FIT_START / fitStart 把图片按比例扩大/缩小到View的宽度,显示在View的上部分位置

  FIT_XY / fitXY 把图片 不按比例 扩大/缩小到View的大小显示

  MATRIX / matrix 用矩阵来绘制,动态缩小放大图片来显示。

 

来自:http://hi.baidu.com/%CD%F5%D5%F1%C1%D6wzl/blog/item/8a81de904f334410d31b70a6.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值