官方动画文档

Overview

Animated 可以使用2种值类型:

  • Animated.Value() 单一值,能够绑定样式属性或者其它属性,也可以使用插值,单个 Animated.Value 能够驱动任意数量的属性
  • Animated.ValueXY() 容器(vectors)

Configuring animations

Animated 提供了3种动画类型。每种动画类型提供了特定的用于控制从初始值到结束值的动画曲线

  • Animated.decay(): 以一个初始速度开始,然后渐渐的停止
  • Animated.spring(): 提供简单的弹簧物理模型
  • Animated.timing(): 使用 easing function 基于时间的动画 (easeInOut 曲线,先快后慢)

Working with animations

可以通过调用 start() 方法开始动画,start() 方法还可以接收一个动画完成之后的回调函数。如果动画正常的结束,完成回调函数将返回 {finished: true}.如果动画在其正常完成之前因为调用 stop() 方法完成(比如被手势中断或者其它动画中断),它将返回 {finished: false}

Using the native driver

通过使用native driver,在开始动画之前将所有动画相关的信息都发送给原生,允许原生代码在UI thread上进行动画,而不需要在每一帧都都通过桥连接。一旦动画开始,JS线程将被阻塞而不影响动画。

可以在动画配置中指定 useNativeDriver: true 来使用原生驱动。

Animatable components

只有可动画组件才能进行动画。这个特殊的组件将动画值绑定到属性上,并且做目标原生更新,这样能避免react对每一帧进行渲染和调和过程(reconciliation process)的花销。它们也会在unmount时做清理工作因此它们默认是安全的。

  • createAnimatedComponent() 可以用于使一个组件animatable

Animated库使用上面的方法导出了下列可动画的组件:

  • Animated.View
  • Animated.ScrollView
  • Animated.Text
  • Animated.Image

Composing animations

动画可以结合复合函数组成复杂的动画:

  • Animated.delay() 在给定的delay之后开始动画
  • Animated.parallel() 同时开始多个动画
  • Animated.sequence() 按顺序开始动画,下一个动画在上一个动画结束之后开始
  • Animated.stagger() 按顺序和并行的开始动画,每个动画都给一个delay

动画可以连接起来(chain together),通过简单的设置一个动画的 toValue值成为另一个动画的 Animated.Value值, 详情见 tracking dynamic values.

默认情况下,如果一个动画停止或者被终止,则动画组中的所有其它动画都会停止

combining animated values

可以通过 addition | multiplication | division | modulo 将2个动画值结合成一个新的动画值

  • Animated.add()
  • Animated.divide()
  • Animated.modulo()
  • Animated.multiply()

Interpolation

interpolation() 方法允许输入范围映射为不同的输出范围。默认情况,它会根据给定输入范围外扩输出曲线,但是也可以压缩输出曲线。默认使用线性插值,但是也支持缓动函数

  • interpolate()

Handling gestures and other events

像panning或者 scrolling手势 和其它时间能够通过 Animated.event 直接映射为动画值。这是通过结构性的映射语法完成的,因此值能够从复杂的event 对象中提取出来。第一级是一个允许通过多个args映射的数组,这个数组包含嵌套的对象

  • Animated.event()

例如,当处理水平scrolling手势,你可能像下面那样做,为了将 event.nativeEvent.contentOffset.x 映射为 scrollX(一个Animated.Value)

onScroll = {
    Animated.event(
        // scrollX = e.nativeEvent.contentOffset.x
        [{
            nativeEvent: {
                contentOffset: {
                    x: scrollX
                }
            }
        }]
    )
}

Reference

Methods

decay()

static decay(value, config)

将一个value基于衰减系数从初始速度动画到0

config是一个下列options的对象:

  • velocity: 初始速度, Required
  • deceleration: 衰减率,默认 0.997
  • isInteraction: 是否这个动画在 InteractionManager中创建一个 'interaction handle',默认是 true
  • useNativeDriver: 使用原生driver 默认是false

timing()

static timing(value, config)

随着easing曲线改变动画值。Easing 模块有很多预定义的曲线,你也可以自定义函数。

config也是一个对象:

  • duration: 动画时间,默认为500 (ms)
  • easing: 缓动函数,默认是 Easing.inOut(Easing.ease)
  • delay: 开始动画前的延迟,默认是0
  • isInteraction: 是否这个动画在 InteractionManager中创建一个 'interaction handle',默认是 true
  • useNativeDriver: 使用原生driver 默认是false

spring()

static spring(value, config)

