`
he91_com
  • 浏览: 400976 次
文章分类
社区版块
存档分类
最新评论

Android ListView 之 SimpleAdapter 二 (包含 item 中按钮监听)

 
阅读更多

1MainActivity.java

package com.myadapter;
import java.util.ArrayList;
import java.util.HashMap;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.Button;
import android.widget.ListView;
import android.widget.SimpleAdapter;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends Activity {
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        
        //声明一个 ListView
        ListView listview = new ListView(this);            
        
        //定义数组  数组内容是 HashMap
        ArrayList<HashMap<String,Object>> list=new ArrayList<HashMap<String,Object>>();
        
        //每一个HashMap 对应ListView 中 每一个 item 的数据
        HashMap<String,Object>map=new HashMap<String, Object>();
        map.put("Image", R.drawable.star);
        map.put("Text1", "周杰伦");
        map.put("Text2", "菊花台");
        map.put("Button", "更多");
        list.add(map);
        
        map=null;
        map=new HashMap<String, Object>();
        map.put("Image", R.drawable.ic_menu_send);
        map.put("Text1", "邓丽君");
        map.put("Text2", "在水一方");
        map.put("Button", "更多");
        list.add(map);
        
        map=null;
        map=new HashMap<String, Object>();
        map.put("Image", R.drawable.star);
        map.put("Text1", "蔡琴");
        map.put("Text2", "恰似你的温柔");
        map.put("Button", "更多");
        list.add(map);
        
        //适配器  绑定数据
        SimpleAdapter adapter=new SimpleAdapter(
                this,                             //上下文
                list,                             //要绑定的数据
                R.layout.item_layout,             //每一个 item 的布局
                new String[]{ "Text1",    "Text2",    "Button",    "Image"},    //HashMap 中的 键名
                new int[]{    R.id.text1,  R.id.text2, R.id.button, R.id.image})//分别对应 item 中控件 id,与上一个参数 的键名一一上下对应
        {
                    //在这个重写的函数里设置 每个 item 中按钮的响应事件
                    @Override
                    public View getView(int position, View convertView,ViewGroup parent) {
                        final int p=position;
                        final View view=super.getView(position, convertView, parent);
                        Button button=(Button)view.findViewById(R.id.button);
                        button.setOnClickListener(new OnClickListener() {
                            
                            @Override
                            public void onClick(View v) {
                                
                                //警告框的写法
                                new AlertDialog.Builder(MainActivity.this)
                                .setTitle("More")
                                .setMessage("你选中了"+String.valueOf(p))
                                .setPositiveButton("确定", new DialogInterface.OnClickListener() {
                                    public void onClick(DialogInterface dialog, int which) {
                                        setTitle("点击了对话框上的确定按钮"); 
                                    }
                                })
                                .setNeutralButton("中立" ,new DialogInterface.OnClickListener() {  
                                    public void onClick(DialogInterface dialog, int whichButton) {  
                                        setTitle("点击了对话框上的中立按钮");  
                                    }  
                                }) 
                                .setNegativeButton("取消", new DialogInterface.OnClickListener() {  
                                    public void onClick(DialogInterface dialog, int whichButton) {  
                                        setTitle("点击了对话框上的取消按钮");  
                                    }  
                                })
                                .create()
                                .show();
                            }
                        });
                        return view;
                    }
        };
        //绑定适配器
        listview.setAdapter(adapter);        
        
        //设置背景颜色选择器
        listview.setSelector(R.drawable.on_item_selected);
        
        //设置焦点响应问题    同时要将 item 中的焦点 focusable 设置为 false
        listview.setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);
        
        //设置 item 的监听事件
        listview.setOnItemClickListener(new OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                
                //获得 item 里面的文本控件
                TextView text1=(TextView)view.findViewById(R.id.text1);
                Toast.makeText(getApplicationContext(), text1.getText().toString(), Toast.LENGTH_SHORT).show();
            }
        });
        
        //设置显示的内容
        setContentView(listview);
    }
}

2ListView 之每一个 item的布局item_layout.xml

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    xmlns:tools="http://schemas.android.com/tools"  
    android:layout_width="match_parent"  
    android:layout_height="45dp"  
    android:orientation="horizontal"  
    tools:ignore="HardcodedText,NestedWeights" >  
    <ImageView  
        android:id="@+id/image"  
        android:layout_width="wrap_content"  
        android:layout_height="match_parent"  
        android:layout_weight="4"  
        android:contentDescription="头像"   
        android:src="@drawable/ic_menu_send"/>  
    <LinearLayout  
        android:layout_width="wrap_content"  
        android:layout_height="match_parent"  
        android:layout_weight="24"  
        android:orientation="vertical" >  
        <TextView   
            android:id="@+id/text1"  
            android:layout_width="match_parent"  
            android:layout_height="wrap_content"  
            android:layout_weight="1"  
            android:textColor="@color/blue"  
            android:text="王力宏"/>  
        <TextView   
            android:id="@+id/text2"  
            android:layout_width="match_parent"  
            android:layout_height="wrap_content"  
            android:textColor="@color/darkviolet"  
            android:layout_weight="1"  
            android:text="大城小爱"/>  
    </LinearLayout>  
    <Button   
        android:id="@+id/button"  
        android:layout_width="wrap_content"  
        android:layout_height="match_parent"  
        android:text="more"  
        android:layout_weight="1"  
        android:textColor="@color/darkorchid"  
        android:focusable="false"/>  
</LinearLayout> 


3ListView 之 item 颜色选择器on_item_selected.xml(放在 drawable 文件夹里)

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    <item   android:state_focused="false"
            android:drawable="@android:color/black"/>
    <item   android:state_focused="true"
            android:drawable="@android:color/darker_gray"/>
</selector>


4资源图片

4.1ic_menu_send.png
4.2star.png

5颜色值 color.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <color name="white">#FFFFFF</color>					<!--白色 -->
    <color name="ivory">#FFFFF0</color>					<!--象牙色 -->
    <color name="lightyellow">#FFFFE0</color>			<!--亮黄色 -->
    <color name="yellow">#FFFF00</color>				<!--黄色 -->
    <color name="snow">#FFFAFA</color>					<!--雪白色 -->
    <color name="floralwhite">#FFFAF0</color>			<!--花白色 -->
    <color name="lemonchiffon">#FFFACD</color>			<!--柠檬绸色 -->
    <color name="cornsilk">#FFF8DC</color>				<!--米绸色 -->
    <color name="seashell">#FFF5EE</color>				<!--海贝色 -->
    <color name="lavenderblush">#FFF0F5</color>			<!--淡紫红 -->
    <color name="papayawhip">#FFEFD5</color>			<!--番木色 -->
    <color name="blanchedalmond">#FFEBCD</color>		<!--白杏色 -->
    <color name="mistyrose">#FFE4E1</color>				<!--浅玫瑰色 -->
    <color name="bisque">#FFE4C4</color>				<!--桔黄色 -->
    <color name="moccasin">#FFE4B5</color>				<!--鹿皮色 -->
    <color name="navajowhite">#FFDEAD</color>			<!--纳瓦白 -->
    <color name="peachpuff">#FFDAB9</color>				<!--桃色 -->
    <color name="gold">#FFD700</color>					<!--金色 -->
    <color name="pink">#FFC0CB</color>					<!--粉红色 -->
    <color name="lightpink">#FFB6C1</color>				<!--亮粉红色 -->
    <color name="orange">#FFA500</color>				<!--橙色 -->
    <color name="lightsalmon">#FFA07A</color>			<!--亮肉色 -->
    <color name="darkorange">#FF8C00</color>			<!--暗桔黄色 -->
    <color name="coral">#FF7F50</color>					<!--珊瑚色 -->
    <color name="hotpink">#FF69B4</color>				<!--热粉红色 -->
    <color name="tomato">#FF6347</color>				<!--西红柿色 -->
    <color name="orangered">#FF4500</color>				<!--红橙色 -->
    <color name="deeppink">#FF1493</color>				<!--深粉红色 -->
    <color name="fuchsia">#FF00FF</color>				<!--紫红色 -->
    <color name="magenta">#FF00FF</color>				<!--红紫色 -->    
    <color name="red">#FF0000</color>					<!--红色 -->
    <color name="oldlace">#FDF5E6</color>				<!--老花色 -->
    <color name="lightgoldenyellow">#FAFAD2</color>		<!--亮金黄色 -->
    <color name="linen">#FAF0E6</color>					<!--亚麻色 -->
    <color name="antiquewhite">#FAEBD7</color>			<!--古董白 -->
    <color name="salmon">#FA8072</color>				<!--鲜肉色 -->
    <color name="ghostwhite">#F8F8FF</color>			<!--幽灵白 -->
    <color name="mintcream">#F5FFFA</color>				<!--薄荷色 -->
    <color name="whitesmoke">#F5F5F5</color>			<!--烟白色 -->
    <color name="beige">#F5F5DC</color>					<!--米色 -->
    <color name="wheat">#F5DEB3</color>					<!--浅黄色 -->
    <color name="sandybrown">#F4A460</color>			<!--沙褐色 -->
    <color name="azure">#F0FFFF</color>					<!--天蓝色 -->
    <color name="honeydew">#F0FFF0</color>				<!--蜜色 -->
    <color name="aliceblue">#F0F8FF</color>				<!--艾利斯兰 -->
    <color name="khaki">#F0E68C</color>					<!--黄褐色 -->
    <color name="lightcoral">#F08080</color>			<!--亮珊瑚色 -->
    <color name="palegoldenrod">#EEE8AA</color>			<!--苍麒麟色 -->
    <color name="violet">#EE82EE</color>				<!--紫罗兰色 -->
    <color name="darksalmon">#E9967A</color>			<!--暗肉色 -->
    <color name="lavender">#E6E6FA</color>				<!--淡紫色 -->
    <color name="lightcyan">#E0FFFF</color>				<!--亮青色 -->
    <color name="burlywood">#DEB887</color>				<!--实木色 -->
    <color name="plum">#DDA0DD</color>					<!--洋李色 -->
    <color name="gainsboro">#DCDCDC</color>				<!--淡灰色 -->
    <color name="crimson">#DC143C</color>				<!--暗深红色 -->
    <color name="palevioletred">#DB7093</color>			<!--苍紫罗兰色-->
    <color name="goldenrod">#DAA520</color>				<!--金麒麟色 -->
    <color name="orchid">#DA70D6</color>				<!--淡紫色 -->
    <color name="thistle">#D8BFD8</color>				<!--蓟色 -->
    <color name="lightgray">#D3D3D3</color>				<!--亮灰色 -->
    <color name="lightgrey">#D3D3D3</color>				<!--亮灰色 -->
    <color name="tan">#D2B48C</color>					<!--茶色 -->
    <color name="chocolate">#D2691E</color>				<!--巧可力色 -->
    <color name="peru">#CD853F</color>					<!--秘鲁色 -->
    <color name="indianred">#CD5C5C</color>				<!--印第安红 -->
    <color name="mediumvioletred">#C71585</color>		<!--中紫罗兰色 -->
    <color name="silver">#C0C0C0</color>				<!--银色 -->
    <color name="darkkhaki">#BDB76B</color>				<!-- 暗黄褐色 -->
    <color name="rosybrown">#BC8F8F</color>				<!--褐玫瑰红-->
    <color name="mediumorchid">#BA55D3</color>			<!--中粉紫色 -->
    <color name="darkgoldenrod">#B8860B</color>			<!--暗金黄色 -->
    <color name="firebrick">#B22222</color>				<!--火砖色 -->
    <color name="powderblue">#B0E0E6</color>			<!--粉蓝色 -->
    <color name="lightsteelblue">#B0C4DE</color>		<!--亮钢兰色 -->
    <color name="paleturquoise">#AFEEEE</color>			<!--苍宝石绿 -->
    <color name="greenyellow">#ADFF2F</color>			<!--黄绿色 -->
    <color name="lightblue">#ADD8E6</color>				<!--亮蓝色 -->
    <color name="darkgray">#A9A9A9</color>				<!--暗灰色 -->
    <color name="darkgrey">#A9A9A9</color>				<!--暗灰色 -->
    <color name="brown">#A52A2A</color>					<!--褐色 -->
    <color name="sienna">#A0522D</color>				<!--赭色 -->
    <color name="darkorchid">#9932CC</color>			<!--暗紫色 -->
    <color name="palegreen">#98FB98</color>				<!--苍绿色 -->
    <color name="darkviolet">#9400D3</color>			<!--暗紫罗兰色 -->
    <color name="mediumpurple">#9370DB</color>			<!--中紫色 -->
    <color name="lightgreen">#90EE90</color>			<!--亮绿色 -->
    <color name="darkseagreen">#8FBC8F</color>			<!--暗海兰色 -->
    <color name="saddlebrown">#8B4513</color>			<!--重褐色 -->
    <color name="darkmagenta">#8B008B</color>			<!--暗洋红 -->
    <color name="darkred">#8B0000</color>				<!--暗红色 -->
    <color name="blueviolet">#8A2BE2</color>			<!--紫罗兰蓝色-->
    <color name="lightskyblue">#87CEFA</color>			<!--亮天蓝色-->
    <color name="skyblue">#87CEEB</color>				<!--天蓝色 -->
    <color name="gray">#808080</color>					<!--灰色 -->
    <color name="grey">#808080</color>					<!--灰色 -->
    <color name="olive">#808000</color>					<!--橄榄色 -->
    <color name="purple">#800080</color>				<!--紫色 -->
    <color name="maroon">#800000</color>				<!--粟色 -->
    <color name="aquamarine">#7FFFD4</color>			<!--碧绿色 -->
    <color name="chartreuse">#7FFF00</color>			<!--黄绿色 -->
    <color name="lawngreen">#7CFC00</color>				<!--草绿色 -->
    <color name="mediumslateblue">#7B68EE</color>		<!--中暗蓝色 -->
    <color name="lightslategray">#778899</color>		<!--亮蓝灰 -->
    <color name="lightslategrey">#778899</color>		<!--亮蓝灰 -->
    <color name="slategray">#708090</color>				<!--灰石色 -->
    <color name="slategrey">#708090</color>				<!--灰石色 -->
    <color name="olivedrab">#6B8E23</color>				<!--深绿褐色 -->
    <color name="slateblue">#6A5ACD</color>				<!--石蓝色 -->
    <color name="dimgray">#696969</color>				<!--暗灰色 -->
    <color name="dimgrey">#696969</color>				<!--暗灰色 -->
    <color name="mediumaquamarine">#66CDAA</color>		<!--中绿色-->
    <color name="cornflowerblue">#6495ED</color>		<!--菊兰色 -->
    <color name="cadetblue">#5F9EA0</color>				<!--军兰色 -->
    <color name="darkolivegreen">#556B2F</color>		<!--暗橄榄绿 -->
    <color name="indigo">#4B0082</color>				<!--靛青色 -->
    <color name="mediumturquoise">#48D1CC</color>		<!--中绿宝石-->
    <color name="darkslateblue">#483D8B</color>			<!--暗灰蓝色 -->
    <color name="steelblue">#4682B4</color>				<!--钢兰色 -->
    <color name="royalblue">#4169E1</color>				<!--皇家蓝 -->
    <color name="turquoise">#40E0D0</color>				<!--青绿色 -->
    <color name="mediumseagreen">#3CB371</color>		<!--中海蓝 -->
    <color name="limegreen">#32CD32</color>				<!--橙绿色 -->
    <color name="darkslategray">#2F4F4F</color>			<!--暗瓦灰色 -->
    <color name="darkslategrey">#2F4F4F</color>			<!--暗瓦灰色 -->
    <color name="seagreen">#2E8B57</color>				<!--海绿色 -->
    <color name="forestgreen">#228B22</color>			<!--森林绿 -->
    <color name="lightseagreen">#20B2AA</color>			<!--亮海蓝色 -->
    <color name="dodgerblue">#1E90FF</color>			<!--闪兰色 -->
    <color name="midnightblue">#191970</color>			<!--中灰兰色 -->
    <color name="aqua">#00FFFF</color>					<!--浅绿色 -->
    <color name="cyan">#00FFFF</color>					<!--青色 -->
    <color name="springgreen">#00FF7F</color>			<!--春绿色 -->
    <color name="lime">#00FF00</color>					<!--酸橙色 -->
    <color name="mediumspringgreen">#00FA9A</color>		<!--中春绿色 -->
    <color name="darkturquoise">#00CED1</color>			<!--暗宝石绿 -->
    <color name="deepskyblue">#00BFFF</color>			<!--深天蓝色 -->
    <color name="darkcyan">#008B8B</color>				<!--暗青色 -->
    <color name="teal">#008080</color>					<!--水鸭色 -->
    <color name="green">#008000</color>					<!--绿色 -->
    <color name="darkgreen">#006400</color>				<!--暗绿色 -->
    <color name="blue">#0000FF</color>					<!--蓝色 -->
    <color name="mediumblue">#0000CD</color>			<!--中兰色 -->
    <color name="darkblue">#00008B</color>				<!--暗蓝色 -->
    <color name="navy">#000080</color>					<!--海军色 -->
    <color name="black">#000000</color>					<!--黑色 -->
</resources>


6结果预览



转载请注明出处!



分享到:
评论

相关推荐

    android SimpleAdapter 中添加按钮响应事件

    要在`SimpleAdapter` 的列表项中添加按钮,我们需要自定义一个布局文件(如 `list_item.xml`),并在其中包含一个或多个按钮组件。例如: ```xml &lt;LinearLayout xmlns:android=...

    androidの多种风格listview不同案例积累使用

    在Android开发中,ListView是一个非常重要的视图组件,它允许开发者在一个垂直滚动的列表中展示大量数据。本教程将深入探讨“androidの多种风格listview不同案例积累使用”,旨在帮助开发者掌握ListView的各种使用...

    Android listView学习源码.zip源码资源下载

    在Android开发中,熟练掌握ListView的使用对于构建用户界面至关重要。本资源"Android listView学习源码.zip"提供了关于ListView实现的详细示例,帮助开发者深入理解其工作原理和优化技巧。 1. **ListView基本使用**...

    ListView实现分组显示item上下和长按拖拽移动和添加和删除功能

    在Android开发中,ListView是一种常用的控件,用于展示大量数据并提供良好的滚动性能。本教程将详细介绍如何在ListView中实现分组显示、item上下拖拽移动、长按拖拽以及添加和删除功能。 首先,我们需要了解...

    Android之自定义Adapter的ListView

    在Android开发中,ListView是一个非常重要的组件,它允许开发者展示大量的数据,并且可以通过滚动的方式进行浏览。然而,仅仅使用Android API提供的预定义适配器,如ArrayAdapter、SimpleAdapter和...

    Android ListView常见

    - **自定义Item布局**:通过设置Adapter的`getView()`方法,可以自由定制列表项的外观和交互,包括添加图片、按钮等组件。 - **自定义滚动效果**:可以重写`onScroll()`和`onScrollStateChanged()`方法来自定义...

    ListView批量删除demo

    在Android开发中,ListView是一种常用的组件,用于展示可滚动的列表数据。在许多应用场景中,如邮件管理、联系人列表等,用户可能需要对列表中的多个项目进行批量操作,例如批量删除。本教程将深入讲解如何实现...

    ListView_Android

    在Android应用开发中,ListView是显示大量数据列表的常用组件,尤其适用于展示具有多项内容的长列表。ListView的高效性能和可滚动性使得它成为处理动态数据的理想选择。本篇文章将深入探讨如何在Android中实现...

    ListView的基本显示

    ListView是Android平台中一个常用的控件,用于展示大量数据列表,是用户界面设计中的核心组件。对于初学者来说,理解并掌握ListView的基本显示至关重要。在本文中,我们将深入探讨ListView的使用方法,包括其基本...

    listview单选实现

    ListView是Android平台中一个常用的控件,用于展示大量的数据列表。在某些应用场景中,我们可能需要实现ListView的单选功能,即用户只能选择一个条目,每次点击其他条目时,之前的选择会被取消。本篇文章将详细介绍...

    android中进行布局管理界面

    描述中提到了一个具体的例子:“用户信息1 删除 更新”,这表明我们正在构建一个展示用户信息的列表,每个列表项包括用户的基本信息以及两个操作按钮:删除和更新。这种设计通常适用于需要对数据进行增删改查的应用...

    支持多选和全选的listview

    在Android开发中,ListView是一种常用的视图组件,用于展示数据列表。当用户需要对列表中的多项数据进行操作,如批量删除、标记等,就需要实现多选和全选功能。本项目"支持多选和全选的listview"提供了一种简单易用...

    Android UI学习.doc

    在Android开发中,UI设计是至关重要的一环,而ListView作为常用的数据展示组件,其学习和理解对于提升用户体验具有重大意义。本篇文章将深入探讨Android中的ListView及其相关知识点。 首先,ListActivity是Android ...

    ListView学习实例

    在Android开发中,ListView是一个非常重要的组件,常用于展示大量数据列表。本教程将通过一个具体实例深入探讨ListView的使用,包括如何定义ListView、填充数据以及处理点击事件。以下是详细的知识点讲解: 1. **...

    listview总结

    ListView是Android开发中的一个重要组件,用于以列表形式展示内容,可自适应数据长度,提供良好的滚动性能和用户交互体验。ListView的核心在于它与数据和视图的适配,通过适配器(Adapter)将数据映射到ListView的...

    实验四 ListView的使用

    在Android开发中,ListView是用于显示大量数据列表的一个核心组件,尤其适用于展示可滚动的、行式的项目集合。本实验的焦点在于学习如何有效地利用ListView来呈现数据,并提供交互功能。我们将探讨以下几个关键知识...

    自定义LISTVIEW

    在Android开发中,ListView是一种非常常见且重要的组件,它用于展示大量的数据集合,通常用于创建如联系人列表、消息列表等界面。自定义ListView能够帮助开发者实现更丰富的交互效果和更个性化的显示样式,提高用户...

    listview带可全选全不选删除checkbox

    在Android开发中,ListView是一种常用的UI组件,用于展示大量数据列表。它允许用户滚动查看信息,同时提供了多种自定义选项来增强用户体验。本教程将详细讲解如何在ListView中实现带可全选、全不选以及删除功能的复...

    ListView的扩展示例

    ListView是Android开发中常用的一种控件,主要用于展示大量数据列表,它可以高效地处理大量数据,并且支持多种样式的展示方式,如单行、多行、带图片等。在这个"ListView的扩展示例"中,我们将深入探讨如何使用...

    ListView效果

    1. **列表项布局(Item Layout)**:你可以通过XML文件设计每个列表项的布局,包含文字、图片、按钮等各种元素。例如,可以创建一个包含头像、姓名和描述的列表项布局。 2. **ViewHolder模式**:为提高性能,推荐...

Global site tag (gtag.js) - Google Analytics