问题分析
相信大家对于ImageView图片组件并不陌生吧,见名知意,就是用来显示图片的咯!
而显示图片的话可以通过src属性,又或者blackground属性来进行设置!
这些大家都知道,但是有没有去纠结下什么情况下用这个,什么情况下用那个呢?
估计很多朋友的回答是”没有”,哈哈,那么在本节中就来对这两个属性进行一个讲解吧!
由浅入深,先说下大部分人都知道的:
一.常识
①background通常指的都是背景,而src指的是内容!!
②当使用src填入图片时,是按照图片大小直接填充,并不会进行拉伸
而使用background填入图片,则是会根据ImageView给定的宽度来进行拉伸
多说无益,写个简单布局测试下咯:
main.xml:
1 | <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" |
代码很简单,前面两个用blackground,后面两个用src,效果图如下:
分析:
宽高都是wrap_content那就一样,是原图大小,但是,当我们固定了宽或者高的话,
差别就显而易见了,blackground完全填充了整个ImageView,而src依旧是那么大,
而且他居中了哦,这就涉及到了ImageView的另一个属性scaleType了!
另外还有一点,这里我们说了只设置width或者height哦!加入我们同时设置了
width和height的话,blackground依旧填充,但是,src的大小可能发生改变哦!
比如,我们测试下下面这段代码:
1 | <ImageView |
效果图:
ps:至于ImageView的scaleType这里就不详细进行讲解了,详情可参阅笔者的另一篇博文:
android-UI组件实例大全之ImageView图像视图
另外,这个属性只对src属性生效哦!!切记!!
二.解决blackground拉伸导致图片变形的方法
在前面的效果图中的第二个Imageview中我们可以看到图片已经被拉伸变形了,
正方形变成了长方形,对于和我一样有轻微强迫症的人来说,显然是不可接受的,
有没有办法去设置呢?答案肯定是有的,笔者暂时知道的有以下两种方式:
1)这个适用于动态加载ImageView的,代码也渐渐,只要在添加View的时候,把大小写死就可以了
1 | LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams(48, 48); |
2)除了动态加载view,更多的时候,我们还是会通过xml布局的方式引入ImageView的
解决方法也不难,就是通过drawable的Bitmap资源文件来完成,然后blackground属性设置为该文件即可!
这个xml文件在drawable文件夹下创建,这个文件夹是要自己创建的哦!!
pen_bg.xml:
1 | <bitmap |
上述代码并不难理解,估计大家最迷惑的是titleMode属性吧,这个属性是平铺,就是我们windows设置
背景时候的平铺,多个小图标铺满整个屏幕捏!记得了吧!不记得自己可以试试!disabled就是把他给禁止了!
就是上面这串简单的代码,至于调用方法如下:
动态: ibtnPen.setBacklgroundResource(R.drawable.penbg);
静态: android:background = "@drawable/penbg"
三.设置透明度的问题
说完前面两个区别,接着再说下setAlpha属性咯!
这个很简单,这个属性,只有src时才是有效果的!!
!!!! src设置setAlpha()才有效果!!!!!
四.两者结合妙用:
这是网上的一张图:
一看去是一个简单的GridView,每个item都是一个ImageView,但是细心的你可能发现了,
上面的ICON都不是规则的,而是圆形,圆角矩形等等,于是乎这里用到了src + background了!
要实现上述的效果,你只需要两个操作:
找一张透明的png图片 + 设置一个黑色的背景
(当然你也可以设置png的透明度来实现,不过结果可能和预想的有出入哦!)
哈哈,呆萌呆萌的小猪就这样显示到ImageView上了,哈哈,blackground设置了蓝色背景!
代码如下:
1 | <ImageView |
另外,你也可以用selctor实现点击效果,设置不同的情况设置不同的图片,以实现点击或者触摸效果!
五.Java代码中设置blackground和src属性:
前景(对应src属性):setImageDrawable();
背景(对应background属性):setBackgroundDrawable();