React Native Animated 小總結(jié)

React Native 中實(shí)現(xiàn)動(dòng)畫(huà)的主要框架就是 Animated, 經(jīng)過(guò)很多版本的迭代嗤军,Animated 已經(jīng)相當(dāng)完善,基本能滿(mǎn)足日常開(kāi)發(fā)需求了晃危。

關(guān)于 Animated 的資料叙赚,文檔網(wǎng)上有很多了,這里不展開(kāi)來(lái)詳細(xì)講僚饭【兰螅總結(jié)一下自己開(kāi)發(fā)這段時(shí)間來(lái)對(duì) Animated 的小理解。

Animated VS 原生動(dòng)畫(huà)

蘋(píng)果對(duì)自家平臺(tái) App 的用戶(hù)體驗(yàn)非常重視浪慌,可以說(shuō)現(xiàn)在 RN 平臺(tái)的動(dòng)畫(huà)庫(kù),完全比不上 iOS SDK 所能提供的效果朴则,充其量只能算是一個(gè)精華簡(jiǎn)化版本权纤。而且蘋(píng)果每年的 WWDC 對(duì)自家動(dòng)畫(huà)庫(kù)的更新都十分重視。

在一些 Animated 組件中可以打開(kāi) useNative 開(kāi)關(guān)乌妒,從而借助 iOS 平臺(tái)底層的動(dòng)畫(huà)庫(kù)實(shí)現(xiàn)效果汹想,以得到更加流暢的效果。

相比于原生動(dòng)畫(huà)的實(shí)現(xiàn)方式撤蚊,Animated:

  • 目前只支持 Animated.Text古掏,Animated.ImageAnimated.View 等幾個(gè)指定的組件侦啸,自定義的動(dòng)畫(huà)組件實(shí)現(xiàn)比較麻煩槽唾。
  • 必須使用 Animated Value 來(lái)作為動(dòng)畫(huà)的驅(qū)動(dòng),而不是被動(dòng)畫(huà)組件的具體狀態(tài)光涂,不直觀庞萍。
  • 整個(gè)動(dòng)畫(huà)的代碼被割裂,導(dǎo)致回溯閱讀修改麻煩忘闻。

Animated VS LayoutAnimated

LayoutAnimated 是基于組件 Frame 的簡(jiǎn)化版數(shù)據(jù)庫(kù)钝计,非常類(lèi)似于 Cocoa 中的 UIView animate block。而 Animated 是基于 Value 驅(qū)動(dòng)的齐佳,要復(fù)雜的多私恬。

在一些場(chǎng)景下,LayoutAnimated 要比 Animated 更為直接簡(jiǎn)單炼吴。

LayoutAnimated 簡(jiǎn)單實(shí)現(xiàn):

startAnimation() {
    LayoutAnimation.configureNext({
        duration: 700, //持續(xù)時(shí)間
        create: { // 視圖創(chuàng)建
            type: LayoutAnimation.Types.spring,
            property: LayoutAnimation.Properties.scaleXY,// opacity本鸣、scaleXY
        },
        update: { // 視圖更新
            type: LayoutAnimation.Types.spring,
        },
    });
    this.setState({width: this.state.width + 10, height: this.state.height + 10});
}

Animated 核心邏輯

總結(jié)為兩個(gè)詞:綁定驅(qū)動(dòng)

綁定缺厉,就是將組件的屬性和 Animated.Value 綁定永高,value 值變化驅(qū)動(dòng)組件重繪形成動(dòng)畫(huà)隧土。這和原生動(dòng)畫(huà)中使用組件本身的屬性來(lái)驅(qū)動(dòng)動(dòng)畫(huà)是有區(qū)分的。

驅(qū)動(dòng)命爬,就是控制 Animated.Value 的值在一段時(shí)間內(nèi)的函數(shù)變化曹傀,可以使用現(xiàn)成的曲線(etc: Easing),也可以綁定到其它 value 值上形成映射(Animated.Event)饲宛,Animated 的很多功能皆愉,本質(zhì)上就是對(duì)于 Animated.Value 的不同驅(qū)動(dòng)方式。

也貼一點(diǎn)代碼艇抠,一個(gè)簡(jiǎn)單的 Animated 實(shí)現(xiàn):

constructor(props) {

    super(props);

    this.state = {
      // 定義一個(gè) Animated.Value 值
      bgOpacity: new Animated.Value(0),
    };

    this.bgOpacityToValue = 1;
}

