ListView学习(一)
最近了解了LIstView的用法,在听了孙老师的课程后,终于对Adapter有了一定的理解,特作此文记之。
ListView在App当中应用相当广泛,比如QQ好友列表、微博等等,都是某种特定的列表,所以这也是一个基本的组件,是我等小白不可不跨的槛。
要完成一个ListView的设计,主要需要以下部件:
- main.xml
- item.xml
- Adapter
- 数据
其中,main.xml包含ListView整体组件,item.xml则是ListView中每一项的具体布局,Adapter则是将视图中组件与数据绑定的桥梁。
首先,当然要设计好界面,我这里设计了一个类似微博的界面。
一、layout/main.xml
在main布局文件内,仅一个简单的ListView组件
<ListView
android:id="@+id/lv_main"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:dividerHeight="5dp"/>
二、layout/item.xml
然后在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="vertical">
<RelativeLayout
android:layout_margin="3dp"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<ImageView
android:id="@+id/iv_avatar"
android:layout_width="50dp"
android:layout_height="50dp"
android:src="@drawable/avatar1"
android:layout_alignParentLeft="true"
/>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="50dp"
android:layout_marginStart="5dp"
android:orientation="vertical"
android:layout_toEndOf="@+id/iv_avatar">
<TextView
android:id="@+id/tv_nickname"
android:layout_width="wrap_content"
android:layout_height="25dp"
android:text="黑冰"/>
<TextView
android:id="@+id/tv_news_source"
android:layout_width="wrap_content"
android:layout_height="25dp"
android:text="来自 weibo.com"/>
</LinearLayout>
<Button
android:id="@+id/btn_follow"
android:layout_width="wrap_content"
android:layout_height="40dp"
android:text="+ 关注"
android:layout_alignParentRight="true"
android:layout_centerVertical="true"/>
</RelativeLayout>
<TextView
android:id="@+id/tv_body"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginVertical="3dp"
android:textSize="15sp"
android:text="特朗普动用特权建墙?
California, N.Y. and other states sue Trump over national emergency to fund border wall"/>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<Button
android:id="@+id/btn_forward"
android:layout_marginHorizontal="5dp"
android:layout_width="0dp"
android:layout_height="40dp"
android:layout_weight="1"
android:text="转发3000"/>
<Button
android:id="@+id/btn_comment"
android:layout_marginHorizontal="5dp"
android:layout_width="0dp"
android:layout_height="40dp"
android:layout_weight="1"
android:text="评论1000"/>
<Button
android:id="@+id/btn_love"
android:layout_marginHorizontal="5dp"
android:layout_width="0dp"
android:layout_height="40dp"
android:layout_weight="1"
android:text="赞1000"/>
</LinearLayout>
</LinearLayout>
效果如下,请勿吐槽:

