前言

动画对于客户端来说是非常重要的一部分,直接影响到应用的用户体验。前端对于动画优化通常使用CSS3样式来实现动画,以利用GPU加速特性。而React-Native由于渲染模式的不同,无法使用CSS样式的方式优化。

React-Native的实现

React-Native在动画方面有两个主要方式,一个是Animated,一个是LayoutAnimation。

Animated

Animated动画库的原理是由JavaScript来进行动画的计算,然后在每帧设置对应组件的style来实现动画过程(requestAnimationFrame)。

这个动画库的特点是非常灵活,因为所有的控制都是通过JavaScript实现的,动画补帧都是在JavaScript端完成,可以实现各种复杂动画效果,包括跟手动画等。

但是成也JavaScript败也JavaScript,JavaScript是单线程的,动画的特点是要保证流畅就要保证每秒60的帧率,也就是说如果在16ms内处理不完,势必要掉帧。而在实际业务中,播放动画的同时一般都会执行一些任务处理逻辑。比如数据拉取、数据计算,典型情况通常会伴有Loading动画,切换页面过场时伴随新页面数据加载等。在复杂场景下,由于业务逻辑的加入,动画处理的帧率就很难保证,用我们QA的话说就是卡的像个Web。。。

优点:

  • 可实现复杂动画
  • 非常灵活
  • 可以兼容Web

缺点:

  • 性能问题,掉帧、卡顿

LayoutAnimation

React-Native自带还有一种动画的实现方式,就是LayoutAnimation。这种方案是直接在Native实现一些动画效果,然后由JavaScript进行设置调用,由于整个动画过程交由Native处理,使得性能得以保证。不过LayoutAnimation的实现思路有点问题,他只是预置了几个动画效果,并且只能配置在create/update/delete的时候,需要自定义的动画、跟手动画等都没法实现。

优点:

  • 性能良好

缺点:

  • 动画效果简单,可适用范围较窄

尝试解决

给他特权

针对Animated的优化思路就是解决动画播放时JavaScript任务量的问题,保证动画循环达到60帧。一个典型的解决方案就是暂时停止所有同步任务的处理,等到动画执行完成之后再同步或异步的执行任务处理。比如在切页转场前暂停耗时操作(延迟Redux的dispatch过程等),转场动画结束后再进行同步或异步处理,把大的同步任务用setTimeout等方式拆成多个异步过程处理。

这种方案可以一定程度上解决动画卡顿的问题,但是有几个缺点:

  • 任务总是要执行的,延迟处理会导致整个处理过程变长,响应用户操作速度变慢,影响用户体验。
  • 治标不治本,复杂动画该卡还得卡。。。

优点:

  • 改动较少,成本低,万一以后facebook改进了呢?比如在独立线程进行动画渲染计算?(需要解决数据同步问题,WebWorker也是个坑)
  • 可以实现跟手动画,控制好JavaScript的任务量,效果还可以

所以此方案适用 动画相对简单、后续任务不复杂 的场景

原生优化

要从根本上解决问题,就需要让动画过程脱离JavaScript。所以就要开发原生组件来实现动画过程,这样可以充分利用机器性能,可以使用GPU进行动画渲染。还需要考虑灵活性,如果只能实现固定的效果那么使用场景就大打折扣。

然而,我们并不需要从头设计,OC、Android、WPF,都有优秀的动画API,我们还等什么?抄吧。

(So,欢迎使用 react-native-animation 支持iOS、Android,目前验证可行、能用、不完善、待重构,欢迎PR~)

举个小栗子:

<Animation.AnimationView
data={[{
type: 'Alpha',
from: 0,
to: 1,
duration: 500,
}]} autoplay={true}>
other views...
</Animation.AnimationView>

*Now support: 'Translate' | 'Rotate' | 'Scale' | 'Alpha'

Props:

export interface PropsDefine {
data: AnimationModel[]
style?: React.ViewStyle
autoplay?: boolean
autoclear?: boolean
onStart?: (view: AnimationView) => void
onEnd?: (view: AnimationView) => void
}

数据模型:

export interface AnimationModel {
name?: string
type: 'Translate' | 'Rotate' | 'Scale' | 'Alpha'
from?: number
to?: number
from2?: number
to2?: number
duration: number
startOffset?: number
interpolator?: 'Linear'
interpolatorData?: number
repeat?: number
}

效果演示:

iOS微粉App(android版兼容开发中),业务逻辑全React-Native实现。赞踩动画、弹幕动画、切页动画、回复/评论弹层动画已应用优化。

虽然这种方案可以解决可预测的动画得卡顿问题,缺点也很明显:

  • 动画的过程是预设好的,所以无法实现跟手动画

优点:

  • 动画过程交由Native处理,性能Max,JavaScript任务处理不影响动画效果,可并行

所以此方案适用 可预测的动画 的场景

结语

虽然React-Native标榜的就是性能更好,但也只是跟Web对比而言,跟Native比还是有不少差距的,跟Xamarin等跨平台方案对比性能也差距不小,所以在开发时还是要关注下性能问题,性能调优还是要花不少精力去解决的。

微粉iOS:

