android ImageView scaleType属性(转)

使用ImageView时经常会用到scaleType属性,如:

 

1
2
3
4
5
6
7
8
9
<ImageView
 
  android:layout_width= "50dp" 
 
  android:layout_height= "50dp"
 
    android:scaleType= "matrix" 
 
   android:src= "@drawable/sample_small"  />

  

scaleType属性的各个值总是记不住之间的区别。今天找点时间总结了一下:

scaleType的属性值有:matrix   fitXY  fitStart   fitCenter  fitEnd  center   centerCrop  centerInside

 

它们之间的区别如下:

 

matrix 用矩阵来绘制(从左上角起始的矩阵区域)
 
fitXY  把图片不按比例扩大/缩小到View的大小显示(确保图片会完整显示,并充满View)
 
fitStart  把图片按比例扩大/缩小到View的宽度,显示在View的上部分位置(图片会完整显示)
 
fitCenter  把图片按比例扩大/缩小到View的宽度,居中显示(图片会完整显示)
 
fitEnd   把图片按比例扩大/缩小到View的宽度,显示在View的下部分位置(图片会完整显示)
 
center  按图片的原来size居中显示,当图片宽超过View的宽,则截取图片的居中部分显示,当图片宽小于View的宽,则图片居中显示
 
centerCrop  按比例扩大/缩小图片的size居中显示,使得图片的高等于View的高,使得图片宽等于或大于View的宽
 
centerInside  将图片的内容完整居中显示,使得图片按比例缩小或原来的大小(图片比View小时)使得图片宽等于或小于View的宽 (图片会完整显示)
 
附上两张实验的截图:
 图1: 图片比ImageView大的截图
 
图2: 图比ImageView小 实验截图
 
 
MATRIX矩阵可以动态缩小放大图片来显示,只是贴出相关语句,缩小图片:
 
复制代码
 1 //获得Bitmap的高和宽 
 2 int bmpWidth=bmp.getWidth(); 
 3 int bmpHeight=bmp.getHeight(); 
 4  
 5 //设置缩小比例 
 6 double scale=0.8; 
 7 //计算出这次要缩小的比例 
 8 scaleWidth=(float)(scaleWidth*scale); 
 9 scaleHeight=(float)(scaleHeight*scale); 
10  
11 //产生resize后的Bitmap对象 
12 Matrix matrix=new Matrix(); 
13 matrix.postScale(scaleWidth, scaleHeight); 
14 Bitmap resizeBmp=Bitmap.createBitmap(bmp, 0, 0, bmpWidth, bmpHeight, matrix, true);
复制代码

 

复制代码
1 <ImageView 
2 android:id="@+id/image" 
3     android:layout_width="fill_parent"  
4     android:layout_height="fill_parent" 
5     android:scaleType="center" 
6     android:src="@drawable/candle" 
7 />
复制代码

 

** 要注意一点,Drawable文件夹里面的图片命名是不能大写的
 
 
在独处的过程中激发思考的力量……
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值