前段时间为了实现根据item不同的内容实现不同的背景色google了好久只找到了个隔行换色,通过自定义SimpleAdapter终于实现了此功能,但是定义了selector并没有触发点击效果。今天重新想了一遍终于把这个问题解决了。在自定义的getView里就给每个convertView定义它的背景色和selector。

[代码]自定义SimpleAdapter     

01 public class MySimpleAdapter extends BaseAdapter {
02     private LayoutInflater mInflater;
03  
04     private List<HashMap<String, Object>> dataList;
05  
06     public MySimpleAdapter(Context context, List<HashMap<String, Object>> data) {
07         mInflater = LayoutInflater.from(context);
08         this.dataList = data;
09     }
10  
11     @Override
12     public int getCount() {
13         return dataList.size();
14     }
15  
16     @Override
17     public Object getItem(int position) {
18         return position;
19     }
20  
21     @Override
22     public long getItemId(int position) {
23         return position;
24     }
25  
26     @Override
27     public View getView(int position, View convertView, ViewGroup parent) {
28         ViewHolder holder;
29         if (convertView == null) {
30             convertView = mInflater.inflate(R.layout.color_list_item, null);
31             holder = new ViewHolder();
32             holder.blue = (TextView)convertView.findViewById(R.id.blue_item);
33             holder.red = (TextView)convertView.findViewById(R.id.red_item);
34             holder.green = (TextView)convertView.findViewById(R.id.green_item);
35             holder.yellow = (TextView)convertView.findViewById(R.id.yellow_item);
36  
37             convertView.setTag(holder);
38  
39         else {
40             holder = (ViewHolder)convertView.getTag();
41  
42         }
43         holder.blue.setText((CharSequence)dataList.get(position).get("blue"));
44         holder.red.setText((CharSequence)dataList.get(position).get("red"));
45         holder.green.setText((CharSequence)dataList.get(position).get("green"));
46         holder.yellow.setText((CharSequence)dataList.get(position).get("yellow"));
47         if ("blue".equals(dataList.get(position).get("status").toString())) {
48             convertView.setBackgroundResource(R.drawable.item_chang_blue);
49         else if ("red".equals(dataList.get(position).get("status").toString())) {
50             convertView.setBackgroundResource(R.drawable.item_chang_red);
51         else if ("green".equals(dataList.get(position).get("status").toString())) {
52             convertView.setBackgroundResource(R.drawable.flightinfo_item_chang_green);
53         else if ("yellow".equals(dataList.get(position).get("status").toString())) {
54             convertView.setBackgroundResource(R.drawable.flightinfo_item_chang_yellow);
55         }
56         return convertView;
57     }
58  
59     @Override
60     public void notifyDataSetChanged() {
61         super.notifyDataSetChanged();
62     }
63  
64     class ViewHolder {
65         TextView blue;
66         TextView red;
67         TextView green;
68         TextView yellow;
69     }
70      
71 }

2. [代码]选择器item_chang_blue.xml 其他同理     

01 <?xml version="1.0" encoding="utf-8"?>
02 <selector
03   xmlns:android="http://schemas.android.com/apk/res/android">
04      
05 <!-- 非触摸模式下获得焦点并单击时的背景图片 --> 
06  <item
07     android:state_focused="true"
08     android:state_pressed="true"
09  android:drawable= "@drawable/list_item_pressed"/>  
10 <!-- 触摸模式下单击时的背景图片 -->
11    
12   <item 
13  android:state_focused="false" 
14     android:state_pressed="true"   
15     android:drawable="@drawable/list_item_pressed" /> 
16  
17  
18 <!--选中时的图片背景  --> 
19  <item
20  android:state_selected="true"
21     android:drawable="@drawable/list_item_pressed"/> 
22 <!--获得焦点时的图片背景  --> 
23  <item
24     android:state_focused="true"
25     android:drawable="@drawable/list_item_pressed"/>
26     <!--默认背景  -->  ​
27     <item android:drawable="@drawable/status_blue" />
28 </selector>
29 ​​

BaseAdapter使listview设置不同背景图片并添加selector的更多相关文章

  1. 设置JFrame背景图片

    这里我就放上改写的代码吧,不做多的解释,推荐一个好的博文 https://blog.csdn.net/jdsjlzx/article/details/16831815 public void ini_ ...

  2. 设置按钮背景图片(HTML-CSS)

    很多人提交表单时都喜欢用一个图片来作为提交按钮,大多数人可能用JS去操作表单的提交,即当用户点击这个图片时响应一个JS来提交表单.其实还有一种方法,就是直接设置SUBMIT按钮的图片背景.设置它的图片 ...

  3. MFC 设置窗口背景图片

    //在Onpaint函数中加入如下代码 //----------给窗口设置背景图片---------------------------- CPaintDC dc(this); CRect myrec ...

  4. IOS 在IOS6中设置navigationBar背景图片 会有一条 黑色阴影 --- 解决方案

    //给navigationBar设置背景图片 if ([self.navigationController.navigationBar respondsToSelector:@selector(set ...

  5. 设置VS2017背景图片

    设置方法很简单:安装扩展ClaudiaIDE 1.在这里下载扩展,https://visualstudiogallery.msdn.microsoft.com/9ba50f8d-f30c-4e33-a ...

  6. C++ 设置透明背景图片

    背景:            有两个图片,一个是目标背景图片, 一个是带有自身背景色彩的彩色图片            先将这彩色图片绘制到目标背景图片中, 这一步通过BITBLT就可实现.   但实 ...

  7. 使用css设置边框背景图片

    使用css的特有属性,给不同的盒子添加边框图片. 为什么会有这一场景呢.因为,UI给我们前端的边框图片可能未必适合我们当前的内容. 这里我们主要使用到的属性有: border-image-source ...

  8. iOS设置截图背景图片透明

    /** 设置图片背景为透明 */- (UIImage *)imageToTransparent { // 分配内存 const int imageWidth = self.size.width; co ...

  9. 设置VS2015背景图片(转载)

    设置方法很简单:安装扩展ClaudiaIDE 1.在这里下载扩展,https://visualstudiogallery.msdn.microsoft.com/9ba50f8d-f30c-4e33-a ...

随机推荐

  1. CSS3 Gradient-CSS3渐变

    CSS3 Gradient分为linear-gradient(线性渐变)和radial-gradient(径向渐变).而我们今天主要是针对线性渐变来剖析其具体的用法.为了更好的应用CSS3 Gradi ...

  2. [原创]浅谈如何使用gcc开发NT核心驱动程序

    原文链接:[原创]浅谈如何使用gcc开发NT核心驱动程序 一谈到在 Win NT 下开发核心驱动程序,可能不少人首先都会想到微软“正统”的VC来.诚然,用VC 配合 WINDDK 的确工作的不错,但或 ...

  3. Sql优化(三) 关于oracle的并发

    Oracle的并发技术可以将一个大任务分解为多个小任务由多个进程共同完成.合理地使用并发可以充分利用系统资源,提高效率.一. 并发的种类Parallel queryParallel DML(PDML) ...

  4. onActivityResult不起作用?可能是和你的launchMode有关!

    昨天在自己的项目中用到了onActivityResult()方法获得activity的返回值.我从Activity01通过 startActivityForResult启动了Activity02和Ac ...

  5. shell学习笔记

    shell学习笔记 .查看/etc/shells,看看有几个可用的Shell . 曾经用过的命令存在.bash_history中,但是~/.bash_history记录的是前一次登录前记录的所有指令, ...

  6. frameset常用属性

    框架是网页画面分成几个框窗(不同的窗口对应不同页面以几个网页的形式显示),同时取得多个 src的地址.页面所有框架标记需要放在一个总起的 html 档,这个档案只记录了该框架如何分割 ,不会显示任何资 ...

  7. Android @+id与@id的区别

      Android中的组件需要用一个int类型的值来表示,这个值也就是组件标签中的id属性值.id属性只能接受资源类型的值,也就是必须以@开头的值,例如,@id/abc.@+id/xyz等. 如果在@ ...

  8. ios开发之再谈设计模式

    子曰:设计模式这东西,没有好坏之分,只有合适于不合适 天去面试很有意思,技术考官指着最后一道二选一的编程题说,这是昨天晚上专门为你新加的.当时我听后倍感惭愧. 虽然当时在纸上把大概思路和设计说了下.为 ...

  9. javascript中数组排序

    在javascript中Array类中提供了一个可以为数组排序的方法Array.sort(): 但此方法排序方式是按照unicode码进行的排序,若将整数型加入到数组元素中, 排出的结果往往达不到我们 ...

  10. android入门——Activity(1)

    结构图 mainfests文件夹下面有一个AndroidMainfest.xml文件,类似web开发中的web.xml文件负责整个项目的配置,每当我们新建一个activity,都要在这个文件中进行配置 ...