Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱
MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina.com

RecyclerView 数据刷新的几种方式 局部刷新 notify MD


目录

小结

  • 刷新全部可见的item,notifyDataSetChanged()
  • 刷新指定item,notifyItemChanged(int)
  • 从指定位置开始刷新指定个item,notifyItemRangeChanged(int,int)
  • 插入、移动一个并自动刷新,notifyItemInserted(int)、notifyItemMoved(int)、notifyItemRemoved(int)
  • 局部刷新,notifyItemChanged(int, Object)

Activity

  1. public class Notify_Activity extends Activity implements MyOnItemClickLitener {
  2. private RecyclerView mRecyclerView;
  3. private Notify_Adapter mAdapter;
  4. private ArrayList<PicUrls.BasicPicBean> beans;
  5. @Override
  6. protected void onCreate(Bundle savedInstanceState) {
  7. super.onCreate(savedInstanceState);
  8. setContentView(R.layout.activity_main);
  9. ((SwipeRefreshLayout) findViewById(R.id.swipeLayout)).setEnabled(false);
  10. mRecyclerView = (RecyclerView) findViewById(R.id.rv);
  11. initList();
  12. initView();
  13. }
  14. protected void initView() {
  15. mAdapter = new Notify_Adapter(this, beans);
  16. mAdapter.setOnItemClickLitener(this);
  17. mRecyclerView.setAdapter(mAdapter);//设置adapter
  18. mRecyclerView.setLayoutManager(new GridLayoutManager(this, 3));//设置布局管理器
  19. mRecyclerView.setItemAnimator(new DefaultItemAnimator());//设置Item增加、移除动画
  20. mRecyclerView.addItemDecoration(new GridItemDecoration.Builder().spanCount(3)
  21. .spaceSize(1).mDivider(new ColorDrawable(0x88ff0000)).build());
  22. }
  23. private void initList() {
  24. beans = PicUrls.getPicList(PicUrls.BIG_BEANS_2);
  25. beans.get(0).name = "刷新当前,notifyItemChanged(int)";
  26. beans.get(1).name = "全部刷新,notifyDataSetChanged()";
  27. beans.get(2).name = "从此位置开始刷新2个,notifyItemRangeChanged";
  28. beans.get(3).name = "插入一个并自动刷新,notifyItemInserted";
  29. beans.get(4).name = "只更改数据源,这样当然不会刷新UI";
  30. beans.get(5).name = "插入一个并刷新当前,notifyItemChanged";
  31. beans.get(6).name = "局部刷新,tv";
  32. beans.get(7).name = "局部刷新,et";
  33. beans.get(8).name = "局部刷新,iv";
  34. }
  35. @Override
  36. public void onItemClick(View view, int position) {
  37. Toast.makeText(this, position + " 被点击了", Toast.LENGTH_SHORT).show();
  38. reInit(position);
  39. }
  40. @Override
  41. public void onItemLongClick(View view, int position) {
  42. Toast.makeText(this, position + "被长按了", Toast.LENGTH_SHORT).show();
  43. }
  44. private void reInit(int position) {
  45. switch (position) {
  46. default:
  47. mAdapter.notifyItemChanged(position);//刷新指定一个。一定会闪
  48. break;
  49. case 1:
  50. mAdapter.notifyDataSetChanged();//全部刷新。基本不会闪,刚开始个别可能会闪
  51. break;
  52. case 2:
  53. mAdapter.notifyItemRangeChanged(position, 2);//从指定位置开始刷新指定个。一定会闪
  54. break;
  55. case 3:
  56. beans.add(position, new PicUrls.BasicPicBean("http://img.mmjpg.com/2015/74/1.jpg", "新插入的图片1", 1));
  57. mAdapter.notifyItemInserted(position);//插入一个并刷新,正常
  58. break;
  59. case 4://只更改数据源,这样当然不会刷新UI
  60. beans.add(position, new PicUrls.BasicPicBean("http://img.mmjpg.com/2015/74/2.jpg", "新插入的图片2", 2));
  61. break;
  62. case 5://
  63. beans.add(position, new PicUrls.BasicPicBean("http://img.mmjpg.com/2015/74/3.jpg", "新插入的图片3", 3));
  64. mAdapter.notifyItemChanged(position);//这样只会导致当前item刷新,而不会刷新其他item,当然是不行的
  65. break;
  66. case 6:
  67. beans.set(position, beans.get(new Random().nextInt(beans.size())));
  68. mAdapter.notifyItemChanged(position, Notify_Adapter.NOTIFY_TV);//局部刷新
  69. break;
  70. case 7:
  71. beans.set(position, beans.get(new Random().nextInt(beans.size())));
  72. mAdapter.notifyItemChanged(position, Notify_Adapter.NOTIFY_ET);//局部刷新
  73. break;
  74. case 8:
  75. beans.set(position, beans.get(new Random().nextInt(beans.size())));
  76. mAdapter.notifyItemChanged(position, Notify_Adapter.NOTIFY_IV);//局部刷新
  77. break;
  78. }
  79. }
  80. }

