React Native動畫總結
阿新 • • 發佈:2018-12-14
ops rom nsf 依賴 不能 top oval chm translate
最近在使用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>
React Native動畫總結