您的位置:首页 > 移动开发 > Android开发

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

2016-01-12 00:22 489 查看
Android实习札记(10)---ImageView的src属性 VS blackground属性

                                                                             转载请注明出处:coder-pig

问题分析

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

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

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

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

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

一.常识

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

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

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

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

main.xml:

[html] view
plaincopyprint?





<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的大小可能发生改变哦!

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

[html] view
plaincopyprint?





<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的时候,把大小写死就可以了

[java] view
plaincopyprint?





LinearLayout.LayoutParams layoutParam = new LinearLayout.LayoutParams(48, 48);    

        layout.addView(ibtnPen, layoutParam);    

2)除了动态加载view,更多的时候,我们还是会通过xml布局的方式引入ImageView的
解决方法也不难,就是通过drawable的Bitmap资源文件来完成,然后blackground属性设置为该文件即可!

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

pen_bg.xml:

[html] view
plaincopyprint?





<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设置了蓝色背景!

代码如下:

[html] view
plaincopyprint?





<ImageView  

    android:layout_width="150dp"  

    android:layout_height="wrap_content"  

    android:src="@drawable/pig"  

    android:background="#6699FF" />  

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

五.Java代码中设置blackground和src属性:

前景(对应src属性):setImageDrawable( );

背景(对应background属性):setBackgroundDrawable( );

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

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: