Android实习札记(10)---ImageView的src属性 VS blackground属性

Android实习札记(10)---ImageView的src属性 VS blackground属性

                                                                             转载请注明出处:coder-pig



问题分析

相信大家对于ImageView图片组件并不陌生吧,见名知意,就是用来显示图片的咯!

而显示图片的话可以通过src属性,又或者blackground属性来进行设置!

这些大家都知道,但是有没有去纠结下什么情况下用这个,什么情况下用那个呢?

估计很多朋友的回答是"没有",哈哈,那么在本节中就来对这两个属性进行一个讲解吧!



由浅入深,先说下大部分人都知道的:


一.常识

background通常指的都是背景,而src指的是内容!!

②当使用src填入图片时,是按照图片大小直接填充,并不会进行拉伸

   而使用background填入图片,则是会根据ImageView给定的宽度来进行拉伸


多说无益,写个简单布局测试下咯:

main.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/LinearLayout1"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context="com.jay.example.imageviewdemo.MainActivity" >

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:background="@drawable/pen" />

    <ImageView
        android:layout_width="200dp"
        android:layout_height="wrap_content"
        android:background="@drawable/pen" />

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:src="@drawable/pen" />

    <ImageView
        android:layout_width="200dp"
        android:layout_height="wrap_content"
        android:src="@drawable/pen" />

</LinearLayout>

代码很简单,前面两个用blackground,后面两个用src,效果图如下:


分析:

宽高都是wrap_content那就一样,是原图大小,但是,当我们固定了宽或者高的话,

差别就显而易见了,blackground完全填充了整个ImageView,而src依旧是那么大,

而且他居中了哦,这就涉及到了ImageView的另一个属性scaleType了!

另外还有一点,这里我们说了只设置width或者height哦!加入我们同时设置了

width和height的话,blackground依旧填充,但是,src的大小可能发生改变哦!

比如,我们测试下下面这段代码:

<ImageView
        android:layout_width="100dp"
        android:layout_height="50dp"
        android:src="@drawable/pen" />

效果图:



ps:至于ImageView的scaleType这里就不详细进行讲解了,详情可参阅笔者的另一篇博文:

android-UI组件实例大全之ImageView图像视图

另外,这个属性只对src属性生效哦!!切记!!





二.解决blackground拉伸导致图片变形的方法

在前面的效果图中的第二个Imageview中我们可以看到图片已经被拉伸变形了,

正方形变成了长方形,对于和我一样有轻微强迫症的人来说,显然是不可接受的,

有没有办法去设置呢?答案肯定是有的,笔者暂时知道的有以下两种方式:


1)这个适用于动态加载ImageView的,代码也渐渐,只要在添加View的时候,把大小写死就可以了

LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams(48, 48);  
		layout.addView(ibtnPen, layoutParam);  

2)除了动态加载view,更多的时候,我们还是会通过xml布局的方式引入ImageView的

解决方法也不难,就是通过drawable的Bitmap资源文件来完成,然后blackground属性设置为该文件即可!

这个xml文件在drawable文件夹下创建,这个文件夹是要自己创建的哦!!

pen_bg.xml:

    <bitmap
        xmlns:android="http://schemas.android.com/apk/res/android"
        android:id="@id/pen_bg"
        android:gravity="top"
        android:src="@drawable/pen"
        android:tileMode="disabled" >
    </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设置了蓝色背景!

代码如下:

    <ImageView
        android:layout_width="150dp"
        android:layout_height="wrap_content"
        android:src="@drawable/pig"
        android:background="#6699FF" />

另外,你也可以用selctor实现点击效果,设置不同的情况设置不同的图片,以实现点击或者触摸效果!





好了,本节就到这里,如果对本文有什么疑问或者发现什么纰漏,欢迎告知,万分感激!!





郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。