浅谈Recycleview嵌套卡顿 以及你所不知道的解决方案

2019-05-21 12:34:38

参考地址 浅谈Recycleview嵌套卡顿 以及你所不知道的解决方案

由于项目需要,需要做到recycleview 这里先不讲如何用其他控件代替这种嵌套的方式


先假定你已经嵌套了 老板还不给时间给你给布局方式 那么这个时候你的这个嵌套列表 必定是卡顿的


只要超过一屏,展示效果会有卡顿现象,原因就是由于两个RecyclerView的存在,使得滑动的view滑出当前屏幕的释放存在冲突


每次都执行inflate方法


下面总结网上的几个神方法


1.最常见 的  recyclerView.setNestedScrollingEnabled(false);  这个方法有可能有效 是可以加的


2.重写recycleview


 

public class MyRecycleView extends RecyclerView {

 

    public MyRecycleView(Context context) {

        super(context);

    }

 

    public MyRecycleView(Context context, @Nullable AttributeSet attrs) {

        super(context, attrs);

    }

 

    public MyRecycleView(Context context, @Nullable AttributeSet attrs, int defStyle) {

        super(context, attrs, defStyle);

    }

 

    @Override

    public boolean onInterceptTouchEvent(MotionEvent e) {

        //返回false,则把事件交给子控件的onInterceptTouchEvent()处理

        return false;

    }

 

    @Override

    public boolean onTouchEvent(MotionEvent e) {

        //返回true,则后续事件可以继续传递给该View的onTouchEvent()处理

        return true;

    }

}

这个方法确实有效 但是有坑 比如你的外层recycleview无法滑动等等


3.这个方法是博主 “泡在网上的日子”写的 关于viewpool的使用解决滑动卡顿 的问题,但是我没有尝试 ,所以也不知道怎么样 ,希望有试过的朋友可以留言指教一二  博客地址 :http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2017/0914/8514.html


4.最后的最后 给一些 神功秘籍 这些简单粗暴的方法 是可以帮你解决卡顿问题的


a.调用 预加载方法 setInitialPrefetchItemCount(int) 来优化嵌套时预加载性能,例如横向RecycleView上有3.5个item需要显示,可以调用LinearLayoutManager.setInitialPrefetchItemCount(4),默认的数值是2。


b.设置recycleview的子项缓存 


rv.setItemViewCacheSize(200);


c.继续结合


rv.setHasFixedSize(true);        rv.setNestedScrollingEnabled(false);

完美解决嵌套卡顿


总结:虽然解决了卡顿 但是这种做法目前是不支持的 谷歌本身就不推荐recycleview 嵌套 类似这个需求 我们应该尽可能找类似 ExpandableListView 这些第三方控件来解决



  • 2018-10-28 11:14:29

    矢量资源工具Vector_Asset_Studio

    Android Studio有一个称为“Vector Asset Studio”的工具, 它可以将SVG文件和PSD文件转化为工程可用的矢量可绘制资源(vector drawable resources),

  • 2018-10-28 11:16:09

    Android vector标签 PathData 画图超详解

    SVG是一种矢量图格式,是Scalable Vector Graphics三个单词的首字母缩写。在xml文件中的标签是<vector>,画出的图形可以像一般的图片资源使用,例子如下

  • 2018-10-30 00:16:41

    android ToolBar 设置颜色

    app:popupTheme——有时候我们有需求:ActionBar文字是白的,ActionBar Overflow弹出的是白底黑字让ActionBar文字是白的,那么对应的theme肯定是Dark。可是让ActionBar弹出的是白底黑字,那么需要Light主题。这时候popupTheme就派上用场了。android:theme 与app:theme——在AppCompat v21里,提供了一个快速方便的方法设置Toolbar的主题,使用app:theme。而新版本22.1.x中,AppCompat 允许对 Toolbar 使用 android:theme代替 app:theme。最好的一点是:它会自动继承父视图的theme ,并且兼容所有APIv11以上的设备。

  • 2018-11-01 22:08:19

    Android Toolbar左、中、右对齐

    默认的Android Toolbar中添加子元素view是从左到右依次添加。需要注意的是,Android Toolbar为自身的NavigationIcon(app:navigationIcon)最靠右,Logo(app:logo)紧接NavigationIcon、Title(app:title)接续Logo、保留了默认的位置(从左边到右)。这些Android Toolbar保留的系统设置字段将挤压开发者自己安放在Toolbar中的子view,如图所示: