• 技术文章 >Java >java教程

    Android 自定义ListView

    高洛峰高洛峰2016-12-13 17:01:03原创806
    本文讲实现一个自定义列表的Android程序,程序将实现一个使用自定义的适配器(Adapter)绑定
    数据,通过contextView.setTag绑定数据有按钮的ListView。
    系统显示列表(ListView)时,首先会实例化一个适配器,本文将实例化一个自定义的适配器。实现
    自定义适配器,必须手动映射数据,这时就需要重写getView()方法,系统在绘制列表的每一行的时候
    将调用此方法。
    ListView在开始绘制的时候,系统自动调用getCount()函数,根据函数返回值得到ListView的长度,
    然后根据这个长度,调用getView()逐一画出每一行。
    具体使用方法可以参考下面代码,只需记住Android自定义ListView三步骤:
    第一步:准备主布局文件、组件布局文件等
    第二步:获取并整理数据
    第三部:绑定数据,这里我们是通过自己编写Adapter类来完成的
    1.首先新建一个list.XML

    Java代码

    <?xml version="1.0" encoding="utf-8"?>  
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent"  
        android:orientation="vertical" >  
        <LinearLayout android:layout_width="match_parent"  
            android:layout_height="match_parent"  
            android:orientation="horizontal" android:background="#f1e4f1">  
            <ImageView   
                android:id="@+id/image"  
                android:layout_width="wrap_content"  
                android:layout_height="wrap_content"/>  
            <TextView   
                android:id="@+id/title"  
                android:layout_width="wrap_content"  
                android:layout_height="wrap_content"  
                android:textColor="#666872"/>  
            <Button   
                android:id="@+id/view"  
                android:layout_width="wrap_content"  
                android:layout_height="wrap_content"  
                android:text="详细"/>  
        </LinearLayout>  
        <TextView   
            android:id="@+id/info"  
            android:layout_width="wrap_content"  
            android:layout_height="wrap_content"  
            android:textColor="#666872"/>  
    </LinearLayout>

    2、新建一个适配器类MyAdspter.java

    Java代码

    public class MyAdspter extends BaseAdapter {  
      
        private List<Map<String, Object>> data;  
        private LayoutInflater layoutInflater;  
        private Context context;  
        public MyAdspter(Context context,List<Map<String, Object>> data){  
            this.context=context;  
            this.data=data;  
            this.layoutInflater=LayoutInflater.from(context);  
        }  
        /** 
         * 组件集合,对应list.xml中的控件 
         * @author Administrator 
         */  
        public final class Zujian{  
            public ImageView image;  
            public TextView title;  
            public Button view;  
            public TextView info;  
        }  
        @Override  
        public int getCount() {  
            return data.size();  
        }  
        /** 
         * 获得某一位置的数据 
         */  
        @Override  
        public Object getItem(int position) {  
            return data.get(position);  
        }  
        /** 
         * 获得唯一标识 
         */  
        @Override  
        public long getItemId(int position) {  
            return position;  
        }  
      
        @Override  
        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.image=(ImageView)convertView.findViewById(R.id.image);  
                zujian.title=(TextView)convertView.findViewById(R.id.title);  
                zujian.view=(Button)convertView.findViewById(R.id.view);  
                zujian.info=(TextView)convertView.findViewById(R.id.info);  
                convertView.setTag(zujian);  
            }else{  
                zujian=(Zujian)convertView.getTag();  
            }  
            //绑定数据  
            zujian.image.setBackgroundResource((Integer)data.get(position).get("image"));  
            zujian.title.setText((String)data.get(position).get("title"));  
            zujian.info.setText((String)data.get(position).get("info"));  
            return convertView;  
        }  
      
    }

    关于上面LayoutInflater的使用:在实际开发种LayoutInflater这个类还是非常有用的。它的作用类似
    于 findViewById(),不同点是LayoutInflater是用来找layout下xml布局文件,并且会实例化!。
    getView()的三个参数:position表示将显示的是第几行,covertView是从布局文件中inflate来的布
    局。我们用LayoutInflater的方法将定义好的list.xml文件提取成View实例用来显示。然后将xml文件
    中的各个组件实例化,这样便可以将数据对应到各个组件上了。但是按钮为了响应点击事件,需要为
    它添加点击监听器,这样就能捕获点击事件。
    3、activity_main.xml中添加ListView控件

    Java代码

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"  
        xmlns:tools="http://schemas.android.com/tools"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent"  
        android:paddingBottom="@dimen/activity_vertical_margin"  
        android:paddingLeft="@dimen/activity_horizontal_margin"  
        android:paddingRight="@dimen/activity_horizontal_margin"  
        android:paddingTop="@dimen/activity_vertical_margin"  
        tools:context=".MainActivity" >  
        <ListView   
            android:id="@+id/list"  
            android:layout_width="fill_parent"  
            android:layout_height="fill_parent"></ListView>  
    </RelativeLayout>

    4、在activity中调用ListView

    Java代码

    public class MainActivity extends Activity {  
      
        private ListView listView=null;   
        @Override  
        protected void onCreate(Bundle savedInstanceState) {  
            super.onCreate(savedInstanceState);  
            setContentView(R.layout.activity_main);  
            listView=(ListView)findViewById(R.id.list);  
            List<Map<String, Object>> list=getData();  
            listView.setAdapter(new MyAdspter(this, list));  
        }  
        @Override  
        public boolean onCreateOptionsMenu(Menu menu) {  
            getMenuInflater().inflate(R.menu.main, menu);  
            return true;  
        }  
      
        public List<Map<String, Object>> getData(){  
            List<Map<String, Object>> list=new ArrayList<Map<String,Object>>();  
            for (int i = 0; i < 10; i++) {  
                Map<String, Object> map=new HashMap<String, Object>();  
                map.put("image", R.drawable.ic_launcher);  
                map.put("title", "这是一个标题"+i);  
                map.put("info", "这是一个详细信息"+i);  
                list.add(map);  
            }  
            return list;  
        }  
    }


    php入门到就业线上直播课:查看学习

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:ListView
    上一篇:android listview优化几种写法详细介绍 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• Java数据结构之单链表与OJ题• 详细介绍Java正则表达式之单字符匹配和预定义字符• Java总结分享之反射、枚举、Lambda表达式• 实例详解Java顺序表和链表• 一文搞懂Java线程池实现原理
    1/1

    PHP中文网