ImageView点击时背景图修改(简单方法)

迷途d书童 发布于 2012/03/30 14:07
阅读 2K+
收藏 0

    在使用ImageView时,当被点击时,希望背景图修改一下,这样显示被点击效果明显一些。在这里,一个很简单的方法,最起码是个很清晰的方法。在res/drawable文件夹下创建一个xml文件。比如my.xml,内容如下:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true"
        android:drawable="@*android:drawable/btn_search_dialog_voice_pressed" />
    <item android:state_pressed="false"
        android:drawable="@*android:drawable/btn_search_dialog_voice_default" />
</selector>

这里面要注意一点,就是在上面的drawable是引用的系统的图片资源,如果是使用自己的图片资源,要使用如下格式

android:drawable="@drawable/ic_desk_point_normal"

然后,在定义imageView的xml文件里面设置:

android:src="@drawable/youPicture"
android:background="@drawable/my"

以上即可完成效果。

把下面的XML保存成.xml文件(比如list_item_bg.xml),运行时系统会根据ListView中列表项的状态来使用相应的背景图片。

drawable/list_item_bg.xml

<?xml version="1.0" encoding="utf-8" ?>   
<selector xmlns:android="http://schemas.android.com/apk/res/android">
  <!-- 默认时的背景图片 -->  
  <item android:drawable="@drawable/pic1" />
 
  <!-- 没有焦点时的背景图片 -->  
  <item android:state_window_focused="false" 
        android:drawable="@drawable/pic1" />   
 
  <!-- 非触摸模式下获得焦点并单击时的背景图片 -->  
  <item android:state_focused="true" android:state_pressed="true"   
        android:drawable= "@drawable/pic2" />  
 
  <!-- 触摸模式下单击时的背景图片 -->  
  <item android:state_focused="false" android:state_pressed="true"   
        android:drawable="@drawable/pic3" />   
 
  <!--选中时的图片背景  -->  
  <item android:state_selected="true"   
        android:drawable="@drawable/pic4" />   
 
  <!--获得焦点时的图片背景  -->  
  <item android:state_focused="true"   
        android:drawable="@drawable/pic5" />   
</selector>


使用方法

  • 第一种是在listview中配置android:listSelector=”@drawable/list_item_bg”
  • 第二种是在listview的item中添加属性android:background=”@drawable/list_item_bg”
  • 第三种是java代码中使用:
    Drawable drawable = getResources().getDrawable(R.drawable.list_item_bg);
    listview.setSelector(drawable);

注:列表有时候为黑的情况,需要加上下面的代码使其透明:

android:cacheColorHint="@android:color/transparent"


原文链接:http://blog.csdn.net/aomandeshangxiao/article/details/6759576
加载中
返回顶部
顶部