Adapter

  1. public class Notify_Adapter extends RecyclerView.Adapter<Notify_Adapter.MyViewHolder> {
  2. private Context context;
  3. private List<PicUrls.BasicPicBean> mDatas;
  4. private MyOnItemClickLitener mOnItemClickLitener;
  5. public static final int NOTIFY_TV = 10086;
  6. public static final int NOTIFY_ET = 10087;
  7. public static final int NOTIFY_IV = 10088;
  8. public Notify_Adapter(Context context, List<PicUrls.BasicPicBean> mDatas) {
  9. this.context = context;
  10. this.mDatas = mDatas;
  11. }
  12. @Override
  13. public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
  14. return new MyViewHolder(LayoutInflater.from(context).inflate(R.layout.item_notify, parent, false));
  15. }
  16. @Override
  17. public void onBindViewHolder(MyViewHolder holder, int position) {
  18. //不使用
  19. }
  20. @Override
  21. public void onBindViewHolder(final MyViewHolder holder, int position, List payloads) {
  22. //payloads是从notifyItemChanged(int, Object)中,或从notifyItemRangeChanged(int, int, Object)中传进来的Object集合
  23. //如果payloads不为空并且viewHolder已经绑定了旧数据了,那么adapter会使用payloads参数进行布局刷新
  24. //如果payloads为空,adapter就会重新绑定数据,也就是刷新整个item
  25. PicUrls.BasicPicBean bean = mDatas.get(holder.getAdapterPosition());
  26. long time = System.currentTimeMillis() + bean.url.hashCode();
  27. String data = new SimpleDateFormat("HH:mm:ss", Locale.getDefault()).format(new Date(time));
  28. if (payloads.isEmpty()) {//为空,即不是调用notifyItemChanged(position,payloads)后执行的,也即在初始化时执行的
  29. holder.tv.setText(data);
  30. holder.et.setText(bean.name);
  31. Glide.with(context).load(bean.url)
  32. .dontAnimate()
  33. //.diskCacheStrategy(DiskCacheStrategy.NONE).skipMemoryCache(true)
  34. .into(holder.iv);
  35. } else if (payloads.size() > 0 && payloads.get(0) instanceof Integer) {
  36. //不为空,即调用notifyItemChanged(position,payloads)后执行的,可以在这里获取payloads中的数据进行局部刷新
  37. int type = (int) payloads.get(0);// 刷新哪个部分 标志位
  38. switch (type) {
  39. case NOTIFY_TV:
  40. holder.tv.setText(data);//只刷新tv
  41. break;
  42. case NOTIFY_ET:
  43. holder.et.setText(bean.name);//只刷新et
  44. break;
  45. case NOTIFY_IV:
  46. Glide.with(context).load(bean.url).dontAnimate().into(holder.iv);//只刷新iv
  47. break;
  48. }
  49. }
  50. // 如果设置了回调,则设置点击事件
  51. holder.itemView.setOnClickListener(new OnClickListener() {
  52. @Override
  53. public void onClick(View v) {
  54. if (mOnItemClickLitener != null) mOnItemClickLitener.onItemClick(holder.itemView, holder.getAdapterPosition());
  55. }
  56. });
  57. holder.itemView.setOnLongClickListener(new OnLongClickListener() {
  58. @Override
  59. public boolean onLongClick(View v) {
  60. if (mOnItemClickLitener != null) mOnItemClickLitener.onItemLongClick(holder.itemView, holder.getAdapterPosition());
  61. return false;
  62. }
  63. });
  64. }
  65. @Override
  66. public int getItemCount() {
  67. return mDatas.size();
  68. }
  69. /**
  70. * 添加并更新数据,同时具有动画效果
  71. */
  72. public void addDataAt(int position, PicUrls.BasicPicBean data) {
  73. mDatas.add(position, data);
  74. notifyItemInserted(position);//更新数据集,注意如果用adapter.notifyDataSetChanged()将没有动画效果
  75. }
  76. /**
  77. * 移除并更新数据,同时具有动画效果
  78. */
  79. public void removeDataAt(int position) {
  80. mDatas.remove(position);
  81. notifyItemRemoved(position);
  82. }
  83. public void setOnItemClickLitener(MyOnItemClickLitener mOnItemClickLitener) {
  84. this.mOnItemClickLitener = mOnItemClickLitener;
  85. }
  86. class MyViewHolder extends RecyclerView.ViewHolder {
  87. TextView tv;
  88. ImageView iv;
  89. EditText et;
  90. public MyViewHolder(View view) {
  91. super(view);
  92. tv = (TextView) view.findViewById(R.id.tv_name);
  93. iv = (ImageView) view.findViewById(R.id.iv_head);
  94. et = (EditText) view.findViewById(R.id.et_input);
  95. }
  96. }
  97. }

