美文网首页
ImageView 常见知识

ImageView 常见知识

作者: xsp单细胞 | 来源:发表于2018-03-01 22:40 被阅读0次

    作用

    ImageView,图像视图,直接继承自View类,它的主要功能是用于显示图片,实际上它不仅仅可以用来显示图片,任何Drawable对象都可以使用ImageView来显示。ImageView可以适用于任何布局中,并且Android为其提供了缩放和着色的一些操作

    src 和 background 属性

    一言以蔽之

    • src (前景):setImageDrawable( );
    • background (背景):setBackgroundDrawable( );

    区别

    • src 存放的是原图大小,不进行拉伸,在 View中位置通过 scaleType 属性设置
    • background 根据给定的 width 和 height 进行拉伸,可以设置透明度
    • 两属性可以同时在 xml 或者 java 代码中使用

    scaleType说明

    • android:scaleType=”center”
      保持原图的大小,显示在 ImageView 的中心。当原图的 size 大于 ImageView 的 size,超过部分裁剪处理
    • android:scaleType=”centerCrop”
      以填满整个 ImageView 为目的,将原图的中心对准 ImageView 的中心,等比例放大原图,直到填满 ImageView 为止(指的是 ImageView 的宽和高都要填满),原图超过 ImageView 的部分作裁剪处理
    • android:scaleType=”centerInside”
      以原图完全显示为目的,将图片的内容完整居中显示,通过按比例缩小原图的 size 宽(高)等于或小于 ImageView 的宽(高)。如果原图的 size 本身就小于 ImageView 的
      size,则原图的 size 不作任何处理,居中显示在 ImageView
    • android:scaleType=”matrix” (默认方式)
      不改变原图的大小,从 ImageView 的左上角开始绘制原图,原图超过 ImageView 的部分作裁剪处理
    • android:scaleType=”fitCenter”
      把原图按比例扩大或缩小到 ImageView 的最小边,居中显示
    • android:scaleType=”fitEnd”
      把原图按比例扩大(缩小)到 ImageView 的高度,显示在 ImageView 的下部分位置
    • android:scaleType=”fitStart”
      把原图按比例扩大(缩小)到 ImageView 的高度,显示在 ImageView 的上部分位置
    • android:scaleType=”fitXY”
      把原图按照指定的大小在 ImageView 中显示,拉伸显示图片,不保持原比例,填满 ImageView

    透明度 alpha 的坑

    ImageView 设置透明度主要有以下三种方法:

    • setAlpha(@FloatRange(from=0.0, to=1.0) float alpha) (View提供)
    • setAlpha(int alpha) (已经标记为@Deprecated)
    • setImageAlpha(int alpha) (API>=16)
      其中,setImageAlpha(int alpha) 内部调用 setAlpha(int alpha) 方法,查看 API 可知,setImageAlpha 主要是针对 image 而言,一方面在命名上更为贴切与 View 中的
      setAlpha 方法区分,同时做好兼容性。那 ImageView.setAlpha(0.7f) 来设置ImageView 的透明度对 src 还是 background 有效果呢?正确答案:
    • android:src 在设置 ImageView 的 setAlpha(int alpha) 时,起作用;
    • android:background 在设置 ImageView 的 setAlpha(int alpha) 时,不起作用

    相关文章

      网友评论

          本文标题:ImageView 常见知识

          本文链接:https://www.haomeiwen.com/subject/teonxftx.html