React Native超棒的LayoutAnimation(布局動畫)

來源:互聯網
上載者:User

標籤:

      該文翻譯自:https://medium.com/@Jpoliachik/react-native-s-layoutanimation-is-awesome-4a4d317afd3e#.6syi2v6yh

       剛建立的React Native技術交流群(282693535),歡迎各位大牛,React Native技術愛好者加入交流!同時部落格右側歡迎掃描關注訂閱號,移動技術乾貨,精彩文章技術推送! 

     如果你是用React Native進行開發,然而還沒有嘗試過使用LayoutAnimation的話,那麼你就太out啦~

      做為一個iOS開發人員突然使用ReactNative進行開發,我之前非常擔心會失去iOS中CoreAnimation的很多特性以及使用便利。UIView的動畫是非常不錯的。在React Native中,我們只需要設定好期望的View(視圖)屬性,然後React Native的Animated(具體點擊進入) API就會達到原生開發中的類似動畫效果了。但是我們需要給每一個期望的動畫設定一個狀態屬性。對於複雜的視圖來講這樣設定整個代碼會很快變得一團糟~

       開啟LayoutAnimation(點擊進入)的文檔,千萬不要對於該簡短的文檔感到吃驚哦,其實用起來確實很簡單。

       對於布局中的多個布局變化的功能,一行代碼就可以搞定了。添加如下設定:允許視圖重新渲染以及讓LayoutAnimation為你處理所有的插值(變化)。對於大的並且複雜的視圖來講,這是非常有用強大的。

       下面示範一個例子:在該例子中,我這邊有一個三種可能的狀態的複雜視圖。下面根據三種按鈕的選中的‘index‘索引來進行分別渲染不同的高度,寬度以及item視圖的數量。該下面狀態效果變化的代碼沒有任何動畫。具體實現的效果運行如下:



      我們發現該上面是沒有任何動畫效果的,現在我們來通過添加LayoutAnimation實現狀態改變的時候視圖動畫效果,下面的一行代碼是非常必要的.

LayoutAnimation.configureNext(LayoutAnimation.Presets.spring);

該代碼設定了spring的動畫效果[注意].spring是該定義的動畫效果的一種類型

如上代碼設定之後,該對於任何布局變化的時候都會使用‘spring‘動畫類型來進行渲染呈現。具體效果如下:


      看到這個效果之後,大家是不是覺的非常性感呢?

    【注意】LayoutAnimation只對於布局的建立和更新事件才起作用,然而刪除事件是不支援的。看上面的效果,當黃色的小圓圈刪除的時候是沒有任何動畫的。

       LayoutAnimation有以下三種動畫效果類型:

  1. caseInEaseOut
  2. linear
  3. spring

       大家可以設定不同的動畫類型來看效果,或者可以進行查看原始碼進行學習(原始碼點擊進入)

      

       工作特點:LayoutAnimation運行原理通過指定的視圖計算動畫期望的位置,底層通過原生動畫架構(CoreAnimation on iOS)來完成動畫效果。幀動畫可以支援不透明度以及縮放屬性。不過我們可以添加一些其他的屬性例如:backgroundColor和transformations

      【注】這邊沒有去分析Android原始碼,所以這邊對於Android平台可能會有所不同。

       LayoutAnimation在React Native中絕對是很好的實現動畫效果,完成可以和原生體驗相媲美,非常值得大家一試。本文章執行個體完成代碼請點擊查看

       今天我們主要翻譯一篇國外的關於React Native的LayoutAnimation介紹的文章。大家有問題可以加一下群React Native技術交流群(282693535)或者底下進行回複一下。

       尊重翻譯,轉載請註明:From Sky丶清(http://blog.csdn.net/developer_jiangqq) 侵權必究!

       關注我的訂閱號(codedev123),每天分享移動開發技術(Android/IOS),專案管理以及部落格文章!(歡迎關注,第一時間推送精彩文章)

     關注我的微博,可以獲得更多精彩內容

      


React Native超棒的LayoutAnimation(布局動畫)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.