Android开发:ListView用SimpleAdapter来实现自定义布局和点击

ListView用SimpleAdapter来实现自定义布局和点击

简单的ListView只能实现文字的列表显示。这里就不过多的介绍了,可自行百度找下。
而这次我介绍的是ListView用SimpleAdapter来实现自定义布局和点击。
一、首先要自定义一个列表的样式list_item_layout.xml文件。

<!--list_item_layout.xml-->
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal">
    <LinearLayout
        android:layout_width="165dp"
        android:layout_height="120dp"
        android:paddingLeft="12dp"
        android:paddingRight="12dp"
        android:layout_marginTop="5dp">
        <!--自定义图片-->
        <ImageView
            android:id="@+id/imgv"
            android:layout_width="150dp"
            android:layout_height="120dp"
            android:src="@drawable/a0"
            ></ImageView>
    </LinearLayout>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="120dp"
        android:orientation="vertical"
        android:paddingLeft="12dp"
        android:paddingRight="12dp"
        android:layout_marginTop="5dp">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content">
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginRight="12dp"
                android:text="名称:"></TextView>
            <TextView
                android:id="@+id/name"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text=""></TextView>
        </LinearLayout>
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content">
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginRight="12dp"
                android:text="主演:"></TextView>
            <TextView
                android:id="@+id/zy"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text=""></TextView>
        </LinearLayout>

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content">
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginRight="12dp"
                android:text="导演:"></TextView>
            <TextView
                android:id="@+id/dy"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text=""></TextView>
        </LinearLayout>
    </LinearLayout>
</LinearLayout>

二、自定义完一个list_item的布局文件后,就要在主页面上添加ListView主键,来使用list_item布局。
在主页面添加ListView组件。

<!--注意一定要声明一个id,方便java文件查找到该组件-->
<ListView
    android:id="@+id/lv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"></ListView>
    

三、在主页面的控制器java文件里查找该组件,并添加第一步里的布局文件。
(1)声明需要的变量,这里声明的变量是死的,在真实的开发中是由后端传入的变量。

//模拟数据
private String[] name={"杀破狼2", "谍影重重5", "疯狂原始人", "叶问2", "赤道"},zy={"郑保瑞", "道格·里曼", " 柯克·德·米科", "叶伟信", "梁乐民/陆剑青"},dy={"吴京/托尼·贾/张晋",  "马特·达蒙/弗兰卡·波坦特" , "尼古拉斯·凯奇", " 甄子丹/洪金宝", "张学友/张家辉"};
//这是模拟的图片数据,报错的话需要引入图片放在drawable文件夹里
private int[] imgv=new int[]{R.drawable.a0,R.drawable.a1,R.drawable.a2,R.drawable.a3,R.drawable.a4};

(2)在onCreate方法里添加自定义组件并添加点击事件

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //找到ListView
        ListView listView=findViewById(R.id.lv);
        //声明一个列表映射
        List<Map<String,Object>> list=new ArrayList<Map<String,Object>>();
        for (int i=0;i< name.length;i++){
        //声明一个映射将值添加的映射列表中
            Map<String,Object> listitem=new HashMap<String,Object>();
            listitem.put("imgv",imgv[i]);
            listitem.put("name",name[i]);
            listitem.put("zy",zy[i]);
            listitem.put("dy",dy[i]);
            list.add(listitem);
        }
        //声明SimpleAdapter将this,列表映射,自定义的布局文件,文件需要的值等等传给每个列表项中
        SimpleAdapter adapter=new SimpleAdapter(this,list,R.layout.list_item_layout,new String[]{"imgv","name","zy","dy"},new int[]{R.id.imgv,R.id.name,R.id.zy,R.id.dy});
        listView.setAdapter(adapter);
        //给每个列表项添加点击事件
        listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {
            @Override
            public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
            //这里写具体点击的事件,下面写的是一个弹框
                Toast.makeText(MainActivity.this,name[i],Toast.LENGTH_SHORT).show();
            }
        });
    }

到这里就完成了SimpleAdapter自定义ListView布局和点击事件。

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,针对你的问题,我来为你详细解答一下。 在 Android 中,ListView 是一种常用的列表视图控件,可以显示纵向滚动的数据项列表。ListView 可以使用默认的适配器来显示简单的文本列表,也可以使用自定义的视图来显示更加复杂的列表项。 一、使用默认适配器 默认适配器是 Android 系统提供的一种简单的适配器,可以用来显示简单的文本列表。下面是使用默认适配器的示例代码: ```java String[] data = {"item1", "item2", "item3", "item4", "item5"}; ListView listView = findViewById(R.id.list_view); ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, data); listView.setAdapter(adapter); ``` 上述代码中,我们创建了一个字符串数组 data,然后创建了一个 ListView 控件,并将其 id 设置为 list_view。然后,我们创建了一个 ArrayAdapter 对象,并将其构造函数的第一个参数设置为 this,表示使用当前 Activity 作为上下文;第二个参数使用了系统提供的 simple_list_item_1 布局,该布局只包含一个 TextView 控件,用于显示文本;第三个参数是数据源,即我们刚才创建的字符串数组 data。最后,我们将适配器设置给 ListView 控件,以显示数据项列表。 二、使用自定义视图 如果需要显示更加复杂的列表项,我们可以使用自定义视图来替代默认的视图。下面是使用自定义视图的示例代码: 首先,我们需要创建一个布局文件,用于定义定义视图的外观。例如,我们可以创建一个名为 list_item.xml 的布局文件,包含一个 ImageView 和一个 TextView: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content"> <ImageView android:id="@+id/icon" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/ic_launcher" /> <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Item Text" /> </LinearLayout> ``` 然后,我们可以在代码中使用该布局文件来创建自定义视图: ```java ListView listView = findViewById(R.id.list_view); List<Map<String, Object>> data = new ArrayList<>(); for (int i = 0; i < 5; i++) { Map<String, Object> item = new HashMap<>(); item.put("icon", R.drawable.ic_launcher); item.put("text", "Item " + (i + 1)); data.add(item); } SimpleAdapter adapter = new SimpleAdapter(this, data, R.layout.list_item, new String[]{"icon", "text"}, new int[]{R.id.icon, R.id.text}); listView.setAdapter(adapter); ``` 上述代码中,我们首先创建了一个 ListView 控件,并将其 id 设置为 list_view。然后,我们创建了一个 List 对象 data,用于存储列表项的数据。在循环中,我们为每个列表项创建一个 Map 对象 item,并将该对象添加到 data 中。Map 对象中包含两个键值对,分别用于存储图标和文本。 接下来,我们创建了一个 SimpleAdapter 对象,并将其构造函数的第一个参数设置为 this,表示使用当前 Activity 作为上下文;第二个参数是数据源,即我们刚才创建的 List 对象 data;第三个参数是自定义视图的布局文件,即 list_item.xml;第四个参数是一个字符串数组,用于指定数据源中每个 Map 对象中的键;第五个参数是一个整型数组,用于指定布局文件中对应的控件 id。最后,我们将适配器设置给 ListView 控件,以显示数据项列表。 以上就是使用默认适配器和自定义视图来实现 ListView 列表的方法。希望可以帮到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值