zoukankan      html  css  js  c++  java
  • 图片的ScaleType详解 ImageView的属性android:scaleType,

     imageView.setScaleType(ImageView.ScaleType.FIT_XY );

     这里我们重点理解ImageView的属性android:scaleType,即ImageView.setScaleType(ImageView.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 用矩阵来绘制

    一开始我不明白MATRIX矩阵,网上搜索后发现原来MATRIX矩阵可以动态缩小放大图片来显示,这里不展开深入的了解,只是贴出相关语句,缩小图片:

    //获得Bitmap的高和宽 
            int bmpWidth = bmp.getWidth();
            int bmpHeight = bmp.getHeight();
    
            //设置缩小比例 
            double scale = 0.8;
            //计算出这次要缩小的比例 
            scaleWidth = (float) (scaleWidth * scale);
            scaleHeight = (float) (scaleHeight * scale);
    
            //产生resize后的Bitmap对象 
            Matrix matrix = new Matrix();
            matrix.postScale(scaleWidth, scaleHeight);
            Bitmap resizeBmp = Bitmap.createBitmap(bmp, 0, 0, bmpWidth, bmpHeight, matrix, true);
     <ImageView 
        android:id="@+id/image" 
         android:layout_width="fill_parent"  
         android:layout_height="fill_parent" 
         android:scaleType="center" 
         android:src="@drawable/candle"/> 
  • 相关阅读:
    【转】Linux目录结构FHS
    单链表是否有环并如何找到环入口
    【转】linux dd 的简单应用
    DataSet、ExecuteScalar、ExecuteReader
    解决Excel只验证前8行字符串的长度
    SQL Server UPSERT equivalent
    用通配符替换字符串
    从内存中查询表字段定义的长度大小
    C#判断一个字符串是否为整数
    page life cycle of master page with content page
  • 原文地址:https://www.cnblogs.com/niray/p/3815104.html
Copyright © 2011-2022 走看看