3-VIV-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));

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏开发之途

Android 仿微信底部渐变Tab

22530
来自专栏向治洪

Android仿拼多多拼团堆叠头像

序言 做电商的都知道,作为商品的一种售卖方式,拼团是是提供商品售卖的一种及时有效的方式,而在拼团市场中,拼多多无疑是做的最好的一家。于是,研究拼多多的售卖方式之...

24160
来自专栏Android开发指南

Android刮刮卡自定义控件

40290
来自专栏肖蕾的博客

打造一个无数据显示无数据提示信息的ListView

12830
来自专栏Android干货

关于安卓开发实现侧滑菜单效果

1.1K80
来自专栏向治洪

Android仿拼多多拼团堆叠头像

序言 做电商的都知道,作为商品的一种售卖方式,拼团是是提供商品售卖的一种及时有效的方式,而在拼团市场中,拼多多无疑是做的最好的一家。于是,研究拼多多的售卖方式之...

62780
来自专栏非著名程序员

AutoFlowLayout-多功能流式布局与网格布局控件

近期工作需要用到流式布局,网上也有很多关于这方面的资料。发现流式布局与网格布局的自定义很有意思,是学习自定义控件的一个很好的方式,所以就撸了个几百行代码的控件,...

413100
来自专栏Android干货

安卓开发_慕课网_百度地图_刮刮涂层效果

377140
来自专栏郭霖

Android滑动菜单特效实现,仿人人客户端侧滑效果,史上最简单的侧滑实现

人人客户端有一个特效还是挺吸引人的,在主界面手指向右滑动,就可以将菜单展示出来,而主界面会被隐藏大部分,但是仍有左侧的一小部分同菜单一起展示。 据说人人客户端的...

304100
来自专栏向治洪

PullToRefreshScrollView 嵌套RecyclerView实现特卖列表倒计时抢购

不久之前,我们谈到了通过Handler与timer及TimerTask结合实现倒计时抢购列表,那个是PullToRefreshListView实现的,今天要讲的...

36050

扫码关注云+社区

领取腾讯云代金券