componentDidMount() {

    let animates = [
      // 使用 Animated 庫(kù)函數(shù)驅(qū)動(dòng)這個(gè) Value 值變化幕庐,形成動(dòng)畫(huà)
      Animated.spring(this.state.bgOpacity, {
        toValue: this.bgOpacityToValue,
      })
    ];

    this.state.bgOpacity.setValue(0);
    Animated.parallel(animates).start();
}

render() {

    return (

      <View style={styles.screen} pointerEvents='box-none'>
      
        // 定義 Animated.View, 并且將 Animated.Value 綁定到它的一個(gè)屬性上
        <Animated.View
          style={[styles.screen, styles.screenFlexStyle, {backgroundColor: 'rgba(0, 0, 0, 0.3)', opacity: this.state.bgOpacity}]}>
          </View>
        </Animated.View>
        
      </View>
    );
}

其它 Animated 的高級(jí)實(shí)現(xiàn),比如映射家淤、綁定异剥、組合、關(guān)鍵幀絮重、動(dòng)畫(huà)曲線等等冤寿,可以參考文檔。

Animated Event

起初對(duì) Animated.Event 綁定非常疑惑青伤,也算是 Animated 中比較難理解的一個(gè)點(diǎn)督怜,官方的示例代碼如下:

 onScroll={Animated.event(
   [{nativeEvent: {contentOffset: {x: this._scrollX}}}],
   {listener: (event) => console.log(event)}, // Optional async listener
 )}

文檔本身對(duì)此沒(méi)有太多解釋。這一段中狠角,onScroll 是配置 ScrollView 的回調(diào)函數(shù)号杠,所以 Animated.event() 其實(shí)返回的是一個(gè)方法,它將會(huì)被 scroll 調(diào)用丰歌,傳入當(dāng)前的滾動(dòng)事件 e姨蟋。

Animated.event() 的第一個(gè)參數(shù)是綁定序列:規(guī)定了如何將 Animated.Value() 綁定到指定的源上,可以看做是一種特殊的語(yǔ)法立帖,用偽代碼寫(xiě)就是:

e.nativeEvent.contentOffset.x 綁定到 this._scrollX

第二個(gè)參數(shù)是 config芬探,這里指定了事件的監(jiān)聽(tīng)函數(shù),其實(shí)就是 onScroll 的正常監(jiān)聽(tīng)函數(shù)厘惦,其它可選的配置見(jiàn)文檔偷仿。

所以可以翻譯一下這段拗口的語(yǔ)法,等于:

 onScroll={(e) => {
    
    Animated.event(
        [{nativeEvent: {contentOffset: {x: this._scrollX}}}],
        {listener: (event) => console.log(event)}, // Optional async listener
    )(e);
 }}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末宵蕉,一起剝皮案震驚了整個(gè)濱河市酝静,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌羡玛,老刑警劉巖别智,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異稼稿,居然都是意外死亡薄榛,警方通過(guò)查閱死者的電腦和手機(jī)讳窟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)敞恋,“玉大人丽啡,你說(shuō)我怎么就攤上這事∮裁ǎ” “怎么了补箍?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)啸蜜。 經(jīng)常有香客問(wèn)我坑雅,道長(zhǎng),這世上最難降的妖魔是什么衬横? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任裹粤,我火速辦了婚禮,結(jié)果婚禮上蜂林,老公的妹妹穿的比我還像新娘蛹尝。我一直安慰自己,他們只是感情好悉尾,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著挫酿,像睡著了一般构眯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上早龟,一...
    開(kāi)封第一講書(shū)人閱讀 51,679評(píng)論 1 305
  • 那天惫霸,我揣著相機(jī)與錄音,去河邊找鬼葱弟。 笑死壹店,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的芝加。 我是一名探鬼主播硅卢,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼藏杖!你這毒婦竟也來(lái)了将塑?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤蝌麸,失蹤者是張志新(化名)和其女友劉穎点寥,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體来吩,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡敢辩,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年蔽莱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片戚长。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡盗冷,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出历葛,到底是詐尸還是另有隱情正塌,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布恤溶,位于F島的核電站乓诽,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏咒程。R本人自食惡果不足惜鸠天,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望帐姻。 院中可真熱鬧稠集,春花似錦、人聲如沸饥瓷。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)呢铆。三九已至晦鞋,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間棺克,已是汗流浹背悠垛。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留娜谊,地道東北人确买。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像纱皆,于是被迫代替她去往敵國(guó)和親湾趾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容