Android控件之ImageView

零、前言

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一起使用

一、剪裁类型:scaleType

一图抵千言:左边大图,右边小图

默认:fitCenter

在xml里matrix表现良好(如图开始),但用代码控制有些奇怪

ImageView裁剪类型.gif
fitCenter:按比例扩大或缩小到ImageView的ImageView的高度,居中显示
fitEnd:按比例扩大(缩小)到ImageView的高度,显示在ImageView的下部分位置
fitStart:按比例扩大(缩小)到ImageView的高度,显示在ImageView的上部分位置
fitXY:不保持原比例,填满ImageView
center:按比例扩大或缩小到ImageView的ImageView的高度,居中显示
centerCrop:(小图会放大形成模糊版的center,大图同center)
centerInside:(小图会保持原大小,大图同fitCenter)
matrix:不改变原图的大小,从ImageView的左上角开始绘制,超过ImageView的裁剪

二、剪裁:cropToPadding:需要与scrollX或scrollY同用,单独无效

测试时true和false没有区别。

效果上来看,图片位置偏移了

cropToPadding.gif
android:cropToPadding="true"
android:scrollY="@dimen/sp_30"
android:scrollX="@dimen/sp_16"

三、adjustViewBounds

前提:1.保证layout_width、layout_height为wrap_content

2.设置了maxHeight、maxWidth

adjustViewBounds.png
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:maxHeight="50dp"
android:maxWidth="50dp"
android:adjustViewBounds="true"

四、tint覆盖色:最好有透明度的颜色,不然图片就全盖住了

tint.png
android:tint="#22FF4081"

五、最重要的要数设置图片了

1.xml设置图片
android:src="@mipmap/iv_50x40"
2.代码中设置

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.声明:

1本文由张风捷特烈原创,转载请注明

2欢迎广大编程爱好者共同交流

3个人能力有限,如有不正之处欢迎大家批评指证,必定虚心改正

4你的喜欢与支持将是我最大的动力

2.连接传送门:

更多安卓技术欢迎访问:安卓技术栈

我的github地址:欢迎star

简书首发,腾讯云+社区同步更新

张风捷特烈个人网站,编程笔记请访问:http://www.toly1994.com

3.联系我

QQ:1981462002

邮箱:1981462002@qq.com

微信:zdl1994328

4.欢迎关注我的微信公众号,最新精彩文章,及时送达:
公众号.jpg

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏非著名程序员

教你步步为营掌握自定义 View

国内自定义View的文章汗牛充栋,但是,即使你全部看完它们也未必能掌握这一知识点(实际上,我就几乎看完了所有的国内文章)。为什么?一言以蔽之,你是得其术不明其道...

2016
来自专栏Android干货园

Android自定义下拉刷新动画--仿百度外卖下拉刷新

版权声明:本文为博主原创文章,转载请标明出处。 https://blog.csdn.net/lyhhj/article/details/51...

1343
来自专栏Android知识点总结

6-VI--ListView琐碎小知识点汇总

954
来自专栏Android干货

Android项目实战(四十一):游戏和视频类型应用 状态栏沉浸式效果

3446
来自专栏何俊林

DragVideo,一种在播放视频时,可以任意拖拽的方案

前言:项目已开源到我的github,点击【阅读原文】可以对应github地址。 DragVideo A Method to Drag the Video Wh...

3487
来自专栏Android开发指南

15.屏幕适配

3898
来自专栏Android机器圈

Android图片处理--全景查看效果

PS:Android对于图片处理这块资源还是挺多的,之前用OpenGL制作图片的全景效果,耗时耗力,而且只能点击进去后看到,但是效果是非常的号,今天所写的是编写...

2283
来自专栏知识分享

3-系统方案A(Activity界面跳转,携带数据,显示曲线界面)

https://www.cnblogs.com/yangfengwu/p/9970387.html

972
来自专栏androidBlog

你真的了解View的坐标吗?

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gdutxiaoxu/article/details/...

822
来自专栏QQ音乐技术团队的专栏

小窗播放视频的原理和实现(下)

本文对小窗视频播放进行了详细的研究,针对几种实现方案进行了深入的对比分析,进而给出实现小窗视频播放的最优解。其中通过对系统源码的分析,详细探究了如何完美地实现移...

88210

扫码关注云+社区

领取腾讯云代金券