React Native動畫總結


  最近在使用react native進行App混合開發,相對於H5的開發,RN所提供的樣式表較少,RN中不能使用類似於css3中的動畫,因此,RN提供了Animated的API

  1.寫一個最簡單的動畫

  

import React, { Component } from 'react'
import { Animated, Text, View } from 'react-native'

Class DropList extends React.Component {
constructor(props) { suoer(props)
this.state = { showMenu: false, transVal: new Animated.value(0) } this.switchMenu = this.switchMenu.bind(this) } // 菜單展開動畫 stratAni() { Animated.timing( this.state.fadeAnim, { toValue: 50, duration: 500, useNativeDriver: true // <-- 加上這一行 是否啟用原生動畫 // 啟用后,動畫一開始就完全脫離了 JS 線程,因此此時即便 JS 線程被卡住,也不會影響到動畫了 // 動畫值在不同的驅動方式之間是不能兼容的。因此如果你在某個動畫中啟用了原生驅動,那么所有和此動畫依賴相同動畫值的其他動畫也必須啟用原生驅動 // 啟用原生動畫后,僅支持opacity和transform屬性變化 } ).start() } // 菜單收起動畫 closeAni() { Animated.timing( this.state.menuTransform, { toValue: 0, duration: 0, useNativeDriver: true } ).start() } // 菜單展開與折疊 switchMenu() { if (this.state.showMenu) { // 收起 this.setState({ showMenu: false }) this.closeAni() } else { // 折疊 this.setState({ showMenu: true }) this.stratAni() } }
render() {
let {
showMenu,
transVal
} = this.state
return(
<View>
        <Text onPRess={this.switchMenu}>Switch Menu</Text>
<Animated.View style={{ height: 50, backgroundColor: 'red', position: 'absolute', top: -50, transform: [ translateY: transVal ] }}>

          </Animated.View>    
</View>
)
} }

 2.插值動畫(loading旋轉動畫)

this.state = {
  aniVal: new Animated.Value(0)
}
this.aniVal = 0
componentDidMount() {
  this.state.aniVal.setValue(0);
  Animated.timing(this.state.aniVal, {
    toValue: 1,
    duration: 200
  }).start();
}
<Animated.View
    style={{
    transform: [
      {
        translateY: this.state.aniVal.interpolate({
          inputRange: [0, 1],
          outputRange: [100, 0]
        })
      }
    ],
    opacity:this.state.aniVal.interpolate({
      inputRange: [0, 1],
      outputRange: [0.2, 1]
    })
  }}>
  <Text>加載中...</Text>
</Animated.View>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM