1.ImageView地位:直接继承自View,安卓源码1600+,算是个小类,但图片显示基本上都用它
2.scaleType有点小烦,不过看图还是挺清晰的
3.cropToPadding、adjustViewBounds、tint
4.图片设置
源码中ImageView的自定义属性:
* @attr ref android.R.styleable#ImageView_adjustViewBounds
* @attr ref android.R.styleable#ImageView_src
* @attr ref android.R.styleable#ImageView_maxWidth
* @attr ref android.R.styleable#ImageView_maxHeight
* @attr ref android.R.styleable#ImageView_tint
* @attr ref android.R.styleable#ImageView_scaleType
* @attr ref android.R.styleable#ImageView_cropToPadding #是否截取指定区域用空白代替,需要与scrollY一起使用
一图抵千言:左边大图,右边小图
默认:fitCenter
在xml里matrix表现良好(如图开始),但用代码控制有些奇怪
fitCenter:按比例扩大或缩小到ImageView的ImageView的高度,居中显示
fitEnd:按比例扩大(缩小)到ImageView的高度,显示在ImageView的下部分位置
fitStart:按比例扩大(缩小)到ImageView的高度,显示在ImageView的上部分位置
fitXY:不保持原比例,填满ImageView
center:按比例扩大或缩小到ImageView的ImageView的高度,居中显示
centerCrop:(小图会放大形成模糊版的center,大图同center)
centerInside:(小图会保持原大小,大图同fitCenter)
matrix:不改变原图的大小,从ImageView的左上角开始绘制,超过ImageView的裁剪
测试时true和false没有区别。
效果上来看,图片位置偏移了
android:cropToPadding="true"
android:scrollY="@dimen/sp_30"
android:scrollX="@dimen/sp_16"
前提:1.保证layout_width、layout_height为wrap_content
2.设置了maxHeight、maxWidth
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:maxHeight="50dp"
android:maxWidth="50dp"
android:adjustViewBounds="true"
android:tint="#22FF4081"
android:src="@mipmap/iv_50x40"
Drawable和Bitmap都是安卓中图片显示和处理的重要类,以后会详细论述。
//通过资源加载
mIv500.setImageResource(R.mipmap.bg4);
//通过Drawable对象加载
mIv500.setImageDrawable(ContextCompat.getDrawable(this, R.mipmap.cup));
//通过Bitmap对象加载
mIv500.setImageBitmap(BitmapFactory.decodeResource(getResources(), R.mipmap.bz));
1本文由张风捷特烈原创,转载请注明
2欢迎广大编程爱好者共同交流
3个人能力有限,如有不正之处欢迎大家批评指证,必定虚心改正
4你的喜欢与支持将是我最大的动力
张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com
QQ:1981462002
邮箱:1981462002@qq.com
微信:zdl1994328
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。