`

Android之自定义Adapter的ListView

阅读更多

   在开发中,我们经常使用到ListView这个控件。Android的API也提供了许多创建ListView适配器的快捷方式。例如ArrayAdapter、SimpleAdapter和SimpleCursorAdapter等。但你是否发现,如果采用这些系统自带的适配器,对于事件的响应只能局限在一个行单位。假设一行里面有一个按钮和一个图片控件,它们之间的响应操作是不一样的。若采用系统自带的适配器,就不能精确到每个控件的响应事件。这时,我们一般采取自定义适配器来实现这个比较精确地请求。

       ListView的创建,一般要具备两大元素:

       1)数据集,即要映射的字符串、图片信息之类。

       2)适配器,实现把要映射的字符串、图片信息映射成视图(如Textview、Image等组件),再添加到ListView中。

       下面是一个实操例子:

       实现细节:

       1、创建数据集,一般定义如下

        private List<Map<String, Object>> listItems;

        元素添加方式:

        Map<String, Object> map = new HashMap<String, Object>(); 
        map.put("image", imgeIDs[i]);          //图片资源
        map.put("title", "物品名称:");           //物品标题
        map.put("info", goodsNames[i]);      //物品名称
        map.put("detail", goodsDetails[i]);   //物品详情
        listItems.add(map);                         //添加一项

        2、创建适配器

        public class ListViewAdapter extends BaseAdapter{........}  //自定义的适配器一般继承BaseAdapter类

        listViewAdapter = new ListViewAdapter(this, listItems);

        3、给ListView设置适配器

        listView.setAdapter(listViewAdapter);

        4、这里还有个关键点,如何把list_item.xml布局作为一个视图,添加到listView中:

        LayoutInflater listContainer;   //视图容器工厂

        listContainer = LayoutInflater.from(context); //创建视图容器工厂并设置上下文

        convertView = listContainer.inflate(R.layout.list_item, null);   //创建list_item.xml布局文件的视图

       

        实例视图如下:



 

 

 

 

<?xml version="1.0" encoding="utf-8"?>   
 <LinearLayout xmlns:Android="http://schemas.android.com/apk/res/android"   
    Android:orientation="vertical"   
    Android:layout_width="fill_parent"   
    Android:layout_height="fill_parent">   
        
    <!-- 结算 -->   
    <LinearLayout Android:gravity="center_horizontal"   
    Android:orientation="horizontal" android:layout_width="fill_parent"   
    Android:layout_height="wrap_content">   
    <TextView Android:text="结算: "   
        Android:layout_width="wrap_content"   
        Android:layout_height="wrap_content"     
        Android:textColor="#FFFFFFFF"     
        Android:textSize="20px"/>   
    <ImageButton Android:id="@+id/imgbt_sum"     
        Android:layout_width="40px"   
        Android:layout_height="40px"   
        Android:background = "@drawable/shopping" />   
    </LinearLayout>   
        
    <TextView Android:text="商品列表: "   
        Android:layout_width="wrap_content"   
        Android:layout_height="wrap_content"     
        Android:textColor="#FFFFFFFF" />   
            
    <!-- 商品列表 -->     
    <ListView Android:id="@+id/list_goods"     
        Android:layout_width="fill_parent"   
        Android:layout_height="wrap_content" />   
            
 </LinearLayout>   

 

<?xml version="1.0" encoding="utf-8"?>   
 <LinearLayout xmlns:Android="http://schemas.android.com/apk/res/android"   
    Android:orientation="horizontal" android:layout_width="fill_parent"   
    Android:layout_height="fill_parent">   
   
    <!-- 商品图片 -->   
    <ImageView Android:id="@+id/imageItem"     
        Android:layout_width="wrap_content"   
        Android:layout_height="wrap_content"     
        Android:layout_margin="5px"/>   
        
    <!-- 商品信息 -->   
    <LinearLayout Android:orientation="vertical"   
        Android:layout_width="wrap_content"     
        Android:layout_height="wrap_content">   
   
        <TextView Android:id="@+id/titleItem"     
            Android:layout_width="wrap_content"   
            Android:layout_height="wrap_content"     
            Android:textColor="#FFFFFFFF"   
            Android:textSize="13px" />   
        <TextView Android:id="@+id/infoItem"     
            Android:layout_width="wrap_content"   
            Android:layout_height="wrap_content"     
            Android:textColor="#FFFFFFFF"   
            Android:textSize="22px" />   
    </LinearLayout>   
        
    <!-- 购买和商品详情 -->   
    <LinearLayout Android:gravity="right"   
    Android:orientation="horizontal" android:layout_width="fill_parent"   
    Android:layout_height="wrap_content">   
    <CheckBox Android:id="@+id/checkItem"     
        Android:layout_width="wrap_content"   
        Android:layout_height="wrap_content"     
        Android:layout_margin="5px"/>   
    <Button  Android:id="@+id/detailItem"     
        Android:layout_width="wrap_content"   
        Android:layout_height="wrap_content"     
        Android:layout_margin="5px"/>   
    </LinearLayout>   
 </LinearLayout>   

 

package com.myAndroid.test;    
   
 import java.util.ArrayList;    
 import java.util.HashMap;    
import java.util.List;    
import java.util.Map;    
   
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.widget.ArrayAdapter;    
import Android.widget.ImageButton;    
import Android.widget.ListView;    
   
public class MyListView extends Activity {    
        
    private ListView listView;    
    private ImageButton imgbt_sum;    
    private ListViewAdapter listViewAdapter;    
    private List<Map<String, Object>> listItems;    
    private Integer[] imgeIDs = {R.drawable.cake,     
            R.drawable.gift, R.drawable.letter,    
            R.drawable.love, R.drawable.mouse,    
            R.drawable.music};    
    private String[] goodsNames = {"蛋糕", "礼物",     
            "邮票", "爱心", "鼠标", "音乐CD"};    
    private String[] goodsDetails = {    
            "蛋糕:好好吃。",     
            "礼物:礼轻情重。",     
            "邮票:环游世界。",     
            "爱心:世界都有爱。",    
            "鼠标:反应敏捷。",    
            "音乐CD:酷我音乐。"};    
        
    /** Called when the activity is first created. */   
    @Override   
    public void onCreate(Bundle savedInstanceState) {    
        super.onCreate(savedInstanceState);    
        setContentView(R.layout.main);    
            
        listView = (ListView)findViewById(R.id.list_goods);     
        imgbt_sum = (ImageButton) findViewById(R.id.imgbt_sum);    
        imgbt_sum.setOnClickListener(new ClickEvent());    
        listItems = getListItems();    
        listViewAdapter = new ListViewAdapter(this, listItems); //创建适配器    
        listView.setAdapter(listViewAdapter);    
    }    
        
    /**   
     * 初始化商品信息   
     */   
    private List<Map<String, Object>> getListItems() {    
        List<Map<String, Object>> listItems = new ArrayList<Map<String, Object>>();    
        for(int i = 0; i < goodsNames.length; i++) {    
            Map<String, Object> map = new HashMap<String, Object>();     
            map.put("image", imgeIDs[i]);               //图片资源    
            map.put("title", "物品名称:");              //物品标题    
            map.put("info", goodsNames[i]);     //物品名称    
            map.put("detail", goodsDetails[i]); //物品详情    
            listItems.add(map);    
        }       
        return listItems;    
    }    
        
    class ClickEvent implements OnClickListener{    
   
        @Override   
        public void onClick(View v) {    
            // TODO Auto-generated method stub    
            String goodsList = "";    
            for(int i = 0; i < listItems.size(); i++) {    
                goodsList += listViewAdapter.hasChecked(i)? goodsNames[i] + "  ": "";    
            }    
            new AlertDialog.Builder(MyListView.this)    
            .setTitle("购物清单:")    
            .setMessage("你好,你选择了如下商品:\n" + goodsList)    
            .setPositiveButton("确定", null)    
            .show();    
        }    
            
    }    
}    

 

   
 
package com.myAndroid.test;    
   
 import java.util.List;    
import java.util.Map;    
   
import Android.app.AlertDialog;    
import Android.content.Context;    
import Android.util.Log;    
import Android.view.LayoutInflater;    
import Android.view.View;    
import Android.view.ViewGroup;    
import Android.widget.BaseAdapter;    
import Android.widget.Button;    
import Android.widget.CheckBox;    
import Android.widget.CompoundButton;    
import Android.widget.ImageView;    
import Android.widget.ListView;    
import Android.widget.TextView;    
   
public class ListViewAdapter extends BaseAdapter {    
    private Context context;                        //运行上下文    
    private List<Map<String, Object>> listItems;    //商品信息集合    
    private LayoutInflater listContainer;           //视图容器    
    private boolean[] hasChecked;                   //记录商品选中状态    
    public final class ListItemView{                //自定义控件集合      
            public ImageView image;      
            public TextView title;      
            public TextView info;    
            public CheckBox check;    
            public Button detail;           
     }      
        
        
    public ListViewAdapter(Context context, List<Map<String, Object>> listItems) {    
        this.context = context;             
        listContainer = LayoutInflater.from(context);   //创建视图容器并设置上下文    
        this.listItems = listItems;    
        hasChecked = new boolean[getCount()];    
    }    
   
    public int getCount() {    
        // TODO Auto-generated method stub    
        return listItems.size();    
    }    
   
    public Object getItem(int arg0) {    
        // TODO Auto-generated method stub    
        return null;    
    }    
   
    public long getItemId(int arg0) {    
        // TODO Auto-generated method stub    
        return 0;    
    }    
        
    /**   
     * 记录勾选了哪个物品   
     * @param checkedID 选中的物品序号   
     */   
    private void checkedChange(int checkedID) {    
        hasChecked[checkedID] = !hasChecked[checkedID];    
    }    
        
    /**   
     * 判断物品是否选择   
     * @param checkedID 物品序号   
     * @return 返回是否选中状态   
     */   
    public boolean hasChecked(int checkedID) {    
        return hasChecked[checkedID];    
    }    
        
    /**   
     * 显示物品详情   
     * @param clickID   
     */   
    private void showDetailInfo(int clickID) {    
        new AlertDialog.Builder(context)    
        .setTitle("物品详情:" + listItems.get(clickID).get("info"))    
        .setMessage(listItems.get(clickID).get("detail").toString())                  
        .setPositiveButton("确定", null)    
        .show();    
    }    
        
           
    /**   
     * ListView Item设置   
     */   
    public View getView(int position, View convertView, ViewGroup parent) {    
        // TODO Auto-generated method stub    
        Log.e("method", "getView");    
        final int selectID = position;    
        //自定义视图    
        ListItemView  listItemView = null;    
        if (convertView == null) {    
            listItemView = new ListItemView();     
            //获取list_item布局文件的视图    
            convertView = listContainer.inflate(R.layout.list_item, null);    
            //获取控件对象    
            listItemView.image = (ImageView)convertView.findViewById(R.id.imageItem);    
            listItemView.title = (TextView)convertView.findViewById(R.id.titleItem);    
            listItemView.info = (TextView)convertView.findViewById(R.id.infoItem);    
            listItemView.detail= (Button)convertView.findViewById(R.id.detailItem);    
            listItemView.check = (CheckBox)convertView.findViewById(R.id.checkItem);    
            //设置控件集到convertView    
            convertView.setTag(listItemView);    
        }else {    
            listItemView = (ListItemView)convertView.getTag();    
        }    
//      Log.e("image", (String) listItems.get(position).get("title"));  //测试    
//      Log.e("image", (String) listItems.get(position).get("info"));    
            
        //设置文字和图片    
        listItemView.image.setBackgroundResource((Integer) listItems.get(    
                position).get("image"));    
        listItemView.title.setText((String) listItems.get(position)    
                .get("title"));    
        listItemView.info.setText((String) listItems.get(position).get("info"));    
        listItemView.detail.setText("商品详情");    
        //注册按钮点击时间爱你    
        listItemView.detail.setOnClickListener(new View.OnClickListener() {    
            @Override   
            public void onClick(View v) {    
                //显示物品详情    
                showDetailInfo(selectID);    
            }    
        });    
        // 注册多选框状态事件处理    
        listItemView.check    
                .setOnCheckedChangeListener(new CheckBox.OnCheckedChangeListener() {    
                    @Override   
                    public void onCheckedChanged(CompoundButton buttonView,    
                            boolean isChecked) {    
                        //记录物品选中状态    
                        checkedChange(selectID);    
                    }    
        });    
            
        return convertView;    
    }    
} 

 

至于,如何实现系统自带的适配器,如ArrayAdapter、SimpleAdapter和SimpleCursorAdapter等,有机会再补充。

  • 大小: 43.6 KB
  • 大小: 32.7 KB
  • 大小: 42.1 KB
  • 大小: 33.5 KB
1
1
分享到:
评论

相关推荐

    Android自定义adapter的listview

    以上就是关于“Android自定义adapter的listview”的主要知识点。自定义Adapter是Android开发中的核心技能之一,掌握好这一技巧,能帮助我们实现各种复杂的界面效果。通过不断实践和优化,我们可以在保证性能的同时,...

    Android ListView 自定义adapter好友列表

    本文将深入探讨如何使用自定义Adapter来创建一个功能丰富的Android ListView好友列表。 首先,我们需要理解ListView的工作原理。ListView依赖于Adapter来提供数据和视图之间的桥梁。Adapter是连接数据源(如...

    Android自定义Adapter适配器

    本项目聚焦于自定义Adapter的实现,特别是如何将其应用于ListView的数据显示。 首先,理解Adapter的基本原理是关键。Adapter是一个接口,它的主要职责是将数据模型转换为视图,以便在UI组件如ListView、GridView或...

    TabHost中填充自定义ListView

    在Android开发中,`TabHost` 是一个非常重要的组件,用于实现多标签页面的切换,而将自定义的`ListView`填充到`TabHost`中则可以构建出复杂的交互界面。下面我们将详细探讨如何实现这一功能。 首先,我们需要了解`...

    自定义Adapter适应ListView和GridView

    总之,自定义Adapter是Android开发中不可或缺的一部分,它帮助开发者将数据模型与界面元素紧密结合起来,实现高度定制化的用户体验。理解并掌握自定义Adapter的原理和实践,对于提升Android应用的开发能力具有重要...

    Android中的自定义ListView

    参考链接提供的博客文章《Android自定义ListView实现详解》(https://blog.csdn.net/qq_34020487/article/details/89402562),作者详细介绍了自定义ListView的过程,包括创建自定义适配器、设置点击事件和优化性能...

    android 自定义listview分组显示本地json格式数据

    总结,实现“android 自定义listview分组显示本地json格式数据”需要完成以下步骤:解析本地JSON数据、创建自定义Adapter、处理点击事件以及设置HeaderListView。通过这样的方式,我们可以在Android应用中构建出一个...

    GridView用自定义Adapter

    当我们需要显示的数据不满足默认Adapter提供的功能时,自定义Adapter就显得尤为重要。本篇将深入探讨如何为GridView创建自定义Adapter,以实现更灵活、个性化的数据展示。 首先,了解Adapter的基本概念。Adapter是...

    android listview 自定义样式实例

    以下将详细介绍如何在Android中实现ListView的自定义样式。 1. **自定义ListView的外观** - **自定义ListView项布局**:首先,你需要创建一个XML布局文件来定义ListView每一项的显示样式。这可以通过在`res/layout...

    android studio 自定义adapter开发闹钟小案例

    总结起来,这个"android studio 自定义adapter开发闹钟小案例"涵盖了Android开发中的多个核心知识点:自定义Adapter的实现、ListView的使用、通知栏提醒的构建、以及数据持久化和定时任务的管理。通过这个案例,你...

    ListView中使用自定义Adapter及时更新数据

    本篇将详细讲解如何在ListView中使用自定义Adapter来实现数据的及时更新。 首先,我们需要理解ListView的工作原理。ListView通过Adapter来与数据源进行交互,Adapter是连接数据集和视图的桥梁。它负责从数据集中...

    listview 自定义adapter的例子demo

    示例中的"adapter"文件可能包含了实现以上步骤的代码,包括自定义Adapter类、数据模型类以及展示数据的布局文件。在实际开发中,你可能还需要处理点击事件、优化视图复用等高级功能。 总之,自定义ListView的...

    Android ListView 之 自定义Adapter 实现列表条目功能,以及 OnItemClickListener(点击事件) OnScrollListener(滑动事件)事件监听

    Android ListView 之 自定义Adapter 实现列表条目功能,以及 OnItemClickListener(点击事件) OnScrollListener(滑动事件)事件监听   目录 Android ListView 之 自定义Adapter 实现列表条目功能,以及 ...

    android 自定义 listview

    - 在Activity或Fragment中,实例化自定义Adapter,并传入数据源和ListView引用,然后调用ListView的`setAdapter()`方法设置Adapter。 4. **优化性能**: - 使用convertView参数在`getView()`方法中进行视图复用,...

    Android自定义Adapter的ListView的思路及代码

    总结起来,自定义Adapter是Android开发中实现ListView个性化和功能扩展的重要手段。通过自定义Adapter,开发者可以根据需求创建复杂的数据视图,并处理各种用户交互事件,从而提高应用的用户体验和功能多样性。

    android listview 高效显示网络图片,自定义listview布局

    2. 自定义Adapter:你需要创建一个继承自BaseAdapter的自定义Adapter,这个Adapter负责填充ListView的每一项。在getView()方法中,使用AsyncListView提供的API来加载网络图片。 3. 设置ListView:在布局文件中,将...

    Android 自定义ScrollView ListView 体验各种纵向滑动的需求

    这时,我们可以自定义ListView的Adapter,继承自BaseAdapter,重写其中的方法,如getCount、getItem、getView等,以实现自定义的数据绑定和视图渲染。此外,还可以通过设置OnItemClickListener或...

Global site tag (gtag.js) - Google Analytics