Android布局相关&&ImageView.scaleType

本文详细解析了Android开发中ImageView的scaleType属性的各种选项及其实际应用效果,同时对比了padding与margin的区别。

很多人在看技术书籍或者技术博客的过程中,有些地方会感到困惑,总感觉作者有些地方没说清楚.这大概是由于在平时的学习和工作过程中,对一些相关控件,每个人也许有自己不同的理解.这也是为什么在网络上,有些疑惑得不到解决的原因,这时候就需要自己去查阅原始资料.加深自己的理解,理解的越透彻,就越接近真相.

在Android开发时,常常需要用到ImageView.scaleType这个属性.由于网上很多资料说的不够全面,所以在过去的工作中,从网上及书籍各种资料慢慢理清了其中的区别,整理到了自己的印象笔记中.现转移到自己的博客里.

#Android布局相关

##padding与margin的区别

padding 是以父控件为视角,即本身为父控件 距离自己内部控件的距离为padding, 又称 内边距.
而margin 是以子控件为视角,即本身为子控件,距离其外部控件的距离为margin,又称外边距.

##ImageView 的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的ImageView的高度,居中显示

android:scaleType=”fitEnd”
把原图按比例扩大(缩小)到ImageView的高度,显示在ImageView的下部分位置

android:scaleType=”fitStart”
把原图按比例扩大(缩小)到ImageView的高度,显示在ImageView的上部分位置

android:scaleType=”fitXY”
把原图按照指定的大小在View中显示,拉伸显示图片,不保持原比例,填满ImageView.

ImageView的android:adjustViewBounds属性为是否保持原图的长宽比,单独设置不起作用,需要配合maxWidth或maxHeight一起使用。

fitCenter与centerInside的区别在于,fitCenter是将原图等比例放大或缩小,使原图的高度等于ImageView的高度,并居中显示,而centerInside在原图的原本size大于ImageView的size时,则缩小原图,效果同fitCenter;在原图的原本size小于ImageView的size时,则不进行任何size处理,居中显示,效果同center。

我在给一个布局添加提示图标,但是切换RTL后图标不见了,该怎么改 private fun addTipsIcon() { if (tipsIcon == null) { return } var thisClass: Class<Any>? = this.javaClass while (thisClass?.name != TextInputLayout::class.java.name) { if (thisClass?.name == LinearLayout::class.java.name) { break } thisClass = thisClass?.superclass } try { val field: Field? = thisClass?.getDeclaredField("collapsingTextHelper") field?.isAccessible = true val collapsingTextHelper: CollapsingTextHelper = field?.get(this) as CollapsingTextHelper collapsingTextHelper.maxLines = 2 //calculateCollapsedTextWidth已经被替换为collapsedTextWidth 1.5.0-alpha05 val fieldWidth: Field? = collapsingTextHelper.javaClass.getDeclaredField("collapsedTextWidth") fieldWidth?.isAccessible = true val labelWidth = fieldWidth?.getFloat(collapsingTextHelper)?.toInt() collapsingTextHelper.getCollapsedTextActualBounds(bounds, labelWidth ?: 0, collapsingTextHelper.collapsedTextGravity) // 将 imageView 添加到 TextInputLayout 中 post {//Fix在recycleView里不展示的问题 if (isAttachedToWindow && labelImageView.parent == null) { labelImageView.layoutParams = FrameLayout.LayoutParams(WRAP_CONTENT, WRAP_CONTENT) labelImageView.scaleType = ImageView.ScaleType.CENTER val inputFrame = getChildAt(0) as FrameLayout inputFrame.addView(labelImageView) labelImageView.wrapAccessibilitySize() } } val leftPadding = (8 * resources.displayMetrics.density + 0.5f).toInt() labelImageView.x = bounds.right - leftPadding // 获取imageView的高度 labelImageView.measure(0, 0) labelImageView.y = bounds.top + (bounds.height() - labelImageView.measuredHeight) / 2 } catch (e: Exception) { e.printStackTrace() } }
12-12
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值