alltolove 发表于 2017-8-9 06:08:09

react native 手机app之动画制作

import React, { Component } from 'react';
import {
AppRegistry,
View,
Text,
TouchableHighlight,
StyleSheet,
Button,
Animated
} from 'react-native';

export default class myreact extends Component {
constructor(props) {
    super(props);
    this.state = {
      action:0,
      a:new Animated.Value(0)
      }
   
    };
render() {   
    return (
      <View style={styles.container}>
      <Button
      onPress={()=>{
      this.setState({action:this.state.a})
      Animated.timing(
          this.state.a,
         
          {toValue: 360,
          duration: 5000}
         
    ).start()
      }
      }
      style={styles.btn}
      title="moving right"
      color="#841584"
      />
      <Animated.Text
      style={{fontSize: 25,marginTop: 100,
      transform:[{
      translateX:this.state.action
      },{translateY:this.state.action}]}}>
      我走了88...
      </Animated.Text>
      
      </View>
    );
}
}
const styles=StyleSheet.create({
container:{
    flex:1,
    flexWrap: 'wrap',
    backgroundColor: '#f0f0f0',
    alignItems: 'center',
    marginTop: 50
},
btn:{
    backgroundColor: 'gray',width: 150,height: 90,
    justifyContent: 'center',
    alignItems: 'center'
},
})
AppRegistry.registerComponent('myreact', () => myreact);

再向大家介绍一个Button组件,这是RN官方为我们做好的一个按钮组件,非常漂亮。RN动画有点像我以前讲的Qt动画制作,非常简单效率,它的原理是用js代码实现的网页动画。做一下广告http://bbs.fishc.com/forum.php?mod=collection&action=view&ctid=570&fromop=my这是我的Qt动画制作的淘专辑。主要动画代码在第25行onPress事件里,先把action状态设置成a这个变量的值,a变量会随着时间自增,5秒钟从0加到360,原理就是这么简单。还有文字动画必须使用Animated.Text标签才行,标签采用css3的样式,translateX 和 translateY分别是向右移动和向下移动,如果反方向就设置成负数,这回上下左右移动就都会了吧?看效果图:
页: [1]
查看完整版本: react native 手机app之动画制作