三、/MyAdapter.java
下一步,就是编写自定义Adapter(因为ArrayAdapter和SimpleAdapter比较简单,不再赘述)
package com.example.administrator.bloglistview;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import java.util.List;
import java.util.Map;
public class MyAdapter extends BaseAdapter {
List<Map<String, Object>> list;
LayoutInflater inflater;
public MyAdapter(Context context){
this.inflater = LayoutInflater.from(context);
}
public void setList(List<Map<String, Object>> list) {
this.list = list;
}
@Override
public int getCount() {
return list.size();
}
@Override
public Object getItem(int position) {
return list.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
if(convertView == null) {
convertView = inflater.inflate(R.layout.item, null);
holder = new ViewHolder();
holder.avatar = convertView.findViewById(R.id.iv_avatar);
holder.nickname = convertView.findViewById(R.id.tv_nickname);
holder.newsSource = convertView.findViewById(R.id.tv_news_source);
holder.follow = convertView.findViewById(R.id.btn_follow);
holder.body = convertView.findViewById(R.id.tv_body);
holder.forward = convertView.findViewById(R.id.btn_forward);
holder.comment = convertView.findViewById(R.id.btn_comment);
holder.love = convertView.findViewById(R.id.btn_love);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
Map map = list.get(position);
holder.avatar.setImageResource((Integer) map.get("avatar"));
holder.nickname.setText((String)map.get("nickname"));
holder.newsSource.setText((String)map.get("newsSource"));
holder.body.setText((String)map.get("body"));
return convertView;
}
public static class ViewHolder {
ImageView avatar;
TextView nickname;
TextView newsSource;
Button follow;
TextView body;
Button forward;
Button comment;
Button love;
}
}
这里要注意两点:一是inflater,二是数据绑定。
首先,inflater要在构造函数里定义好,再去getView方法里调用inflate静态方法,以将xml视图转化为View对象。
对于数据绑定,我们用的是自定义类ViewHolder来控制。首先是将视图里所有组件与ViewHolder类里的属性绑定,再取数据赋值。
可以看出,在MyAdapter类里,最重要的就是getView方法,因为它完成了布局与数据的连接。
四、/MainActivity.java
最后,在Main文件里传入数据,并设置好适配器即可。
package com.example.administrator.bloglistview;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ListView lvMain = findViewById(R.id.lv_main);
List<Map<String, Object>> list = new ArrayList<>();
Map<String, Object> map = new HashMap<>();
map.put("avatar", R.drawable.avatar1);
map.put("nickname", "基笃山伯爵");
map.put("newsSource", "来自 iPhone客户端");
map.put("body", "【“凯奇莱案”卷宗丢失等问题调查结果公布:系王林清故意所为】今天,中央政法委牵头,中央纪委国家监委、最高检、公安部参加的联合调查组,公布了最高人民法院二审审理的陕西榆林“凯奇莱案”卷宗丢失等问题的调查结果。经查明:最高法民一庭助理审判员王林清因工作中对单位产生不满,于2016年11月25");
list.add(map);
map = new HashMap<>();
map.put("avatar", R.drawable.avatar2);
map.put("nickname", "赵丽颖颖生活轧机");
map.put("newsSource", "来自 iPhone客户端");
map.put("body", "#为了不上学做过的事#\n孙子:爷爷,我不想上学。\n爷爷:不,大孙子,你必须想!");
list.add(map);
map = new HashMap<>();
map.put("avatar", R.drawable.avatar3);
map.put("nickname", "羊咩咩爱羊");
map.put("newsSource", "来自 荣耀8青春版 颜值担当");
map.put("body", "看上去很温柔的人,不一定都是好脾气,不生气不代表没脾气,不计较不代表脾气好,只是自己的修养克制了心中的怒火。如果你非要触及我的底线,我可以告诉你,我并非善良。 \u200B\u200B\u200B \u200B\u200B\u200B\u200B");
list.add(map);
map = new HashMap<>();
map.put("avatar", R.drawable.avatar4);
map.put("nickname", "英国报姐");
map.put("newsSource", "来自 iPhone客户端");
map.put("body", "再来品一下欧洲老醋王格林德沃的这句“Do you think Dumbledore will mourn for you”有多阴阳怪气[酸]本来以为预告里已经是醋意大发了,没想到正片里是一字一句顿出来的简直酸到爆!德普自己都说格林德沃就是嫉妒纽特,你们校园黄昏恋能不能放过学长!!");
list.add(map);
map = new HashMap<>();
map.put("avatar", R.drawable.avatar5);
map.put("nickname", "Mr_张教主");
map.put("newsSource", "来自 iPhone客户端");
map.put("body", "人生如梦,岁月无情。蓦然回首,才发现人活着是一种心情。穷也好,富也好,得也好,失也好。一切都是过眼云烟。不论昨天、今天、明天,能豁然开朗就是美好的一天。不论亲情、友情、爱情,能永远珍惜就是好心情。 \u200B\u200B\u200B\u200B");
list.add(map);
MyAdapter adapter = new MyAdapter(this);
adapter.setList(list);
lvMain.setAdapter(adapter);
}
}
运行后,界面如下:

以上只是手动的写入了一些数据,现实情况肯定要从数据库中取,不会这么蠢的,不必纠结。
且目前所有按钮都是空的,下节再实现按钮功能。
ListView学习(一)的更多相关文章
- [Android]ListView学习笔记
基本用法流程 创建Adapter并且派生自BaseAdapter,实现其必要的接口方法 将创建的Adapter分配给ListView对象:mPhoneBookListView.setAdapter(p ...
- C# winform控件之listview学习积累
//1.用key给ListViewItem 的 SubItems赋值 ListViewItem listViewItem= listView1.Items.Add("第一列文字") ...
- 【转】ListView学习笔记(二)——ViewHolder
在android开发中Listview是一个很重要的组件,它以列表的形式根据数据的长自适应展示具体内容,用户可以自由的定义listview每一列的布局,但当listview有大量的数据需要加载的时候, ...
- 【转】ListView学习笔记(一)——缓存机制
要想优化ListView首先要了解它的工作原理,列表的显示需要三个元素:ListView.Adapter.显示的数据: 这里的Adapter就是用到了适配器模式,不管传入的是什么View在ListVi ...
- ListView学习小结
ListView小结 ListView 是Android UI中十分重要的一个组件,在数据的显示上能有着十分灵活的表现,其使用也比较简单,一般包括以下几个要点: 1. 可以通过编写ListActiv ...
- [转]ListView学习笔记(二)——ViewHolder
在android开发中Listview是一个很重要的组件,它以列表的形式根据数据的长自适应展示具体内容,用户可以自由的定义listview每一列的布局,但当listview有大量的数据需要加载的时候, ...
- [转]ListView学习笔记(一)——缓存机制
要想优化ListView首先要了解它的工作原理,列表的显示需要三个元素:ListView.Adapter.显示的数据: 这里的Adapter就是用到了适配器模式,不管传入的是什么View在ListVi ...
- ListView学习
ListView类 常用的基本属性 FullRowSelect:设置是否行选择模式.(默认为false)提示:只有在Details视图,该属性有效. GridLines:设置行和列之间是否显示网格线. ...
- Android Studio 通过 ListView 学习 ArrayAdapte
ListView •前言 ListView 绝对可以称得上是 Android 中最常用的控件之一,几乎所有的应用程序都会用到它. 由于手机屏幕空间有限,能够一次性在屏幕上显示的内容并不多,当我们的程序 ...
随机推荐
- Java原型模式之浅拷贝-深拷贝
一.是什么? 浅拷贝:对值类型的成员变量进行值的复制,对引用类型的成员变量仅仅复制引用,不复制引用的对象 深拷贝:对值类型的成员变量进行值的复制,对引用类型的成员变量也进行引用对象的复制 内部机制: ...
- 【EasyUi DataGrid】批量删除
DataGrid是我们做网页经常使用到的组件之中的一个,对它的操作也无非是增删改查操作.单条数据的增删改相对来说比較简单.添加.改动能够直接在DataGrid中进行,也能够用弹出框的形式把数据装载在文 ...
- POJ Area of Simple Polygons 扫描线
这个题lba等神犇说可以不用离散化,但是我就是要用. 题干: Description There are N, <= N <= , rectangles -D xy-plane. The ...
- css的一些命名规范
网页制作中规范使用DIV+CSS命名规则,可以改善优化功效特别是团队合作时候可以提供合作制作效率,具体DIV CSS命名规则CSS命名大全内容篇. 常用DIV+CSS命名大全集合,即CSS命名规则 D ...
- [App Store Connect帮助]一、 App Store Connect 使用入门(4)iOS 版 App Store Connect
通过 iOS 版 App Store Connect,您可以在移动设备上查看销售数据.App 元数据和顾客评论.您还可以检查 App 状态.发布您 App 的新版本并回应“Resolution Cen ...
- [Swift通天遁地]八、媒体与动画-(15)使用TextKit实现精美的图文混排效果
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- 慕课网3-13编程练习:采用flex弹性布局制作页面主导航
小伙伴们,伸缩容器的属性我们已经学完了,接下来使用我们所学的伸缩容器属性完成下面的效果图. 要求: 1.logo.导航项.登录注册按钮这三项在水平和垂直方向上都对齐,而且他们之间的距离也相等. 2.导 ...
- C#中Random
说明:C#中的随机数是一个伪随机数,随机数字从一组有限的数字选择以相同的概率,所选的数字不是完全随机的,因为使用数学算法来选择它们.在大多数Windows系统中,Random的15毫秒内创建的对象很可 ...
- 数据库mysql原生代码基本操作
创建表: CREATE TABLE `biao` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT COMMENT '测试表', `createtime` ...
- Django总结四
0.ORM操作 1.必会的13条 返回对象列表的 all filter exclude order_by reverse distinct 特殊的对象列表 values values_list 返回对 ...