根据一种基于阻尼谐振的分析弹簧模型,对其进行赋值。

主要使用方法:

  • Animated.spring(value: Animated.Value | Animated.ValueXY, config: SpringAnimationConfig): Animated.CompositeAnimation

其中 config 有如下选项:

  • friction: 控制反弹力或者超过部分,默认值是 7
  • tension: 控制速度,默认是 40
  • speed: 控制动画的速度,默认值是 12
  • bounciness: 控制反弹力,默认值是 8

指定 刚度/阻尼/质量(sniffness/damping/mass) 传入 Animated.spring 函数config中,将使动画采用基于阻尼谐振子运动方程的解析弹簧模型

  • stiffness: 弹簧刚度系数,默认值是 100
  • damping: 定义弹簧的运动是如何因摩擦力(frication)而阻尼的,默认值是 10
  • mass: 附着在弹簧末端的物体质量,默认值是 1

注意你只能定义其中的一组数据,例如定义了 '反弹力和速度', 其余的2组则不能再定义了

  • bounciness/speed: 反弹力和速度
  • tension/friction:张力和摩擦力
  • stiffness/damping/mass:刚度,阻尼和质量

其余的配置选项:

  • velocity: 附着在弹簧末端物体的初始速度,默认值是0,即物体没有运动
  • overshootClamping: 表示弹簧是否应该是压缩状态而非舒展状态,默认值是false
  • restDisplacementThreshold: 在静止时(at rest)位移阈值,默认值是 0.001
  • restSpeedThreshold: 静止时应考虑弹簧的速度,单位为 pixel/second, 默认值是 0.001
  • delay: 动画开始前延迟时间,单位ms,默认值是0
  • isInteraction: 是否这个动画在InteractionManager上创建一个 'interaction handle',默认是true
  • useNativeDriver: 是否使用原生驱动,默认false

add()

static add(a, b)

将2个动画值加在一起组合创建一个新的动画值

divide()

static divide(a, b)

第1个动画值减去第2个动画值组合创建一个新的动画值

multiply()

static multiply(a, b)

将2个动画值相乘在一起组合创建一个新的动画值

modulo()

static modulo(a, modulus)

将动画值取模创建一个新的动画值

diffClamp()

static diffClamp(a, min, max)

在限制的2个值之间创建一个新的动画值。它使用了最后一个值之间的差值,因此,即使值远离界限,当值再次接近时,它也会开始改变。(value = clamp(value + diff, min, max)).

这在scroll events中有用,比如,在向上滚动时显示navbar,在向下滚动时隐藏navbar

loop()

static loop(animation)

连续的循环一个给定的动画,因此每次到达最后之后再从头开始。能够通过 iterations 指定循环的次数。如果子动画设置了 useNativeDriver: true将不会影响UI线程。另外,loops将阻止那些基于 VirtualizedList的组件在动画运行时渲染更多的行,可以通过在子动画config中设置isInteraction: false来修复这个问题

event()

static event(argMapping, config?)

接收映射数组,从每个arg依次的提取值,然后对映射的结果调用 setValue方法

onScroll= {Animated.event(
    [{nativeEvent: {contentOffset: {x: this._scrollX}}}],
    {listener: (event)=> console.log(event)} // 可选的异步listener
)}

...
onPanResponderMove: Animated.event([
   null,                // raw event arg ignored
   {dx: this._panX}],    // gestureState arg
{listener: (event, gestureState) => console.log(event, gestureState)}, // Optional async listener
 ),

forkEvent()

static forkEvent(event, listener)

高级命令式API,用于监听传入props的动画事件。尽量直接使用values

unforkEvent()

static forkEvent(event, listener)

取消监听

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • React Native 进阶(二)--动画 动画 流畅、有意义的动画对于移动应用用户体验来说是非常必要的。我们可...
    呼呼哥阅读 2,784评论 2 5
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,649评论 18 139
  • 动画翻译3 自然的动画 可以使用标准的时间曲线,但那并不是最优方案,并且不一定会带给用户令人赞叹和愉悦的感觉,因为...
    SHChen阅读 717评论 0 2
  • 动画 准备工作 本文基于react-native 0.47版本,提供两个动画系统: Animated : 细粒度的...
    liuyanhongwl阅读 4,477评论 2 9
  • 一个人到底可以忙到什么程度 忙到忘记吃饭忙到忘记下班忙到忘记约会忙到都挤不出时间看书? 虽然我对许多人自称忙得不可...
    09cbe5559b8c阅读 167评论 0 0