`

【android】自定义listView(转http://yilee.info/android-diy-listview.html)

阅读更多
本文讲实现一个自定义列表的Android程序,程序将实现一个使用自定义的适配器(Adapter)绑定数据,通过contextView.setTag绑定数据有按钮的ListView。

系统显示列表(ListView)时,首先会实例化一个适配器,本文将实例化一个自定义的适配器。实现自定义适配器,必须手动映射数据,这时就需要重写getView()方法,系统在绘制列表的每一行的时候将调用此方法。

ListView在开始绘制的时候,系统自动调用getCount()函数,根据函数返回值得到ListView的长度,然后根据这个长度,调用getView()逐一画出每一行。


具体使用方法可以参考下面代码,只需记住Android自定义ListView三步骤:

第一步:准备主布局文件、组件布局文件等 第二步:获取并整理数据 第三部:绑定数据,这里我们是通过自己编写Adapter类来完成的


首先新建一个LIST.XML:

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" android:layout_height="fill_parent" 
    android:orientation="vertical" android:background="#F1E4F1"> 
    <LinearLayout android:layout_width="wrap_content" 
        android:layout_height="wrap_content" android:orientation="horizontal"> 
        <ImageView android:id="@+id/image" android:layout_width="40px" 
            android:layout_height="40px" android:layout_margin="5px" /> 
        <TextView android:id="@+id/title" android:layout_width="wrap_content" 
            android:layout_height="wrap_content" android:textSize="26px" 
            android:layout_marginLeft="20px" android:layout_marginTop="10px" 
            android:textColor="#666872" /> 
        <Button android:id="@+id/view_btn" android:layout_width="wrap_content" 
            android:layout_height="wrap_content" android:text="详细" 
            android:layout_marginLeft="90px" /> 
    </LinearLayout> 
    <TextView android:id="@+id/info" android:layout_width="wrap_content" 
        android:layout_height="wrap_content" android:textColor="#666872" 
        android:textSize="13px" /> 
</LinearLayout>


建立MYADAPTER.JAVA继承BaseAdapter


public class MyAdapter extends BaseAdapter { 
    private ArrayList<HashMap<String, Object>> data; 
    private LayoutInflater layoutInflater; 
    private Context context;
    public MyAdapter(Context context, ArrayList<HashMap<String, Object>> data) { 
        this.context = context; 
        this.data = data; 
        this.layoutInflater = LayoutInflater.from(context); 
    }

    public int getCount() { 
        return data.size(); 
    }

    /** 
     * 获取某一位置的数据 
     */ 
    public Object getItem(int position) { 
        return data.get(position); 
    }

    /** 
     * 获取唯一标识 
     */ 
    public long getItemId(int position) { 
        return position; 
    }

    /** 
     * android绘制每一列的时候,都会调用这个方法 
     */ 
    public View getView(int position, View convertView, ViewGroup parent) { 
        ZuJian zuJian = null; 
        if (convertView == null) { 
            zuJian = new ZuJian(); 
            // 获取组件布局 
            convertView = layoutInflater.inflate(R.layout.list, null); 
            zuJian.imageView = (ImageView) convertView.findViewById(R.id.image); 
            zuJian.titleView = (TextView) convertView.findViewById(R.id.title); 
            zuJian.infoView = (TextView) convertView.findViewById(R.id.info); 
            zuJian.button = (Button) convertView.findViewById(R.id.view_btn); 
            // 这里要注意,是使用的tag来存储数据的。 
            convertView.setTag(zuJian); 
        } else { 
            zuJian = (ZuJian) convertView.getTag(); 
        } 
        // 绑定数据、以及事件触发 
        zuJian.imageView.setBackgroundResource((Integer) data.get(position) 
                .get("image")); 
        zuJian.titleView.setText((String) data.get(position).get("title")); 
        zuJian.infoView.setText((String) data.get(position).get("info")); 
        zuJian.button.setOnClickListener(new OnClickListener() { 
            public void onClick(View v) { 
                //按钮触发事件,自己添加 
            } 
        }); 
        return convertView; 
    } 
}


关于上面LayoutInflater的使用:在实际开发种LayoutInflater这个类还是非常有用的。它的作用类似于 findViewById(),不同点是LayoutInflater是用来找layout下xml布局文件,并且会实例化!。

getView()的三个参数:position表示将显示的是第几行,covertView是从布局文件中inflate来的布局。我们用LayoutInflater的方法将定义好的list.xml文件提取成View实例用来显示。然后将xml文件中的各个组件实例化,这样便可以将数据对应到各个组件上了。但是按钮为了响应点击事件,需要为它添加点击监听器,这样就能捕获点击事件。


新建一个组件类,为显示在LISTVIEW上的组件

public final class ZuJian { 
    public ImageView imageView; 
    public TextView titleView; 
    public TextView infoView; 
    public Button button; 
}



最后新建一个类GOODSLISTACTIVITY.JAVA,继承自LISTACTIVITY

public class GoodsListActivity extends ListActivity { 
    
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
        // 数据格式必须严格 
        ArrayList<HashMap<String, Object>> data = getData(); 
        MyAdapter adapter = new MyAdapter(this, data); 
        setListAdapter(adapter); 
    }
    private ArrayList<HashMap<String, Object>> getData() { 
        ArrayList<HashMap<String, Object>> arrayList = new ArrayList<HashMap<String, Object>>(); 
        //根据需求添加一些数据, 
        for (int i = 0; i <10; i++) { 
            HashMap<String, Object> tempHashMap = new HashMap<String, Object>(); 
            tempHashMap.put("info", content[6]); 
            tempHashMap.put("image", R.drawable.icon); 
            tempHashMap.put("title", "餐饮美食"); 
            arrayList.add(tempHashMap); 
        } 
        return arrayList; 
    } 
}







  • 大小: 55.4 KB
分享到:
评论

相关推荐

    一款很实用的 字母条索引+自定义进度条 http://blog.csdn.net/u013210620/article/details/51250542

    ListView是早期Android API中的组件,而RecyclerView是后来引入的,性能更优,支持更多的动画效果和自定义布局管理器。 2. **SectionIndexer接口**:为了实现字母条索引,开发者需要实现这个接口。它包含三个方法:...

    ListViewTimeCountDownDemo

    在Android开发中,ListView是一种常用的视图组件,用于展示大量数据列表。`ListViewTimeCountDownDemo`项目显然是一个示例,旨在教你如何在ListView的每个item中实现倒计时的效果。这种功能常见于订单状态、限时活动...

    通讯录资源

    4、Android]仿通讯录ListView小例子 5、私密通讯录源码contact.zip 6、类QQ界面-ContactsManager 7、界面效果不错.rar 8、使用Jquery Mobile设计Android通讯录.docx 9、手机通讯录产品横评及畅想.docx 10、资源.txt ...

    文件管理apk示例代码

    1. **文件系统的访问**:Android提供了`java.io.File`类来访问和操作文件系统。开发者可以使用此类来获取SD卡的根目录,并遍历其中的文件和目录。 2. **ListView的使用**:ListView是Android中用于展示大量数据的UI...

    android 自定义listview实现仿微信/QQ设置界面demo

    在Android应用开发中,自定义ListView是常见的需求,特别是在创建具有独特交互和视觉效果的界面时,如微信或QQ的设置界面。这个“android自定义listview实现仿微信/QQ设置界面demo”就是一个实例,旨在教你如何打造...

    android自定义listview使用方法

    &lt;LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"&gt; android:id="@...

    Android代码-PagedHeadListView

    PagedHeadListView Android Library [![Android Arsenal](http://img.shields.io/badge/Android Arsenal-PagedHeadListView-blue.svg?style=flat)](http://android-arsenal.com/details/1/816) Details If ...

    android 通过向viewpage中添加listview来完成滑动效果(类似于qq滑动界面)

    文件名:page.xml 代码如下:&lt;RelativeLayout xmlns:android=”http://schemas.android.com/apk/res/android” xmlns:tools=”http://schemas.android.com/tools” android:layout_width=”fill_parent” android:...

    Android代码-android

    android Android tutorial and code http://www.javajirawat.com/2013/03/android-listview-tutorial.html http://www.javajirawat.com/2013/03/android-listview-tutorial_12.html

    开源项目集合

    这个开源项目集合包含了一系列在Android开发中非常实用的库和组件,这些项目可以帮助开发者提升应用的功能性和用户体验。以下是每个项目的详细介绍: 1. **android-pulltorefresh**:这是一个强大的下拉刷新库,...

    Android ListView 中item的左右滑动动画效果的实现

    公司有个项目要用到类似手机QQ聊天记录列表ListView左右滑动后改变item的效果,网上没找到好的代码,偶然在安卓巴士的开源站http://d.apkbus.com/里面找到了SwipeToDismiss的源码...改成自己的显示另一个view的效果就行...

    Android 自定义ListView(下拉刷新PullToRefreshListView 上拉加载LoadListView)

    Android 自定义ListView,分别实现下拉刷新的ListView及上拉加载的ListView 详情可以参考我的博客 http://blog.csdn.net/sunshanai/article/details/51622917

    Android-从页面右侧滑出通讯录

    Android 实现ListView的A-Z字母排序和过滤搜索功能,实现汉字转成拼音 * http://blog.csdn.net/xiaanming/article/details/12684155 * 2. Android 带清除功能的输入框控件ClearEditText,仿IOS的输入框 * ...

    Android ListView 选中效果 自定义

    自定义ListView的选中效果是一项常见的需求,这可以提升用户体验并增加应用的视觉吸引力。本篇将深入探讨如何实现Android ListView的自定义选中效果。 首先,我们要了解ListView的工作原理。ListView通过Adapter来...

    android 自定义listview无法响应点击事件OnItemClickListener

    在Android开发中,ListView是一种常用的组件,用于展示大量的数据列表。然而,在自定义ListView时,开发者经常遇到一个常见问题:ListView的子项无法响应点击事件,即OnItemClickListener不生效。这个问题可能由多种...

    android的listview嵌套listview,列表嵌套列表 android studio版本

    在Android开发中,ListView是一种常用的视图组件,用于展示大量数据列表。当需求涉及列表中的每个条目本身也需要展示一个子列表时,我们就会遇到ListView的嵌套问题。本教程将详细讲解如何在Android Studio环境下...

    Android代码-Android简单聊天应用程序

    This sample is deprecated. For a Firebase v3.x sample see: https://github.com/firebase/quickstart-android...ListView. Firebase keeps the list data up to date based on a mapping to a model class. More abo

    Android ListView边框圆角美化

    在Android开发中,ListView是常用的一种控件,用于展示大量数据列表。为了提升用户体验和界面设计的美观性,我们常常需要对ListView进行定制化,包括设置边框和实现圆角效果。本文将深入探讨如何在Android中实现...

    Android中的自定义ListView

    本篇文章将深入探讨如何在Android中使用ListView,以及如何实现自定义ListView。 首先,理解ListView的基本概念至关重要。ListView是一个视图容器,可以动态加载并显示一串可滚动的项目列表。每个列表项通常由一个...

    Android listview下拉刷新加载更多!

    自己重写了listview ,很理想了!下拉刷新,加载更多,(并不是上滑而是点击底部加载更多按钮,主流设计!像百度贴吧等主流软件都是这样设计的)!非常完美了,高级集成,就一个重写的listview类。可以直接用!亲们...

Global site tag (gtag.js) - Google Analytics