博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android中的ListView点击时的背景颜色设置
阅读量:5340 次
发布时间:2019-06-15

本文共 1891 字,大约阅读时间需要 6 分钟。

想设置listview中每行在点击、选中等不同状态下有不同的背景颜色,或者背景图片。 

这可以用Android的Selector来实现。它可以定义组件在不同状态下的显示方式。 

新建一个xml文件list_bg_selector.xml在drawable目录下

[html]
  1.  <?xml version="1.0" encoding="utf-8" ?>  
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">  
  3.     <item android:state_window_focused="false" android:drawable="@drawable/没有焦点时图片背景" />  
  4.     <item android:state_focused="true" android:state_pressed="true"       
  5.         android:drawable="@drawable/非触摸模式下获得焦点并单击时的背景图片" /> <!--双条件-->  
  6.     <item android:state_focused="false" android:state_pressed="true"  
  7.         android:drawable="@drawable/触摸模式下单击时的背景图片" />  
  8.     <item android:state_selected="true" android:drawable="@drawable/选中时的图片背景" />  
  9.     <item android:state_focused="true" android:drawable="@drawable/获得焦点时的图片背景" />  
  10.     <item android:drawable="@drawable/silver" /> <!--default color 当对应状态下没有定义时使用此default -->  
  11. </selector>  

定义item时具体可以选择的条件有:

 

[html]
  1. android:state_pressed=["true" | "false"]  //被点击  
  2. android:state_focused=["true" | "false"]  //获得焦点  
  3. android:state_selected=["true" | "false"] //被选中  
  4. android:state_checkable=["true" | "false"] //可以被check时  
  5. android:state_checked=["true" | "false"]  //被check时,例如用于checkbox  
  6. android:state_enabled=["true" | "false"]  //可用是,即能接收click/touch事件  
  7. android:state_window_focused=["true" | "false"]  //所在的窗口获得焦点  
android:state_pressed=["true" | "false"]  //被点击 android:state_focused=["true" | "false"]  //获得焦点 android:state_selected=["true" | "false"] //被选中 android:state_checkable=["true" | "false"] //可以被check时 android:state_checked=["true" | "false"]  //被check时,例如用于checkbox android:state_enabled=["true" | "false"]  //可用是,即能接收click/touch事件 android:state_window_focused=["true" | "false"]  //所在的窗口获得焦点

然后再listview的layout定义里加上就ok了 

 

[html]
  1. android:background="@drawable/list_bg_selector"  
android:background="@drawable/list_bg_selector"

转载于:https://www.cnblogs.com/navy-wang/p/3195747.html

你可能感兴趣的文章
css3渐变画斜线 demo
查看>>
JS性能DOM优化
查看>>
设计模式 单例模式 使用模板及智能指针
查看>>
HAL层三类函数及其作用
查看>>
Odoo 去掉 恼人的 "上午"和"下午"
查看>>
web@h,c小总结
查看>>
java编程思想笔记(一)——面向对象导论
查看>>
Data Structure 基本概念
查看>>
Ubuntu改坏sudoers后无法使用sudo的解决办法
查看>>
NEYC 2017 游记
查看>>
[搬运] 写给 C# 开发人员的函数式编程
查看>>
Python之旅Day14 JQuery部分
查看>>
core--线程池
查看>>
redux-effect
查看>>
Swift和OC混编
查看>>
Android轻量级的开源缓存框架ASimpleCache
查看>>
他山之石:加载图片的一个小问题
查看>>
shell - 常识
查看>>
mssql sqlserver 使用sql脚本 清空所有数据库表数据的方法分享
查看>>
分层图最短路【bzoj2763】: [JLOI2011]飞行路线
查看>>