报告:目前完成度【 0.5/3 】,预计上线时间:【 未知 】 【问卷调查】
英文链接源链接 [6862]
contenteditable="true"

React Native - Animations 介绍

在本章中,我们将向您展示如何在React Native中使用 LayoutAnimation 。

动画组件

我们将 myStyle 设置为状态的属性。此属性用于设置 PresentationalAnimationComponent 中的元素的样式。

我们还将创建两个函数- expandElement 和 collapseElement 。这些功能将从状态更新值。第一个将使用 spring 预设动画,而第二个将具有 linear 预设。我们也将这些作为道具传递。 Expand 和 Collapse 按钮调用 expandElement()和 collapseElement()函数。

在此示例中,我们将动态更改框的宽度和高度。由于 Home 组件相同,因此我们只更改 Animations 组件。

在此示例中,我们将动态更改框的宽度和高度。由于 Home 组件相同,因此我们只更改 Animations 组件。

App.js

import React, { Component } from 'react'
import { View, StyleSheet, Animated, TouchableOpacity } from 'react-native'

class Animations extends Component {
   componentWillMount = () => {
      this.animatedWidth = new Animated.Value(50)
      this.animatedHeight = new Animated.Value(100)
   }
   animatedBox = () => {
      Animated.timing(this.animatedWidth, {
         toValue: 200,
         duration: 1000
      }).start()
      Animated.timing(this.animatedHeight, {
         toValue: 500,
         duration: 500
      }).start()
   }
   render() {
      const animatedStyle = { width: this.animatedWidth, height: this.animatedHeight }
      return (
         <TouchableOpacity style = {styles.container} onPress = {this.animatedBox}>
            <Animated.View style = {[styles.box, animatedStyle]}/>
         </TouchableOpacity>
      )
   }
}
export default Animations

const styles = StyleSheet.create({
   container: {
      justifyContent: 'center',
      alignItems: 'center'
   },
   box: {
      backgroundColor: 'blue',
      width: 50,
      height: 100
   }
})
点我分享笔记