- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试制作一个动画,从左上角的彩色方 block 开始。单击它会将方 block 移动到屏幕中心,同时将其缩放到两倍大小。然后它应该翻转并显示背面。当我尝试在模拟器上加载应用程序时,出现此错误:
这是代码:
import React, {Component} from 'react';
import
{
StyleSheet,
View,
Text,
Animated,
Dimensions,
TouchableWithoutFeedback
}
from 'react-native';
export default class App extends Component {
state = {
animation: new Animated.ValueXY(),
scaleAnimation: new Animated.Value(1),
rotateAnimation: new Animated.Value(0)
};
startAnimation = () => {
const {width, height} = Dimensions.get("window");
Animated.parallel([
Animated.timing(this.state.animation.y, {
toValue: (height / 2) - (this._height / 2),
duration: 500,
useNativeDriver: true
}),
Animated.timing(this.state.animation.x, {
toValue: (width / 2) - (this._width / 2),
duration: 500,
useNativeDriver: true
}),
Animated.timing(this.state.scaleAnimation, {
toValue: 2,
duration: 500,
useNativeDriver: true
})
]).start(() => {
Animated.timing(this.state.rotateAnimation, {
toValue: 180,
duration: 500,
useNativeDriver: true
}).start();
})
}
saveDimensions = (e) => {
this._width = e.nativeEvent.layout.width;
this._height = e.nativeEvent.layout.height;
}
render() {
const animatedStyles = {
transform: [
{
translateX: this.state.animation.x
},
{
translateY: this.state.animation.y
},
{
scale: this.state.scaleAnimation
}
]
}
const frontInterpolate = this.state.rotateAnimation.interpolate({
inputRange: [0, 180],
outputRange: ['0deg', '180deg']
})
const backInterpolate = this.state.rotateAnimation.interpolate({
inputRange: [0, 180],
outputRange: ['180deg', '360deg']
})
const frontAnimatedStyle = {
transform: [
{
rotateY: this.frontInterpolate
}
]
}
const backAnimatedStyle = {
transform: [
{
rotateY: this.backInterpolate
}
]
}
return (
<View style={styles.container}>
<TouchableWithoutFeedback
onPress={() => this.startAnimation()}
onLayout={() => this.saveDimensions()}
>
<View>
<Animated.View
style={[styles.box, animatedStyles, frontAnimatedStyle]}
>
<Text>Front</Text>
</Animated.View>
<Animated.View
style={[backAnimatedStyle, styles.box, styles.boxBack]}
>
<Text>Back</Text>
</Animated.View>
</View>
</TouchableWithoutFeedback>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
//alignItems: 'center',
//justifyContent: 'center',
},
box: {
width: 150,
height: 150,
backgroundColor: 'tomato',
position: 'absolute',
top: 0,
left: 0,
},
boxBack: {
backgroundColor: 'green',
},
});
我什至不知道动画是否会起作用,因为如果没有出现此错误,它甚至无法加载。
最佳答案
这是零食https://snack.expo.io/@ziyoshams/frisky-watermelon ,并尝试检查代码。您的错误来自 onLayout
,但修改了很多。这是代码:
import React, { Component } from 'react';
import {
StyleSheet,
View,
Text,
Animated,
Dimensions,
TouchableWithoutFeedback,
} from 'react-native';
const { width, height } = Dimensions.get('window');
export default class App extends Component {
state = {
animation: new Animated.ValueXY(),
scaleAnimation: new Animated.Value(1),
box1RotateAnimation: new Animated.Value(0),
box2RotateAnimation: new Animated.Value(0),
};
startAnimation = () => {
Animated.parallel([
Animated.timing(this.state.animation.y, {
toValue: height / 2 - this._height / 2,
duration: 500,
useNativeDriver: true,
}),
Animated.timing(this.state.animation.x, {
toValue: width / 2 - this._width / 2,
duration: 500,
useNativeDriver: true,
}),
Animated.timing(this.state.scaleAnimation, {
toValue: 2,
duration: 500,
useNativeDriver: true,
}),
]).start(() => {
Animated.sequence([
Animated.timing(this.state.box1RotateAnimation, {
toValue: 180,
duration: 500,
useNativeDriver: true,
}),
Animated.timing(this.state.box2RotateAnimation, {
toValue: 180,
duration: 500,
useNativeDriver: true,
}),
]).start();
});
};
saveDimensions = e => {
this._width = e.nativeEvent.layout.width;
this._height = e.nativeEvent.layout.height;
};
render() {
const frontInterpolate = this.state.box1RotateAnimation.interpolate({
inputRange: [0, 180],
outputRange: ['0deg', '90deg'],
});
const backInterpolate = this.state.box2RotateAnimation.interpolate({
inputRange: [0, 180],
outputRange: ['90deg', '0deg'],
});
const parentAnimation = {
transform: [
{
translateX: this.state.animation.x,
translateY: this.state.animation.y,
scale: this.state.scaleAnimation,
},
],
};
const box1Animation = {
transform: [
{
rotateY: frontInterpolate,
},
],
};
const box2Animation = {
transform: [
{
rotateY: backInterpolate,
},
],
};
return (
<View style={styles.container}>
<TouchableWithoutFeedback
onPress={this.startAnimation}
onLayout={this.saveDimensions}>
<Animated.View style={[styles.box, parentAnimation]}>
<Animated.View style={[styles.box1, box1Animation]}>
<Text>Front</Text>
</Animated.View>
<Animated.View style={[styles.box2, box2Animation]}>
<Text>Back</Text>
</Animated.View>
</Animated.View>
</TouchableWithoutFeedback>
</View>
);
}
}
const styles = StyleSheet.create({
container: {
flex: 1,
},
box: {
width: 150,
height: 150,
position: 'absolute',
top: 0,
left: 0,
},
box1: {
width: 150,
height: 150,
backgroundColor: 'tomato',
alignItems: 'center',
justifyContent: 'center',
position: 'absolute',
top: 0,
left: 0,
},
box2: {
width: 150,
height: 150,
backgroundColor: 'green',
alignItems: 'center',
justifyContent: 'center',
position: 'absolute',
top: 0,
left: 0,
},
});
关于javascript - React-native动画: Trying to combine multiple animations; getting error,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56510956/
我正在尝试设计我的输入:文件。以下 SO 问题让我完成了 95% 的任务。区别在于我使用的是 HTML5 multiple=multiple 属性。 How to style "input file"
我一直在进行一项实验,其中多个调查参与者使用可穿戴技术聆听多首音乐来跟踪多条信息,两个例子是 BPM(心率)和 T(体温)。 目标是衡量每首音乐(以用户反馈为特征)对人类情感的影响。 目前,所有数据都
我使用 jquery 添加/删除输入 我使用append为日期/收入添加多个Tr 我还使用另一个附加来添加多个 td 以获取同一日期 Tr 中的收入 我添加多个日期输入,并在此表中添加多个收入输入 我
在 Android 中,有一种方法可以为项目中的所有模块生成签名的 APK。例如。我有以下项目 Project -- Library Module -- Module 1 -- Modul
我有一个用于网站展示的系统。 展览数据可能来自差异表中的多个数据。 喜欢这个设计: Table [ExhibitionType] used for differentiate category. Ta
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我正在使用 UILocalnotification...收到通知时,当应用程序处于事件模式时我打开 viewcontroller...但是如果同时收到多个通知...我如何打开多个 viewcontro
我遇到的问题是一个策略浏览器游戏,它有 7 种类型的值。问题如下: 我在 $_POST 中获得了 7 个不同的值,包括从索引 unit_1 到索引 unit_7。这 7 个值是 0 到 20 之间的整
这个问题已经有答案了: Search Large Text File for Thousands of strings (3 个回答) 已关闭10 年前。 我想在多个文件上“grep”多个正则表达式。
我经常对如何在我的应用程序中解决这个问题感到矛盾。我使用了很多选项,包括: 一个通用的多选 - 这是我最不喜欢和最很少使用的选项。我发现可用性非常糟糕,一个简单的误点击就会毁了你所有的辛勤工作。 “自
以下是 couchbase 中的示例文档之一。 { "name":"abc", "friends":["a","b","c"], "bestfriends":["x","y","z"] }
我有 4 张 table 。 表组 | ID | NAME | 1 Premium 2 Silver 表用户 | ID | group_id | NAME | 1
我正在开发一个使用第三方服务(Facebook、Google 等)对用户进行身份验证的应用程序。我为每个用户提供一个内部 ID(uuid v4),该 ID 与他们的第 3 方 ID 相关联。现在,我的
我是 bicep 新手,一直在努力实现 Bicep 脚本来部署具有许多主题和订阅的 Azure 服务总线。 我添加的每个主题都有可变数量的订阅(例如,通知主题可能有 3 个订阅,但分析主题可能有 2
我是 bicep 新手,一直在努力实现 Bicep 脚本来部署具有许多主题和订阅的 Azure 服务总线。 我添加的每个主题都有可变数量的订阅(例如,通知主题可能有 3 个订阅,但分析主题可能有 2
我必须创建一个大型数据库。它将保存来自 100 多个设备的数据,并不断更新数据库。每 10 秒,每个设备都会更新数据库中的一行。是为每个设备数据建立一个单独的表还是将数据与设备 ID 放在同一个表中更
我需要在 Activity 开始时显示“正在加载”进度对话框,然后在加载完成后显示一些内容。在我的 onresume 中,我有类似这样的代码: loadThread = true; Thread sh
我有一个 html 表单 当我提交表单时,假设对于 id = 1,数量为 5 或 对于 id = 3,数量为 8。如何在java脚本或jquery中获取这些值并将这些信息提交到服务器?我
我正在创建一个 Mozilla 扩展程序,通过单击“转换按钮”(标签:转换)将网页内容转换为其他语言它的标签被转换为英文,以便单击该按钮(标签:英文)内容被转换为原始形式 我尝试为每个选项卡设置属性“
我正在尝试根据 进行搜索 我通过运行代码从 select 中获取值: for($i=0;$i= '$age_from' AND users.user_age = '$age_from' AND u
我是一名优秀的程序员,十分优秀!