Android编程简单实现ImageView点击时背景图修改的方法

时间:2021-05-20

本文实例讲述了Android编程简单实现ImageView点击时背景图修改的方法。分享给大家供大家参考,具体如下:

在使用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"

以上即可完成效果。

记得ImageView要加上加上clickable="true",不然它的selector 是不会有效果。

把下面的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"

希望本文所述对大家Android程序设计有所帮助。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章