ListView 使用详解
wptr33 2025-05-23 20:37 32 浏览
阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android
本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:
- ListView主要使用方法
- 使用android:entries 为ListView准备数据
- 使用List 为ListView 准备数据
- 为ListView 添加头,尾,以及空布局
- 使用SimpleAdapter 为Listview 适配图文
- 使用BaseAdapter 为Listview适配图文
- ListView 分类显示
ListView 是Android中显示数据常用的控件之一,主要用于显示一个垂直滚动的数据集合,随着Android 手机对性能要求越来越高,一个更现代,更灵活,显示列表性能更优异的RecyclerView将会逐渐取代ListView的数据显示方式,但是目前为止,ListView在开发中还是十分常见的,并未被弃用。
ListView 简介
ListView 继承关系如下:
java.lang.Object
android.view.View
android.view.ViewGroup
android.widget.AdapterView<android.widget.ListAdapter>
android.widget.AbsListView
android.widget.ListView
ListView 常用XML属性
ListView XML常用属性如下:
- android:divider
- android:dividerHeight
- android:entries
- android:footerDividersEnabled
- android:headerDividersEnabled
1.ListView主要使用方法如下:
ListView 常用来显示同分类数据,常用使用方法如下:
1. 准备数据源
List mAddHeaderFooterList = new ArrayList<String>();
2.将数据源添加到适配器中
ArrayAdapter adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, mAddHeaderFooterList);
3. 将适配器中的数据添加到ListView 中
mListView.setAdapter(adapter);
2. 使用android:entries 为ListView准备数据
- 实现效果如下
android:entries
- 实现代码如下
- 在Listview标签中直接用数组为ListView填充数据
- entries 属性使用方法:
<ListView android:id="@+id/lv_entries" android:layout_width="match_parent" android:layout_height="match_parent" android:divider="@android:color/darker_gray" android:dividerHeight="2dp" android:visibility="gone" android:entries="@array/citys" />
- 填充数据如下
- array 数组资源
<string-array name="citys">
<item>北京</item>
<item>上海</item>
<item>广州</item>
<item>深圳</item>
<item>郑州</item>
<item>成都</item>
</string-array>
3. 使用List 为ListView 准备数据
- 实现效果如下
ListView
- 部分实现代码如下:
public void ListViewArrayList(View view) {
ClearAllView();
mListViewArray.setVisibility(View.VISIBLE);
// 1.准备数据源
final String[] citys = getResources().getStringArray(R.array.citys);
// 2.将数据源加载到适配器中
// ArrayAdapter adapter = new ArrayAdapter<String>(ListViewMethods.this,
// android.R.layout.simple_expandable_list_item_1, citys);
// 3.将适配器中的数据加载到ListView控件中
mArrayList = Arrays.asList(citys);
ArrayAdapter adapter = new ArrayAdapter<String>(ListViewMethods.this,
android.R.layout.simple_expandable_list_item_1, mArrayList);
mListViewArray.setAdapter(adapter);
}
4. 为ListView 添加头,尾,以及空布局
- 实现效果如下
ListView添加头 尾 空布局
- 主要方法如下:
1. 添加头布局方法
ListView.addHeaderView(View)
2.添加尾布局方法
ListView.addFooterView(View)
3. ListView数据为空时, 设置空布局方法
ListView.setEmptyView(View)
- 效果图实现代码如下
public void ListViewHAddHeaderFooter(View view) {
ClearAllView();
mListAddHeadFooter.setVisibility(View.VISIBLE);
// 准备数据源
mAddHeaderFooterList = new ArrayList<String>();
for (int i = 0; i < 6; i++) {
mAddHeaderFooterList.add("测试" + i);
}
// 将数据源添加到适配器中
final ArrayAdapter adapter = new ArrayAdapter<String>(
ListViewMethods.this, android.R.layout.simple_list_item_1,
mAddHeaderFooterList);
// 添加listview 头
imageHeader = new ImageView(this);
imageHeader.setLayoutParams(new AbsListView.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT));
imageHeader.setImageResource(R.drawable.gril);
imageHeader.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
int index = mAddHeaderFooterList.size();
for (int i = index; i < index + 20; i++) {
mAddHeaderFooterList.add("加载更多数据内容" + i);
}
adapter.notifyDataSetChanged();
}
});
mListAddHeadFooter.addHeaderView(imageHeader);
// 添加listview 尾
btnFooter = new Button(this);
btnFooter.setLayoutParams(new AbsListView.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT));
btnFooter.setText("点击加载更多");
btnFooter.setOnClickListener(new View.OnClickListener() {
public void onClick(View v) {
int index = mAddHeaderFooterList.size();
for (int i = index; i < index + 20; i++) {
mAddHeaderFooterList.add("加载更多" + i);
}
adapter.notifyDataSetChanged();
}
});
mListAddHeadFooter.addFooterView(btnFooter);
TextView tv = new TextView(this);
tv.setLayoutParams(new AbsListView.LayoutParams(
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.WRAP_CONTENT));
tv.setText("数据为空");
mListAddHeadFooter.setEmptyView(tv);
// 将适配器中的数据添加到ListView 中
mListAddHeadFooter.setAdapter(adapter);
}
5. 使用SimpleAdapter 为Listview 适配图文
- 实现效果如下
SimpleAdapter
- 实现代码如下
public void ListViewSimpleAdapter(View view) {
ClearAllView();
mListViewSimple.setVisibility(View.VISIBLE);
int[] images = { R.drawable.gril, R.drawable.ic_launcher,
R.drawable.gril, R.drawable.ic_launcher, R.drawable.gril,
R.drawable.ic_launcher, R.drawable.gril,
R.drawable.ic_launcher, R.drawable.gril, };
mSimpleList = new ArrayList<Object>();
// 准备数据
for (int i = 0; i < images.length; i++) {
Map<String, Object> map = new HashMap<String, Object>();
map.put("img", images[i]);
map.put("text", "item" + i);
mSimpleList.add(map);
}
/**
* 将数据源的数据加载到适配器中 SimpleAdapter context: 上下文对象 data:表示加载到适配器中的数据对象
* resource: 表示adapter控件中每项资源id from:表示数据源map 中key 的数组,表示key指定的值
* to:表示需要展示对应数据的控件资源id
*
* 通过from 和to的对应,将from 中key值对应的数据指定的显示到to 指定资源id的控件中
*
* **/
SimpleAdapter adapter = new SimpleAdapter(ListViewMethods.this,
mSimpleList, R.layout.listview_item_img_tv, new String[] {
"img", "text" }, new int[] { R.id.img, R.id.tv });
// 将适配器中的数据添加到控件中
mListViewSimple.setAdapter(adapter);
}
- 使用的item 布局如下
<?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="horizontal">
<ImageView
android:id="@+id/img"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_margin="5dp"
android:gravity="center_vertical"
android:src="@drawable/ic_launcher" />
<TextView
android:id="@+id/tv"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_margin="5dp"
android:textColor="@android:color/darker_gray"
android:text="test"
android:gravity="center_vertical"
android:textSize="25sp" />
</LinearLayout>
6. 使用BaseAdapter 为Listview适配图文
- 实现效果如下
BaseAdapter
-实现代码如下
public void ListViewBaseAdapter(View view) {
ClearAllView();
mListViewBase.setVisibility(View.VISIBLE);
mBaseAdapterList = new ArrayList<Map<String, Object>>();
int[] images = { R.drawable.gril, R.drawable.ic_launcher,
R.drawable.gril, R.drawable.ic_launcher, R.drawable.gril,
R.drawable.ic_launcher, R.drawable.gril,
R.drawable.ic_launcher, R.drawable.gril, };
for (int i = 0; i < images.length; i++) {
Map<String, Object> map = new HashMap<String, Object>();
map.put("img", images[i]);
map.put("text", "数据" + i);
mBaseAdapterList.add(map);
}
MyBaseAdapter adapter = new MyBaseAdapter();
mListViewBase.setAdapter(adapter);
}
自定义适配器实现的方法
class MyBaseAdapter extends BaseAdapter {
// 当前适配器中加载数据的总条目
@Override
public int getCount() {
return mBaseAdapterList.size();
}
// 根据指定下标获取对应item 的view
@Override
public Object getItem(int position) {
return mBaseAdapterList.get(position);
}
// 根据指定下标获取当前item的id
@Override
public long getItemId(int position) {
return position;
}
/**
* 获取适配器控件中的View对象,得到用于展示数据的视图 int position,:当前item的下标 View convertView,
* 表示可复用的View ViewGroup parent 当前绘制的item 所属的listview
*/
@Override
public View getView(int position, View convertView, ViewGroup parent) {
// 表示第一次运行创建,否则复用view
if (convertView == null) {
convertView = LayoutInflater.from(ListViewMethods.this)
.inflate(R.layout.listview_item_img_tv, null);
mHolder = new Holder();
mHolder.tv = (TextView) convertView.findViewById(R.id.tv);
mHolder.img = (ImageView) convertView.findViewById(R.id.img);
convertView.setTag(mHolder);
} else {
// 进行复用
mHolder = (Holder) convertView.getTag();
}
mHolder.tv.setText((String) mBaseAdapterList.get(position).get(
"text"));
mHolder.img.setImageResource((Integer) mBaseAdapterList.get(
position).get("img"));
return convertView;
}
}
class Holder {
public TextView tv;
public ImageView img;
}
- 使用的item 布局如下
<?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="horizontal"> <ImageView android:id="@+id/img" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_margin="5dp" android:gravity="center_vertical" android:src="@drawable/ic_launcher" /> <TextView android:id="@+id/tv" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_margin="5dp" android:textColor="@android:color/darker_gray" android:text="test" android:gravity="center_vertical" android:textSize="25sp" /> </LinearLayout>
7. ListView 分类显示
- 实现效果如下:
ListView 分类显示
- 实现代码如下:
public void ListViewTypeBaseAdapter(View view) {
ClearAllView();
mListViewType.setVisibility(View.VISIBLE);
MyTypeBaseAdapter myTypeBaseAdapter = new MyTypeBaseAdapter();
mListViewType.setAdapter(myTypeBaseAdapter);
}
class MyTypeBaseAdapter extends BaseAdapter {
private String[] tittles = { "分类一 :水果", "分类二 :蔬菜" };
private String[] mTypeOneList = { "苹果", "香蕉", "梨", "西瓜", "菠萝" };
private String[] mTypeTwoList = { "番茄", "土豆", "大葱", "辣椒", "莲藕", "白菜",
"萝卜", "豆角", "芹菜", "茄子" };
int[] typeOneImages = { R.drawable.gril, R.drawable.ic_launcher,
R.drawable.gril, R.drawable.ic_launcher, R.drawable.gril };
int[] typeTwoImages = { R.drawable.gril, R.drawable.ic_launcher,
R.drawable.gril, R.drawable.ic_launcher, R.drawable.gril,
R.drawable.gril, R.drawable.ic_launcher, R.drawable.gril,
R.drawable.ic_launcher, R.drawable.gril };
@Override
public int getCount() {
return mTypeOneList.length + mTypeTwoList.length + 2;
}
@Override
public Object getItem(int position) {
if (position == 0 || position == mTypeOneList.length + 1) {
return 0;
} else {
if (position < mTypeOneList.length + 1) {
return mTypeOneList[position];
} else {
return mTypeTwoList[position - mTypeOneList.length - 2];
}
}
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
int mode = getItemViewType(position);
if (mode == 0) {
ViewTitleHolder holder = null;
if (convertView == null) {
convertView = View.inflate(getApplicationContext(),
R.layout.listview_type_tv, null);
holder = new ViewTitleHolder();
holder.textView = (TextView) convertView
.findViewById(R.id.tv);
convertView.setTag(holder);
} else {
holder = (ViewTitleHolder) convertView.getTag();
}
if (position == 0) {
holder.textView.setText(tittles[position]);
} else {
holder.textView.setText(tittles[1]);
}
return convertView;
} else {
ViewHolder holder = null;
if (convertView == null) {
convertView = View.inflate(getApplicationContext(),
R.layout.listview_item_img_tv, null);
holder = new ViewHolder();
holder.imageView = (ImageView) convertView
.findViewById(R.id.img);
holder.textView = (TextView) convertView
.findViewById(R.id.tv);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
if (position < mTypeOneList.length + 1) {
holder.textView.setText(mTypeOneList[position - 1]);
holder.imageView
.setImageResource(typeOneImages[position - 1]);
} else {
holder.textView.setText(mTypeTwoList[position
- mTypeOneList.length - 2]);
holder.imageView.setImageResource(typeTwoImages[position
- mTypeOneList.length - 2]);
}
return convertView;
}
}
@Override
public int getItemViewType(int position) {
if (position == 0 || position == mTypeOneList.length + 1) {
return 0;
} else {
return 1;
}
}
@Override
public int getViewTypeCount() {
return super.getViewTypeCount() + 1;
}
}
static class ViewHolder {
ImageView imageView;
TextView textView;
}
static class ViewTitleHolder {
TextView textView;
}
- 使用的item 布局如下
<?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="wrap_content" android:orientation="vertical" > <TextView android:id="@+id/tv" android:background="@android:color/darker_gray" android:padding="5dp" android:paddingLeft="10dp" android:textSize="16sp" android:textColor="@android:color/white" android:layout_width="match_parent" android:layout_height="wrap_content"/> </LinearLayout>
友情推荐:
Android 干货分享
至此,本篇已结束,如有不对的地方,欢迎您的建议与指正。同时期待您的关注,感谢您的阅读,谢谢!
相关推荐
- oracle数据导入导出_oracle数据导入导出工具
-
关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...
- 继续学习Python中的while true/break语句
-
上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...
- python continue和break的区别_python中break语句和continue语句的区别
-
python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...
- 简单学Python——关键字6——break和continue
-
Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
-
用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...
- Python 中 break 和 continue 傻傻分不清
-
大家好啊,我是大田。...
- python中的流程控制语句:continue、break 和 return使用方法
-
Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...
- L017:continue和break - 教程文案
-
continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...
- 作为前端开发者,你都经历过怎样的面试?
-
已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...
- 面试被问 const 是否不可变?这样回答才显功底
-
作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...
- 2023金九银十必看前端面试题!2w字精品!
-
导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...
- 前端面试总结_前端面试题整理
-
记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...
- 由浅入深,66条JavaScript面试知识点(七)
-
作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...
- 2024前端面试真题之—VUE篇_前端面试题vue2020及答案
-
添加图片注释,不超过140字(可选)...
- 今年最常见的前端面试题,你会做几道?
-
在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...
- 一周热门
- 最近发表
-
- oracle数据导入导出_oracle数据导入导出工具
- 继续学习Python中的while true/break语句
- python continue和break的区别_python中break语句和continue语句的区别
- 简单学Python——关键字6——break和continue
- 2-1,0基础学Python之 break退出循环、 continue继续循环 多重循
- Python 中 break 和 continue 傻傻分不清
- python中的流程控制语句:continue、break 和 return使用方法
- L017:continue和break - 教程文案
- 作为前端开发者,你都经历过怎样的面试?
- 面试被问 const 是否不可变?这样回答才显功底
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)