布局

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:gravity="center_horizontal"
  6. android:orientation="vertical">
  7. <TextView
  8. android:id="@+id/tv_name"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:gravity="center"
  12. android:text="0.00"
  13. android:textColor="#00f"
  14. android:textSize="13sp"/>
  15. <ImageView
  16. android:id="@+id/iv_head"
  17. android:layout_width="match_parent"
  18. android:layout_height="200dp"
  19. android:scaleType="centerCrop"
  20. android:src="@mipmap/ic_launcher"/>
  21. <EditText
  22. android:id="@+id/et_input"
  23. android:layout_width="wrap_content"
  24. android:layout_height="wrap_content"
  25. android:gravity="center"
  26. android:hint="包青天"
  27. android:inputType="numberDecimal"
  28. android:labelFor="@id/et_input"
  29. android:maxLines="1"
  30. android:minWidth="50dp"
  31. android:textColor="#f00"
  32. android:textSize="10sp"/>
  33. </LinearLayout>

获取图片集合

  1. public class PicUrls {
  2. private static final String HOST0 = "http://img1.mm131.com/pic/";//网站【http://www.mm131.com/】
  3. private static final String HOST1 = "http://img.mmjpg.com/";//网站【http://www.mmjpg.com/】
  4. private static final String HOST2 = "http://pic.meituba.com/uploads/allimg/";//网站【http://www.meituba.com/】
  5. public static final UrlBean BIG_BEANS_0 = new UrlBean.Builder()//http://pic.meituba.com/uploads/allimg/2015/10/23/220.jpg
  6. .host(HOST2).urlHeader("2015/10/23/").picIndexFrom(220).picCount(100).picDes("100张动漫卡通壁纸").build();
  7. public static final UrlBean BIG_BEANS_1 = new UrlBean.Builder()//http://pic.meituba.com/uploads/allimg/2017/03/27/121_5600.jpg
  8. .host(HOST2).urlHeader("2017/03/27/121_").picIndexFrom(5600).picCount(100).picDes("100张搞笑内涵图片").build();
  9. public static final UrlBean BIG_BEANS_2 = new UrlBean.Builder()//http://pic.meituba.com/uploads/allimg/2015/10/23/360.jpg
  10. .host(HOST2).urlHeader("2015/10/23/").picIndexFrom(360).picCount(750).picDes("750张性感美女图").build();
  11. public static final UrlBean BIG_BEANS_3 = new UrlBean.Builder()//http://pic.meituba.com/uploads/allimg/2016/03/25/43_20335.jpg
  12. .host(HOST2).urlHeader("2016/03/25/43_").picIndexFrom(20335).picCount(1400).picDes("1400张动漫卡通壁纸").build();
  13. private static final UrlBean[] simpleBeans = {
  14. //http://img1.mm131.com/pic/996/1.jpg
  15. new UrlBean.Builder().host(HOST0).urlHeader("996/").picCount(10).picDes("北影校花余雨高清写真图片").build(),
  16. new UrlBean.Builder().host(HOST0).urlHeader("2958/").picCount(10).picDes("童颜嫩妹桃子黑丝大尺度诱惑").build(),
  17. new UrlBean.Builder().host(HOST0).urlHeader("2939/").picCount(10).picDes("清纯少女刘奕宁酥胸覆白色内衣").build(),
  18. new UrlBean.Builder().host(HOST0).urlHeader("2343/").picCount(10).picDes("萌妹销魂写真身材惹火让人欲罢不能").build(),
  19. new UrlBean.Builder().host(HOST0).urlHeader("2935/").picCount(10).picDes("性感女神杨晨晨透视睡衣大胆秀乳").build(),
  20. //http://img.mmjpg.com/2015/444/1.jpg
  21. new UrlBean.Builder().host(HOST1).urlHeader("2015/444/").picCount(10).picDes("模范学院美少女柳侑绮制服大片").build(),
  22. new UrlBean.Builder().host(HOST1).urlHeader("2015/74/").picCount(10).picDes("极品女神可儿私拍秀完美身材").build(),
  23. new UrlBean.Builder().host(HOST1).urlHeader("2017/990/").picCount(10).picDes("香艳妹子雪白的美胸绝对让你大饱眼福").build(),
  24. new UrlBean.Builder().host(HOST1).urlHeader("2017/962/").picCount(10).picDes("真诱人啊!女神雪白的美胸看着很有感觉").build(),
  25. new UrlBean.Builder().host(HOST1).urlHeader("2017/936/").picCount(10).picDes("身材娇美纯天然美女小叶子美胸艺术照").build(),
  26. //http://pic.meituba.com/uploads/allimg/2015/10/23/247.jpg
  27. new UrlBean.Builder().host(HOST2).urlHeader("2015/10/23/").picIndexFrom(247).picCount(10).picDes("呆萌可爱的哆啦A梦动漫").build(),
  28. new UrlBean.Builder().host(HOST2).urlHeader("2016/03/25/43_").picIndexFrom(20574).picCount(10).picDes("海贼王红发香克斯").build(),

2017-6-7

RecyclerView 数据刷新的几种方式 局部刷新 notify MD的更多相关文章

  1. 基于MVC4+EasyUI的Web开发框架经验总结(12)--利用Jquery处理数据交互的几种方式

    在基于MVC4+EasyUI的Web开发框架里面,大量采用了Jquery的方法,对数据进行请求或者提交,方便页面和服务器后端进行数据的交互处理.本文主要介绍利用Jquery处理数据交互的几种方式,包括 ...

  2. 数据存储的两种方式:Cookie 和Web Storage

    数据存储的两种方式:Cookie 和Web Storage 1.Cookie Cookie的作用就像你去超市购物时,第一次给你办张购物卡,这个购物卡里存放了一些你的个人信息,下次你再来这个连锁超市时, ...

  3. 数据存储的两种方式:Cookie 和Web Storage(转)

    数据存储的两种方式:Cookie 和Web Storage   数据存储的两种方式:Cookie 和Web Storage 1.Cookie Cookie的作用就像你去超市购物时,第一次给你办张购物卡 ...

  4. (转)基于MVC4+EasyUI的Web开发框架经验总结(12)--利用Jquery处理数据交互的几种方式

    http://www.cnblogs.com/wuhuacong/p/4085682.html 在基于MVC4+EasyUI的Web开发框架里面,大量采用了Jquery的方法,对数据进行请求或者提交, ...

  5. 实现web数据同步的四种方式

    http://www.admin10000.com/document/6067.html 实现web数据同步的四种方式 1.nfs实现web数据共享 2.rsync +inotify实现web数据同步 ...

  6. QF——iOS中数据持久化的几种方式

    数据持久化的几种方式: 一.属性列表文件: .plist文件是种XML文件.数组,字典都可以和它互相转换.数组和字典可以写入本地变成plist文件.也可以读取本地plist文件,生成数组或字典. 读取 ...

  7. PHP中数据类型转换的三种方式

    PHP中数据类型转换的三种方式 PHP的数据类型转换属于强制转换,允许转换的PHP数据类型有: 1.(int).(integer):转换成整形2.(float).(double).(real):转换成 ...

  8. linux下实现web数据同步的四种方式(性能比较)

    实现web数据同步的四种方式 ======================================= 1.nfs实现web数据共享2.rsync +inotify实现web数据同步3.rsyn ...

  9. 数据可视化之powerBI基础(十二)PowerBI导入Excel数据有哪几种方式?

    https://zhuanlan.zhihu.com/p/64999937 Excel作为使用最频繁.应用最广泛.用户最庞大的数据处理工具,当然也应该是PowerBI最常用的数据获取方式,本文介绍一下 ...

随机推荐

  1. 开源IDS系列--snorby 进程正常,但是worker无法启动 The Snorby worker is not currently running

    设置页面报错:   The Snorby worker is not currently running. It's imperative you start the worker immediate ...

  2. 经常报错:Communications link failure

    连接池配置中配上:<property name="validationQuery" value="SELECT 1 FROM DUAL" />

  3. Java利用Redis实现消息队列

    应用场景 为什么要用redis?二进制存储.java序列化传输.IO连接数高.连接频繁 一.序列化 这里编写了一个java序列化的工具,主要是将对象转化为byte数组,和根据byte数组反序列化成ja ...

  4. Boolean Expressions POJ - 2106 (表达式求值)

    The objective of the program you are going to produce is to evaluate boolean expressions as the one ...

  5. ARC 058

    所以为啥要写来着........... 链接 T1 直接枚举大于等于$n$的所有数,暴力分解判断即可 复杂度$O(10n \log n)$ #include <cstdio> #inclu ...

  6. [UOJ61]怎样更有力气

    这个题还是挺有意思的... 一个小结论是:在一个$n$点$m$边的图中,如果度数最小的点度数为$d$,那么$d^2=O(m)$,因为$d\leq\frac{2m}n$,所以$d^2\leq dn\le ...

  7. 2017-2018-1 JAVA实验站 冲刺 day06

    2017-2018-1 JAVA实验站 冲刺 day06 各个成员今日完成的任务 小组成员 今日工作 完成进度 张韵琪 进行工作总结.博客.小组成员头像 100% 齐力锋 找背按钮声音 100% 张浩 ...

  8. Java泛型之类型未被擦除

    大家都知道Java源码在编译之后会擦除泛型信息,现在来看一种泛型未被擦除的情况,见ConcurrentHashMap.comparableClassFor方法. ParameterizedType.g ...

  9. 小识.htaccess文件

    .htaccess文件(或者"分布式配置文件")提供了针对目录改变配置的方法, 即,在一个特定的文档目录中放置一个包含一个或多个指令的文件, 以作用于此目录及其所有子目录.作为用户 ...

  10. [转]ANDROID开发之SQLite详解

    SQLite简介 Google为Andriod的较大的数据处理提供了SQLite,他在数据存储.管理.维护等各方面都相当出色,功能也非常的强大.SQLite具备下列特点: 1.轻量级 使用 SQLit ...