React-Native 动画优化的更多相关文章

  1. React Native 性能优化指南【全网最全,值得收藏】

    2020 年谈 React Native,在日新月异的前端圈,可能算比较另类了.文章动笔之前我也犹豫过,但是想到写技术文章又不是赶时髦,啥新潮写啥,所以还是动笔写了这篇 React Native 性能 ...

  2. React Native动画总结

    最近在使用react native进行App混合开发,相对于H5的开发,RN所提供的样式表较少,RN中不能使用类似于css3中的动画,因此,RN提供了Animated的API 1.写一个最简单的动画 ...

  3. React Native性能优化之可取消的异步操作

    前沿 在前端的项目开发中,异步操作是一个不可获取的,从用户的角度来说,异步操作所带来的体验是美妙的,但有时候也会带来一些性能隐患.比如说:有一个异步请求还没有返回结果,但是页面却关闭了,这时由于异步操 ...

  4. 慢牛系列四:好玩的React Native

    在上次随笔(系列三)中,我试着用RN实现了一个Demo,感觉很不错,当时遇到的问题这篇文章里基本都解决了,比如导航动画问题,这篇文章里主要介绍RN的动画,学会动画以后,各种小创意都可以实现了^^ 下面 ...

  5. React Native细节知识点总结<二>

    1.关于React Native导出组件的export default和export的问题: 一个文件只能有一个export default,可以有多个export export class Temp ...

  6. 【独家】React Native 版本升级指南

    前言 React Native 作为一款跨端框架,有一个最让人头疼的问题,那就是版本更新.尤其是遇到大版本更新,JavaScript.iOS 和 Android 三端的配置构建文件都有非常大的变动,有 ...

  7. 📝 没 2 年 React Native 开发经验,你都遇不到这些坑

    如果你喜欢我的文章,希望点赞 收藏 评论 三连支持一下,谢谢你,这对我真的很重要! React Native 开发时,如果只是写些简单的页面,基本上按着官方文档 reactnative.dev就能写出 ...

  8. H5、React Native、Native应用对比分析

    每日更新关注:http://weibo.com/hanjunqiang  新浪微博!iOS开发者交流QQ群: 446310206 "存在即合理".凡是存在的,都是合乎规律的.任何新 ...

  9. 《React Native 精解与实战》书籍连载「React 与 React Native 简介」

    此文是我的出版书籍<React Native 精解与实战>连载分享,此书由机械工业出版社出版,书中详解了 React Native 框架底层原理.React Native 组件布局.组件与 ...

  10. 1000 千米高空俯瞰 React Native

    一.历史:React Native 从开始到现在 React Native 的定位是通过 React 构建原生 App: A framework for building native apps wi ...

随机推荐

  1. 关于DOM的操作以及性能优化问题-重绘重排

     写在前面: 大家都知道DOM的操作很昂贵. 然后贵在什么地方呢? 一.访问DOM元素 二.修改DOM引起的重绘重排 一.访问DOM 像书上的比喻:把DOM和JavaScript(这里指ECMScri ...

  2. 从源码看Azkaban作业流下发过程

    上一篇零散地罗列了看源码时记录的一些类的信息,这篇完整介绍一个作业流在Azkaban中的执行过程,希望可以帮助刚刚接手Azkaban相关工作的开发.测试. 一.Azkaban简介 Azkaban作为开 ...

  3. 前端CSS预处理器Sass

    前面的话   "CSS预处理器"(css preprocessor)的基本思想是,用一种专门的编程语言,进行网页样式设计,然后再编译成正常的CSS文件.SASS是一种CSS的开发工 ...

  4. .Net 分布式云平台基础服务建设说明概要

    1)  背景 建设云平台的基础框架,用于支持各类云服务的业务的构建及发展. 2)  基础服务 根据目前对业务的理解和发展方向,总结抽象出以下几个基础服务,如图所示 3)  概要说明 基础服务的发展会根 ...

  5. Unity3D 5.3 新版AssetBundle使用方案及策略

    1.概览 Unity3D 5.0版本之后的AssetBundle机制和之前的4.x版本已经发生了很大的变化,一些曾经常用的流程已经不再使用,甚至一些老的API已经被新的API所取代. 因此,本文的主要 ...

  6. PHP代码优化

    1 代码优化 1 尽量静态化 如果一个方法能被静态,那就声明它为静态的,速度可提高1/4,甚至我测试的时候,这个提高了近三倍. 当然了,这个测试方法需要在十万级以上次执行,效果才明显. 其实静态方法和 ...

  7. [原]Cachedb 网络模块文档

    Cachedb 网络模块文档 整体结构 多路复用 (epoll 模块) 事件驱动 (事件封装) 缓冲管理 (上层buffer管理) 设计思想 层次化的设计,每一个模块只调用上一个模块的接口,并将耦合聚 ...

  8. linux centos中添加删除修改环境变量,设置java环境变量

    前言 安装完软件必要添加环境变量.指令很少,然而长时间不写就会不自信:我写的对吗?于是百度开始,于是发现又是各有千秋.好吧,好记星不如烂笔头.当然,最重要的是,百度出来的都他妈的是如何添加环境变量,只 ...

  9. 代码的坏味道(20)——过度耦合的消息链(Message Chains)

    坏味道--过度耦合的消息链(Message Chains) 特征 消息链的形式类似于:obj.getA().getB().getC(). 问题原因 如果你看到用户向一个对象请求另一个对象,然后再向后者 ...

  10. Java类访问权限修饰符

    一.概要 通过了解Java4种修饰符访问权限,能够进一步完善程序类,合理规划权限的范围,这样才能减少漏洞.提高安全性.具备表达力便于使用. 二.权限表 修饰符 同一个类 同一个包 不同包的子类 不同包 ...