zoukankan      html  css  js  c++  java
  • RecyclerView局部刷新那点事

    1.局部刷新的引入 
    提到RecyclerView,我们首先想到的是ListView,对于ListView的局部刷新,我们之前已经有解决方案,[android:ListView的局部刷新]当时的解决方案是:记录点击的Item的position,然后在更新过程中,不断的判断,该position是不是介于可见的Item之间,如果是,则更新,否者,不更新。 


    2.RecyclerView的局部更新  

    按照之前的思路,首先要寻找RecyclerView中可见的item的位置范围,该方法并不在RecyclerView中,而是LinearLayoutManager中,如:

    int fristPos = layoutManager.findFirstVisibleItemPosi
    int lastPos = layoutManager.findLastVisibleItemPosition();
    
    if (position >= fristPos && position <= lastPos) {
      View view = recyclerView.getChildAt(position);
      …
    }

    然后查找到对应的View,进行更新(递归查找) 

        /**
         * 在ViewGroup中根据id进行查找
         * @param vg
         * @param id 如:R.id.tv_name
         * @return
         */
        private View findViewInViewGroupById(ViewGroup vg, int id) {
            for (int i = 0; i < vg.getChildCount(); i++) {
                View v = vg.getChildAt(i);
                if (v.getId() == id) {
                    return v;
                } else {
                    if (v instanceof ViewGroup) {
                        return findViewInViewGroupById((ViewGroup) v, id);
                    }
                }
            }
            return null;
        }    

    3.新的思路:notifyItemChanged
    RecyclerView不像ListView,只有一个更新notifyDataSetChanged,它不仅保留了ListView的更新特点,还针对“增加,删除,更新”操作专门进行更新,可以只更新一个item,也可以更新一部分item,所以,用起来效率更高。因此,RecyclerView的局部刷新,就可以通过修改数据源的方式,调用notifyItemChanged(position)即可。


    4.优化
    虽然只更新单个item,不会造成闪烁,但是,如果单个item都很复杂,比如,item中需要从网络上加载图片等等。为了避免多次刷新照成的闪烁,我们可以在加载的时候,为ImageView设置一个Tag,比如imageView.setTag(image_url),下一次再加载之前,首先获取Tag,比如imageUrl = imageView.getTag(),如果此时的地址和之前的地址一样,我们就不需要加载了,如果不一样,再加载。

  • 相关阅读:
    FPGA时序约束的几种方法
    使用NiosII代替SignalTap来监测FPGA内部数据
    Modelsim的使用
    Modelsim+Debussy
    ChipScope用法总结
    QuartusII增量编译的个人学习
    quartus II .qsf文件(zz)
    RAM与Nand/Nor flash之间的区别 (转)
    黑金资料AX301_A的Quartus工程建立、编译及引脚分配、程序下载
    关于sg90舵机的,要知道!要注意!
  • 原文地址:https://www.cnblogs.com/tianzhijiexian/p/4629422.html
Copyright © 2011-2022 走看看