ImageView中src与background的区别
来源:互联网 发布:网站主持人源码 编辑:程序博客网 时间:2024/06/05 09:55
一、ImageView中XML属性src和background的区别:
background会根据ImageView组件给定的长宽进行拉伸,而src就存放的是原图的大小,不会进行拉伸 。src是图片内容(前景),bg是背景,可以同时使用。
此外: scaleType只对src起作用;bg可设置透明度,比如在ImageButton中就可以用android:scaleType控制图片的缩放方式
二、 解决android:background背景图片被拉伸问题 :
如上所述,background设置的图片会跟View组件给定的长宽比例进行拉伸。举个例子, 36x36 px的图标放在 xhdpi 文件夹中,在854x480(FWVGA,对应hdpi)环境下,按照
xhdpi : hdpi : mdpi: ldip = 2 : 1.5 : 1 : 0.75
的比例计算,在FWVGA下,图标的实际大小应该是 27x27。
但是当我把它放到一个 layout_width = 96px, layout_height = 75px 的 LinearLayout,布局代码如下:
[html] view plain copy 在CODE上查看代码片 派生到我的代码片
< LinearLayout android:gravity = "center" android:layout_width = "96px" android:layout_height = "75px" >
< ImageButton android:layout_width = "wrap_content" android:layout_height = "wrap_content" android:background = "@drawable/toolbar_bg" />
</ LinearLayout >
实际情况是,我们得到的ImageButton的大小是 33x27,很明显width被拉伸了,这是我们不想看到的情况。
解决方案一:
代码中动态显式设置ImageButton的layout_width和layout_width,如下
[java] view plain copy 在CODE上查看代码片 派生到我的代码片
LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams( 27 , 27 );
layout.addView(imageButton, layoutParam);
不过,事实上我们并不希望在代码存在“硬编码”的情况。
解决方案二:
在你通过setBackgroundResource()或者在xml设置android:background属性时,将你的background以XML Bitmap的形式定义,如下:
[html] view plain copy 在CODE上查看代码片 派生到我的代码片
<? xml version = "1.0" encoding = "utf-8" ?>
< bitmap xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@id/toolbar_bg_bmp"
android:src = "@drawable/toolbar_bg"
android:tileMode = "disabled" android:gravity = "top" >
</ bitmap >
调用如下:
imageButton.setBackgroundResource(R.drawable.toolbar_bg_bmp)
或者
<ImageButton ... android:background="@drawable/toolbar_bg_bmp" ... />
若背景图片有多种状态,还可参照toolbar_bg_selector.xml:
[html] view plain copy 在CODE上查看代码片 派生到我的代码片
<? xml version = "1.0" encoding = "utf-8" ?>
< selector xmlns:android = "url" >
< item android:state_pressed = "true" >
< bitmap android:src = "@drawable/toolbar_bg_sel" android:tileMode = "disabled" android:gravity = "top" />
</ item >
< item >
< bitmap android:src = "@drawable/toolbar_bg" android:tileMode = "disabled" android:gravity = "top" />
</ item >
</ selector >
background会根据ImageView组件给定的长宽进行拉伸,而src就存放的是原图的大小,不会进行拉伸 。src是图片内容(前景),bg是背景,可以同时使用。
此外: scaleType只对src起作用;bg可设置透明度,比如在ImageButton中就可以用android:scaleType控制图片的缩放方式
二、 解决android:background背景图片被拉伸问题 :
如上所述,background设置的图片会跟View组件给定的长宽比例进行拉伸。举个例子, 36x36 px的图标放在 xhdpi 文件夹中,在854x480(FWVGA,对应hdpi)环境下,按照
xhdpi : hdpi : mdpi: ldip = 2 : 1.5 : 1 : 0.75
的比例计算,在FWVGA下,图标的实际大小应该是 27x27。
但是当我把它放到一个 layout_width = 96px, layout_height = 75px 的 LinearLayout,布局代码如下:
[html] view plain copy 在CODE上查看代码片 派生到我的代码片
< LinearLayout android:gravity = "center" android:layout_width = "96px" android:layout_height = "75px" >
< ImageButton android:layout_width = "wrap_content" android:layout_height = "wrap_content" android:background = "@drawable/toolbar_bg" />
</ LinearLayout >
实际情况是,我们得到的ImageButton的大小是 33x27,很明显width被拉伸了,这是我们不想看到的情况。
解决方案一:
代码中动态显式设置ImageButton的layout_width和layout_width,如下
[java] view plain copy 在CODE上查看代码片 派生到我的代码片
LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams( 27 , 27 );
layout.addView(imageButton, layoutParam);
不过,事实上我们并不希望在代码存在“硬编码”的情况。
解决方案二:
在你通过setBackgroundResource()或者在xml设置android:background属性时,将你的background以XML Bitmap的形式定义,如下:
[html] view plain copy 在CODE上查看代码片 派生到我的代码片
<? xml version = "1.0" encoding = "utf-8" ?>
< bitmap xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@id/toolbar_bg_bmp"
android:src = "@drawable/toolbar_bg"
android:tileMode = "disabled" android:gravity = "top" >
</ bitmap >
调用如下:
imageButton.setBackgroundResource(R.drawable.toolbar_bg_bmp)
或者
<ImageButton ... android:background="@drawable/toolbar_bg_bmp" ... />
若背景图片有多种状态,还可参照toolbar_bg_selector.xml:
[html] view plain copy 在CODE上查看代码片 派生到我的代码片
<? xml version = "1.0" encoding = "utf-8" ?>
< selector xmlns:android = "url" >
< item android:state_pressed = "true" >
< bitmap android:src = "@drawable/toolbar_bg_sel" android:tileMode = "disabled" android:gravity = "top" />
</ item >
< item >
< bitmap android:src = "@drawable/toolbar_bg" android:tileMode = "disabled" android:gravity = "top" />
</ item >
</ selector >
如此,不管是通过代码方式setBackgroundResource()或XML android:background方式设置背景,均不会产生被拉伸的情况。
附:更详细的scaleType说明:
android:scaleType是控制图片如何resized/moved来匹对ImageView的size。
ImageView.ScaleType / android:scaleType值的意义区别:
CENTER /center 按图片的原来size居中显示,当图片长/宽超过View的长/宽,则截取图片的居中部分显示
CENTER_CROP / centerCrop 按比例扩大图片的size居中显示,使得图片长(宽)等于或大于View的长(宽)
CENTER_INSIDE / centerInside 将图片的内容完整居中显示,通过按比例缩小或原来的size使得图片长/宽等于或小于View的长/宽
FIT_CENTER / fitCenter 把图片按比例扩大/缩小到View的宽度,居中显示
FIT_END / fitEnd 把图片按比例扩大/缩小到View的宽度,显示在View的下部分位置
FIT_START / fitStart 把图片按比例扩大/缩小到View的宽度,显示在View的上部分位置
FIT_XY / fitXY 把图片不按比例扩大/缩小到View的大小显示
MATRIX / matrix 用矩阵来绘制,动态缩小放大图片来显示。
0 0
- ImageView中src与background的区别
- ImageView src与background的区别
- imageView src与background区别
- imageView src与background区别
- imageView src与background区别
- ImageView src Background 的区别
- ImageView的background属性与src属性的区别
- ImageView 的 src属性与background的区别
- ImageView的src与background的区别分析
- ImageView的src与background的区别分析
- ImageView中XML属性src和background的区别
- ImageView中src和background属性的主要亮点区别
- ImageView中XML属性src和background的区别
- android:ImageView中XML属性src和background的区别
- ImageView中XML属性src和background的区别
- Android中给ImageView添加background和src的区别
- 【ImageView】android中src和background区别
- ImageView设置background和src的区别
- USB gadget hid
- Android中View绘制流程以及invalidate()等相关方法分析
- linux C语言学习之安装linux系统
- AndroidStudio无法预览布局文件问题的解决
- 李开复给大学生的第1封信:从诚信谈起
- ImageView中src与background的区别
- HDU 5706 GirlCat DFS解决
- hive 内置操作符
- 传输层TCP协议
- 【垂直搜索引擎搭建13】HtmlParser中Visitor实践
- 创建UITableViewCell程序奔溃
- eclipse如何安装genymotion插件,终于安装成功了,终极方案
- 集合框架的讲解--面试常问问题
- linux把标准输出赋值给变量遇到的问题