客户端骨架屏详解

客户端骨架屏详解,第1张

一直以来,客户端的应用中,为了提升应用的加载等待这段时间的用户感知体验,各种技术层出不穷。其中,尤以菊花图以及由它衍生各种加载动画最为突出。

对于菊花图我们自不必多说,现在对于加载的设计体验有了比菊花加载体验更棒的方法,即大家常看到的Skeleton Screen Loading,中文叫做骨架屏。

所谓Skeleton Screen Loading,即表示在页面完全渲染完成之前,用户会看到一个占位的样式,用以描绘了当前页面的大致框架,加载完成后,最终骨架屏中各个占位部分将被真实的数据替换。很多项目中都有相关的应用,如饿了么h5版本、知乎、facebook等网站中都有应用。 其效果如下图所示:

iOS实现Skeleton效果的第三方库有很多,当然也可以自己创建一个,而骨架屏最核心的就是占位和属性动画。在实现方面,本文介绍几种主流的实现方式:

实现原理

对UIView进行扩展,增加skeletonable、skeletonLayer等属性。调用showSkeleton方法,对属性skeletonable为true的视图进行遍历,找到其最上层的、skeletonable为true的子View,然后创建skeletonLayer添加到上面,构成骨架图,动效效果亦是在skeletonLayer层。需要隐藏效果时,调用hideSkeleton,同样进行遍历,移除skeletonLayer。

简单的说,在显示占位的时候,将tableView的代理设置为通过某个对象,这个对象根据cell的Idenfier创建cell并添加占位显示。关闭显示占位的时候,将代理tableView的代理切回ViewController,正常显示。

特点

1、不需手动写占位控件,不需处理圆角等问题,占位效果与实际控件布局一致。

2、缺点是有的控件是自适应大小,在未获得数据之前,控件位置是错误的,导致占位效果有问题。

同样是扩展UIView,添加属性somoContainer,表示占位视图的容器视图,其中每个占位区域都是一个SomoView。对于想要显示占位效果的View,需实现协议,在协议方法中返回SomoView列表。将这些SomoView添加到somoContainer,并显示。

特点

1、避免了上述自适应控件无数据时大小不正确的问题。

2、需要手工指定每个占位区域,且每个占位区域是UIView级别,不是CALayer。

除此之外,TABAnimated也是一个被使用的比较多的,同样TABAnimated也是扩展的UIView。在ios中集成TABAnimated需要经历以下几步:

1,Install

2,第二步(可选)

可以选择在appDelegate的didFinishLaunchingWithOptions方法全局设置动画属性,设有默认属性。例如:

3,第三步,设置animatedStyle属性

在需要动画的view上,将属性animatedStyle设置为TABTableViewAnimationStart,不需要动画的view不用做额外的 *** 作。

4,第四步

1、将需要动的组件的属性loadStyle,设置为需要的类型,不需要动的组件不用做额外的 *** 作;

2、(可选)新增属性tabViewWidth,其为动画开启时该组件的宽度,有较为合理默认值;

5,第五步

在获取到数据后,停止动画。

示例源码链接: iOS骨架屏示例

在Android中,骨架屏的实现也后很多的第三方框架,常见的有以下几个库:

ShimmerRecyclerView是一个带有闪光和指示效果的库,其运行效果如下图:

源码地址: >

获取RecyclerView滑动的距离。

Android教程2020 - 系列总览

前面我们已经用 RecyclerView显示一些数据

本文演示如何获取RecyclerView的滑动距离。

要实现这个功能,需要给RecyclerView添加滑动时监听 RecyclerViewOnScrollListener 。

RecyclerViewOnScrollListener 是一个抽象类,我们可以选择性地实现它的方法。

onScrolled 方法的 dy 表示的是每一次y方向上的相对滑动距离。向下滑动是正数,向上滑动是负数。

可以添加一个变量来累计滑动的距离。

每次滑动都累加到 mmRvScrollY 中。

打印log

建议同时给adapter加个 registerAdapterDataObserver ,监听插入/删除/移动,自己加减前面记录的dy滚动值。

工程放这里: >

LayoutManager是一个抽象类,有3个子类:

LinearLayoutManager : 线性布局管理器 GridLayoutManager : 表格布局管理器 StaggeredGridLayoutManager : 瀑布流布局管理器

LinearLayoutManager 是线性布局管理器,使用频率是最高的,展示的样式跟listview一模一样。 该类有3个构造方法:

第一个构造方法内部调用了第二个构造方法,第二个构造方法参数的含义:

orientation也可以通过mangersetOritation()设置 reverseLayout,也可以通过managersetReverseLayout()设置。 setStackFromEnd(boolean stackFromEnd) 当设置为true时,列表便会从底部开始展示内容,RecycelrView会自动滑倒尾部。 这个方法和managersetReverseLayout(true)共同点就是都自动滑动尾部,RecyclerView默认会展示末尾的item。差别在于,managersetStackFromEnd(true)不会影响内部的数据顺序,怎么添加进Adapter的,就怎么展示。

scrollToPosition(int position) 滑动到指定item linearLayoutManagerscrollToPositionWithOffset(int position,int offset) 滑动到指定item,在这个基础上,又附加偏移了offset的距离。

获取当前RecyclerView首尾可见item的位置方法

这4个方法,只有当RecyclerView在屏幕展示出来后,才能得到正常的返回值,否则都是-1

该管理器继承LinearLayoutManager,也有3个构造方法,由于是继承LiearLayoutMnager,使用起来差别不大,构造方法内使用了super()方法来直接调用了父类的构造方法:只是构造函数会多一个参数 spanCount : 列数 根据方法的注释,可以知道,默认情况下,GridLayoutManager是垂直的。在方法内,列数是调用setSpanCount(spanCount)进行设置。如果GridLayoutManager是水平的,则spanCount 代表行数,这个还是很容易理解。 GridLayoutManager不支持setStackFromEnd(),但支持setReverseLayout(boolean)方法。其他LinearLayoutManager的方法在上面已经提过了,就不重复了。

这里我们spanCount 设置为3,效果如下图

构造函数StaggeredGridLayoutManager(int spanCount, int orientation) 意思和GridLayoutManager一样。使用也是一样。这边就不具体表现讲了,看效果

使用这3个布局管理器,差不多90%的需求都能满足吧,LayoutManager也可以自定义实现,后面有用在进行详细讨论,这边仅说简单的使用。

git地址: >

以上就是关于客户端骨架屏详解全部的内容,包括:客户端骨架屏详解、关于Android RecyclerView滑动卡顿怎么解决、Android教程2020 - RecyclerView获取滑动距离等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/9388151.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-27
下一篇2023-04-27

发表评论

登录后才能评论

评论列表(0条)

    保存