百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术流 > 正文

ListView的数据更新问题

citgpt 2024-06-26 14:59 5 浏览 0 评论

1.先写个正常的demo先

好的,先写个正常的Demo先,等下我们再慢慢调:

ListView的数据更新问题

entity类:Data.java

/**

* Created by Jay on 2015/9/21 0021.

*/

public class Data {

private int imgId;

private String content;

public Data() {}

public Data(int imgId, String content) {

this.imgId = imgId;

this.content = content;

}

public int getImgId() {

return imgId;

}

public String getContent() {

return content;

}

public void setImgId(int imgId) {

this.imgId = imgId;

}

public void setContent(String content) {

this.content = content;

}

}

Activity布局以及列表项布局

activity_main.xml

<LinearLayout 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:orientation="vertical"

tools:context=".MainActivity">

<ListView

android:id="@+id/list_one"

android:layout_width="match_parent"

android:layout_height="match_parent" />

</LinearLayout>

item_list.xml:

<?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_icon"

android:layout_width="56dp"

android:layout_height="56dp"/>

<TextView

android:id="@+id/txt_content"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginTop="20dp"

android:layout_marginLeft="10dp"

android:textSize="18sp" />

</LinearLayout>

自定义BaseAdapter的实现:MyAdapter.java

/**

* Created by Jay on 2015/9/21 0021.

*/

public class MyAdapter extends BaseAdapter {

private Context mContext;

private LinkedList<Data> mData;

public MyAdapter() {}

public MyAdapter(LinkedList<Data> mData, Context mContext) {

this.mData = mData;

this.mContext = mContext;

}

@Override

public int getCount() {

return mData.size();

}

@Override

public Object getItem(int position) {

return null;

}

@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 = LayoutInflater.from(mContext).inflate(R.layout.item_list,parent,false);

holder = new ViewHolder();

holder.img_icon = (ImageView) convertView.findViewById(R.id.img_icon);

holder.txt_content = (TextView) convertView.findViewById(R.id.txt_content);

convertView.setTag(holder);

}else{

holder = (ViewHolder) convertView.getTag();

}

holder.img_icon.setImageResource(mData.get(position).getImgId());

holder.txt_content.setText(mData.get(position).getContent());

return convertView;

}

private class ViewHolder{

ImageView img_icon;

TextView txt_content;

}

}

MainActivity.java的编写:

public class MainActivity extends AppCompatActivity {

private ListView list_one;

private MyAdapter mAdapter = null;

private List<Data> mData = null;

private Context mContext = null;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mContext = MainActivity.this;

bindViews();

mData = new LinkedList<Data>();

mAdapter = new MyAdapter((LinkedList<Data>) mData,mContext);

list_one.setAdapter(mAdapter);

}

private void bindViews(){

list_one = (ListView) findViewById(R.id.list_one);

}

}

可以运行,运行后发现我们的页面并没有任何的数据,白茫茫的一片,这样的用户体验并不好, 我们可以通过调用ListView的一个setEmptyView(View)的方法,当ListView数据为空的时候, 显示一个对应的View,另外发现这个方法很奇葩,动态添加的View,竟然无效,只能在ListView 所在的布局文件中添加当ListView无数据时,想显示的View,另外用这个setEmptyView设置后的 View,加载的时候竟然不会显示出来,好灵异....比如这里的是没有数据时显示一个没有数据 的TextView,部分代码如下:

<TextView

android:id="@+id/txt_empty"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center"

android:textSize="15pt"

android:textColor="#000000"/>

txt_empty = (TextView) findViewById(R.id.txt_empty);

txt_empty.setText("暂无数据~");

list_one.setEmptyView(txt_empty);

当然除了这种方法外我们还可以定义一个与ListView一样大小位置的布局,然后设置, android:visibility="gone",在Java代码中对mData集合的size进行判断,如果==0, 说明没数据,让这个布局显示出来,当有数据的时候让这个布局隐藏~


2.添加一条记录

好的,我们弄个添加按钮,没按一次添加一条记录哈~

运行效果图:

代码实现

在我们自定义的BaseAdapter中定义一个方法,方法内容如下:

public void add(Data data) {

if (mData == null) {

mData = new LinkedList<>();

}

mData.add(data);

notifyDataSetChanged();

}

然后布局自己加个按钮,然后设置下事件,代码如下:

private Button btn_add;

btn_add = (Button) findViewById(R.id.btn_add);

btn_add.setOnClickListener(this);

@Override

public void onClick(View v) {

switch (v.getId()){

case R.id.btn_add:

mAdapter.add(new Data(R.mipmap.ic_icon_qitao,"给猪哥跪了~~~ x " + flag));

flag++;

break;

}

}

嘿嘿,成了,添加数据就这么简单~,如果你想插入到特定位置,也行,我们Adapter类里,再另外 写一个方法:

//往特定位置,添加一个元素

public void add(int position,Data data){

if (mData == null) {

mData = new LinkedList<>();

}

mData.add(position,data);

notifyDataSetChanged();

}

然后加个按钮,写个事件:

private Button btn_add2;

btn_add2 = (Button) findViewById(R.id.btn_add2);

btn_add2.setOnClickListener(this);

case R.id.btn_add2:

//position从0开始算的

mAdapter.add(4,new Data(R.mipmap.ic_icon_qitao,"给猪哥跪了~~~ x " + flag));

break;

运行效果图:

可以看到我们的第九项插入到了第五个位置~


3.删除某一项

同样的,我们写两个方法,一个直接删对象,一个根据游标来删:

public void remove(Data data) {

if(mData != null) {

mData.remove(data);

}

notifyDataSetChanged();

}

public void remove(int position) {

if(mData != null) {

mData.remove(position);

}

notifyDataSetChanged();

}

然后加两个Button,调用下这两个方法:

case R.id.btn_remove:

mAdapter.remove(mData_5);

break;

case R.id.btn_remove2:

mAdapter.remove(2);

break;

运行效果图

从图中我们可以看到,第五项被移除了,然后点击游标删除数据,一直删的是第三项!


4.移除所有的记录:

这个更加简单,直接调用clear方法即可!方法代码如下:

public void clear() {

if(mData != null) {

mData.clear();

}

notifyDataSetChanged();

}


5.更新某一个记录

细心的你应该发现了,进行了数据修改操作后,都会调用一个notifyDataSetChanged(); 一开始我以为:

notifyDataSetChanged()会把界面上现实的的item都重绘一次,这样会影响ui性能吧,如果数据量 很大,但是我改变一项就要重新绘制所有的item,这肯定不合理是吧!于是乎,我用了一个傻办法 来修改某个Item中控件的值,我在Java代码中写了这样一段代码:

private void updateListItem(int postion,Data mData){

int visiblePosition = list_one.getFirstVisiblePosition();

View v = list_one.getChildAt(postion - visiblePosition);

ImageView img = (ImageView) v.findViewById(R.id.img_icon);

TextView tv = (TextView) v.findViewById(R.id.txt_content);

img.setImageResource(mData.getImgId());

tv.setText(mData.getContent());

}

后来和群里的朋友讨论了下,发现自己错了

notifyDataSetChanged()方法会判断是否需要重新渲染,如果当前item没有必要重新渲染 是不会重新渲染的,如果某个Item的状态发生改变,都会导致View的重绘,而重绘的并不是 所有的Item,而是View状态发生变化的那个Item!所以我们直接notifyDataSetChange()方法 即可,当然知道多一个上面的方法也没什么~


代码下载:

ListViewDemo3.zip


本节小结:

好的,本节跟大家讲述了ListView中数据更新的实现,当然不止ListView,其他的Adapter 类控件都可以调用这些方法来完成数据更新~就说这么多吧~谢谢

相关推荐

js中arguments详解

一、简介了解arguments这个对象之前先来认识一下javascript的一些功能:其实Javascript并没有重载函数的功能,但是Arguments对象能够模拟重载。Javascrip中每个函数...

firewall-cmd 常用命令

目录firewalldzone说明firewallzone内容说明firewall-cmd常用参数firewall-cmd常用命令常用命令 回到顶部firewalldzone...

epel-release 是什么

EPEL-release(ExtraPackagesforEnterpriseLinux)是一个软件仓库,它为企业级Linux发行版(如CentOS、RHEL等)提供额外的软件包。以下是关于E...

FullGC详解  什么是 JVM 的 GC
FullGC详解 什么是 JVM 的 GC

前言:背景:一、什么是JVM的GC?JVM(JavaVirtualMachine)。JVM是Java程序的虚拟机,是一种实现Java语言的解...

2024-10-26 08:50 citgpt

使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
  • 使用Spire.Doc组件利用模板导出Word文档
跨域(CrossOrigin)

1.介绍  1)跨域问题:跨域问题是在网络中,当一个网络的运行脚本(通常时JavaScript)试图访问另一个网络的资源时,如果这两个网络的端口、协议和域名不一致时就会出现跨域问题。    通俗讲...

微服务架构和分布式架构的区别

1、含义不同微服务架构:微服务架构风格是一种将一个单一应用程序开发为一组小型服务的方法,每个服务运行在自己的进程中,服务间通信采用轻量级通信机制(通常用HTTP资源API)。这些服务围绕业务能力构建并...

深入理解与应用CSS clip-path 属性
深入理解与应用CSS clip-path 属性

clip-pathclip-path是什么clip-path 是一个CSS属性,允许开发者创建一个剪切区域,从而决定元素的哪些部分可见,哪些部分会被隐...

2024-10-25 11:51 citgpt

HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
  • HCNP Routing&Switching之OSPF LSA类型(二)
Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
  • Redis和Memcached的区别详解
Request.ServerVariables 大全

Request.ServerVariables("Url")返回服务器地址Request.ServerVariables("Path_Info")客户端提供的路...

python操作Kafka

目录一、python操作kafka1.python使用kafka生产者2.python使用kafka消费者3.使用docker中的kafka二、python操作kafka细...

Runtime.getRuntime().exec详解

Runtime.getRuntime().exec详解概述Runtime.getRuntime().exec用于调用外部可执行程序或系统命令,并重定向外部程序的标准输入、标准输出和标准错误到缓冲池。...

promise.all详解 promise.all是干什么的
promise.all详解 promise.all是干什么的

promise.all详解promise.all中所有的请求成功了,走.then(),在.then()中能得到一个数组,数组中是每个请求resolve抛出的结果...

2024-10-24 16:21 citgpt

Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解
  • Content-Length和Transfer-Encoding详解

取消回复欢迎 发表评论: