AnimationTing

本文介绍了一个使用React Native实现的简单旋转动画案例。通过定义Animated.Value并结合timing动画方法,实现了一张图片的无限循环旋转效果。文章提供了完整的代码示例及运行效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

完整代码:

AnimationTing.js:

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

const IMG_URI = 'https://s3.amazonaws.com/media-p.slid.es/uploads/alexanderfarennikov/images/1198519/reactjs.png';

export default class AnimationTing extends Component {
  constructor(props) {
    super(props);
    //使用 ** Animated.Value** 声明了一个 spinValue 变量,并传了一个 0 作为初始值
     this.spinValue = new Animated.Value(0);
  }
  spin () {
       this.spinValue.setValue(0);//this.spinValue 重置成 0
       Animated.timing(
              this.spinValue,
         {
             toValue: 1,//终值
             duration: 4000,//一次动画的持续时间
             easing: Easing.linear,//缓存函数
             delay: 0 //延迟执行的时间
         }
      ).start(() => this.spin());
      //调用 start(),并将 this.spin 作为回调传递给 start,它将在(一次)动画完成之后调用,这也是创建无穷动画的一种基本方式
  }
  componentDidMount() {
       this.spin();                         // 开始执行动画
  }
  render () {
               //inputRange 和 outputRange 参数给interpolate 方法,并分别赋值为 [0,1] 和 &[‘0deg’, ‘360deg’] 例 将数值 01 映射到了 0deg360deg
         const spin = this.spinValue.interpolate({
                inputRange: [0, 1],
                outputRange: ['0deg', '360deg'] });
        return (
            <View style={styles.container}>
                  <Animated.Image
                        style={{
                            width: 227,
                            height: 200,
                            transform: [{rotate: spin}] }}
                            source={{uri: IMG_URI}}/>
                  <View></View>         
             </View>
         )
    }
}

const styles = StyleSheet.create({
  container: {
    marginTop: 200,            
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    alignSelf : 'center',
  }
});
使用:

import React from 'react';
import {
   AppRegistry,
   View,
   Text,
   StyleSheet,
   Animated,
} from 'react-native';
import AnimationTing from './AnimationTing';

class MyFirstProject extends React.Component{

    render() {
        return (
             <View>
                 <AnimationTing></AnimationTing>
             </View>
        );
    }
}

AppRegistry.registerComponent('MyFirstProject', ()=> MyFirstProject);
效果图:




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值