鱼C论坛

 找回密码
 立即注册
查看: 3408|回复: 0

[技术交流] react native 手机app之动画制作

[复制链接]
发表于 2017-8-9 06:08:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
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?m ... d=570&fromop=my这是我的Qt动画制作的淘专辑。主要动画代码在第25行onPress事件里,先把action状态设置成a这个变量的值,a变量会随着时间自增,5秒钟从0加到360,原理就是这么简单。还有文字动画必须使用Animated.Text标签才行,标签采用css3的样式,translateX 和 translateY分别是向右移动和向下移动,如果反方向就设置成负数,这回上下左右移动就都会了吧?看效果图:
jdfw.gif

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-22 01:19

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表