鱼C论坛

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

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

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

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

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

x
  1. import React, { Component } from 'react';
  2. import {
  3.   AppRegistry,
  4.   View,
  5.   Text,
  6.   TouchableHighlight,
  7.   StyleSheet,
  8.   Button,
  9.   Animated
  10. } from 'react-native';

  11. export default class myreact extends Component {
  12.   constructor(props) {
  13.     super(props);
  14.     this.state = {
  15.       action:0,
  16.       a:new Animated.Value(0)
  17.       }
  18.    
  19.     };
  20.   render() {   
  21.     return (
  22.       <View style={styles.container}>
  23.       <Button
  24.       onPress={()=>{
  25.         this.setState({action:this.state.a})
  26.         Animated.timing(
  27.           this.state.a,
  28.          
  29.           {toValue: 360,
  30.           duration: 5000}
  31.          
  32.     ).start()
  33.       }
  34.       }
  35.       style={styles.btn}
  36.       title="moving right"
  37.       color="#841584"
  38.       />
  39.       <Animated.Text  
  40.         style={{fontSize: 25,marginTop: 100,
  41.         transform:[{
  42.         translateX:this.state.action
  43.         },{translateY:this.state.action}]}}>
  44.         我走了88...
  45.       </Animated.Text>
  46.       
  47.       </View>
  48.     );
  49.   }
  50. }
  51. const styles=StyleSheet.create({
  52.   container:{
  53.     flex:1,
  54.     flexWrap: 'wrap',
  55.     backgroundColor: '#f0f0f0',
  56.     alignItems: 'center',
  57.     marginTop: 50
  58.   },
  59.   btn:{
  60.     backgroundColor: 'gray',width: 150,height: 90,
  61.     justifyContent: 'center',
  62.     alignItems: 'center'
  63.   },
  64. })
  65. 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-5-5 11:28

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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