前段时间为了实现根据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. easyui datagrid 列的内容超出所定义的列宽时,自动换行

    定义表单  nowrap="false"可以使得列中的内容超出所定义的列宽是就会自动换行pagination : true, // 当true时在DataGrid底部显示一个分页工 ...

  2. intent传对象

    intent还有一个很好用的地方,就是传输对象,但要注意的是这里的传输只是将对象复制了一份通过intent进行传递,并不能达到实时更新的效果,也就是这个对象等偏重于“读”.intent对这个对象有着严 ...

  3. 关于Apple Pay,一篇让你不看就会后悔的文章

    编者按:本文作者康上明学为“小米生活”产品经理,在苹果Apple Pay发布后,他对该产品做了深入研究,带来这篇文章. 对于 Apple Pay ,我有几个疑问: 线下支付是一个庞大复杂的流程,当中涉 ...

  4. Unix/Linux环境C编程入门教程(10) SUSE Linux EnterpriseCCPP开发环境搭建

    安装SUSE企业版以及搭建C/C++开发环境 1.      SUSELinux Enterprise是一款服务器操作系统,异常稳定. 2.设置虚拟机类型. 3.选择稍后安装操作系统. 4.选择SUS ...

  5. 深入Blocks分析

    1.简介 从iOS4开始,苹果引入了这个C语言的扩充功能"Blocks",在一些特定的场景下也是一把利刃.我前面一篇博客中初步介绍了Blocks这个东西,主要是语法的介绍(< ...

  6. [LeetCode][Python]17: Letter Combinations of a Phone Number

    # -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 17: Letter Combinations of a Phone Numb ...

  7. html基础标签-2-textarea文本域

    textarea文本域 <!doctype html> <html lang='zh-cn'> <head> <meta charset='utf-8'> ...

  8. Ghost Button制作教程及设计趋势分析

    概述:Ghost Button(虚拟按钮)是网页设计中一个非常实用的按钮样式,特别是图片背景中,有出色的效果.今天我们一起来研究Ghost Button的各种效果的制作方法,并对Ghost Butto ...

  9. CheckBox只选择一项

    最近做一个问卷的页面,客户那边说要使用checkbox而且只能选择一项 就写了下面的代码 <html xmlns="http://www.w3.org/1999/xhtml" ...

  10. Spring MVC 完整示例

    在本例中,我们将使用Spring MVC框架构建一个入门级web应用程序.Spring MVC 是Spring框架最重要的的模块之一.它以强大的Spring IoC容器为基础,并充分利用容器的特性来简 ...