一、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。布局代码例如以下:
plaincopy
- <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,例如以下
plaincopy
- LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams(27, 27);
- layout.addView(imageButton, layoutParam);
只是,其实我们并不希望在代码存在“硬编码”的情况。
解决方式二:
在你通过setBackgroundResource()或者在xml设置android:background属性时,将你的background以XML Bitmap的形式定义,例如以下:
plaincopy
- <?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:
plaincopy
- <?
xml version="1.0" encoding="utf-8"?
>
- <selector xmlns:android="http://schemas.android.com/apk/res/android" >
- <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方式设置背景,均不会产生被拉伸的情况。
在Android上有非常多不规则button。如:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvaG93bGFh/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="" style="border:none; max-width:100%">
这个时候。我们假设想做成不规则button的话,第一步就是搞一张边缘透明的png图片,然后用src指定到他,这个时候我们会发现,还没有达到要的效果,还有图片周围还是有一层渲染。
此时还要搞第二步:须要对ImageButton设置背景属性android:background="#00000000",就实现了不规则button的效果了。如图:
有朋友可能会说,直接用background指定该图片就ok啦, 但是,假设用background指定,会使图片填充整个imageButton.比方imageButton长宽200。而图片长款仅仅有50。那么图片就会被拉伸4倍变模糊。而我们要达到的效果不是为了填充。
像上面锤子图标一样。
*间一部分就OK了。
參考:http://blog.csdn.net/oathevil/article/details/23707359
http://blog.csdn.net/howlaa/article/details/38660593
版权声明:本文博主原创文章,博客,未经同意不得转载。