ImageView的属性和使用
属性详解
1. scaleType
Android 提供了八种scaleType的属性值,每种都对应了一种展示方式,八个ScaleType,其实可以分为三个类型:
-
以FIT_开头的4种,它们的共同点是都会对图片进行缩放;
-
以CENTER_开头的3种,它们的共同点是居中显示,图片的中心点会与ImageView的中心点重叠;
-
ScaleType.MATRIX
1. ScaleType.FIT_CENTER(默认)
此模式图片会被等比缩放到能够填充控件大小,并居中展示。
2. ScaleType.FIT_START
图片等比缩放到控件大小,并放置在控件的上边或左边展示。
3. ScaleType.FIT_END
图片等比缩放到控件大小,并放置在控件的下边或右边展示。
4. ScaleType.FIT_XY
图片缩放 (不是等比缩放) 到控件大小,完全填充控件大小展示。
5. ScaleType.CENTER
不使用缩放,ImageView会和图片中心对齐后展示图片的中心部分。如果图片的大小小于控件的宽高,那么图片会被居中显示;如果图片大小超过控件的宽高,超出部分无法显示。
6. ScaleType.CENTER_CROP
该模式下图片会被等比缩放直到完全填充整个ImageView,并居中显示。此模式下如果图片宽高大于控件宽高,则图片宽或者高有一个可以完整展示。
7. ScaleType.CENTER_INSIDE
此模式以完全展示图片的内容为目的。图片将被等比缩放到能够完整展示在ImageView中并居中。和ScaleType.FIT_CENTER区别在于如果图片大小小于控件大小,ScaleType.CENTER_INSIDE模式会直接居中展示该图片,不填充到整个空间
8. ScaleType.MATRIX
该模式需要与ImageView.setImageMatrix(Matrix matrix) 配合使用,因为该模式需要用于指定一个变换矩阵用于指定图片如何展示。前面的7种模式都是通过ImageView在内部生成了相应的变换矩阵,等于是提供了该模式的一种特定值。
在使用时,需要先调用setScaleType(ImageView.ScaleType.MATRIX)方法再调用setImageMatrix(matrix),顺序不能错。
代码调用setScaleType(ImageView.ScaleType scaleType)
2. adjustViewBounds
设置ImageView是否调整自己的边界来保持所显示图片的长宽比。需要结合 android:maxWidth、 android:maxHeight一起使用否则单独使用没有效果,并且设置 layout_width和 layout_height为 wrap_content
3. background
使用background添加背景资源时,所添加的背景能够充满整个控件的大小,如果当前使用的资源不能够满足控件大小时,将会把当前资源自动进行拉伸以满足添加背景资源的需要。如果background设置为颜色值,那么整个区域都会被该颜色值填充。当仅仅设置了背景颜色而没有设置src,且宽或者高被设置为wrap_content时,则该View将不会显示。
4. src
src是图片内容(前景),会根据设置将原图填充控件。
5. alpha
设置view透明度。代码 setAlpha(int alpha)
6. tint
颜色值,对图片进行着色,可以实现对相同的基础图片着色后显示不同的效果。可以配合tintMode使用。默认情况下,TINT将使用SRC_ATOP模式混合。代码调用:
setColorFilter(int color)
setColorFilter(int color, PorterDuff.Mode mode)
setColorFilter(ColorFilter cf)
setImageTintList(ColorStateList tint)
注: tint属性的默认tintMode为SRC_ATOP,区别于其他view和setImageTintList(ColorStateList tint)
方法的默认模式为 SRC_IN
7. tintMode
设置着色模式,共有6种模式: (TODO: 每个mode作用的完善)
- src_in
- multiply
- add
- screen
- src_atop
- src_over
代码调用setImageTintMode(PorterDuff.Mode tintMode)