我正在尝试使一个Slider根据Lottie动画的Progress值更新其位置。
滑块可以控制Lottie的进度,但是如果我按下“ Play Lottie”按钮,它不会更新其位置。如何让组件访问Lottie的Progress值并根据Progress值进行更新?我希望此值是公共的或可从其他组件访问的。似乎外部组件无法访问Progress值。我尝试了“ addListener”,但是它什么也没做。
一般来说,我是本机和编码的新手。我环顾了StackOverflow好多天了,找不到任何东西。
export default class HomeScreen extends React.Component {
constructor(props) {
super(props);
this.playLottie.bind(this);
this.playLottie.bind(this);
this.pauseLottie.bind(this);
this.state = {
progress: new Animated.Value(0),
pausedProgress: 0
};
this.state.progress.addListener(({ value }) => this._value = value); // I tried to use a Listener so that components can Listen to the Progress of the lottie animation...
}
playLottie = () => {
Animated.timing(this.state.progress, {
toValue: 1,
easing: Easing.linear,
}).start;
}
//Shows real-time value of the Slider. Console output works too, updates when I use slider in realtime.
realProgress = (value) => {
console.log("realProgress", value);
this.setState({ pausedProgress: value });
};
//Used by Slider, sets Progress of Lottie
setProgress = (value) => {
this.state.progress.setValue(value);
console.log("setProgress", value)
};
render() {
return (
<View style={styles.container}>
<ScrollView style={styles.container} contentContainerStyle={styles.contentContainer}>
//The Lottie Animation:
<LottieView
ref={animation => { this.animation = animation; }}
source={require('../assets/lottie-animations/animation.json')}
style={{ height: 400, width: '100%' }}
loop={false}
progress={this.state.progress}
/>
<Button
onPress={this.playLottie}
title="Play Lottie"
/>
<Button
onPress={this.pauseLottie}
title="Pause Lottie"
/>
//The slider that controls the progress of the Lottie Animation:
<Slider
style={{ width: '100%', height: 40 }}
minimumValue={0}
maximumValue={1}
onValueChange={(value) => this.setProgress(value)}
/>
//Tried using Text to display the real-time value of the Lottie animation progress. Doesn't display any numbers.
<Text>{'Slider Position: '}{Slider.onValueChange}</Text>
</ScrollView>
</View>
);
}
}
相关依赖项:
"dependencies": {
"expo": "~36.0.0",
"lottie-react-native": "^3.3.2",
"react": "~16.9.0",
"react-lottie": "^1.2.3",
"react-native": "https://github.com/expo/react-native/archive/sdk-36.0.0.tar.gz",
},
博览会版本:3.13.8
Windows 10
最佳答案
使用命令式API要简单得多。
建设者
constructor(props) {
super(props);
this.state = {
progress: 0,
}
}
使用componentDidMount进行测试。
play(startFrame, EndFrame).
您需要找出要与滑块一起使用的动画结束帧号。不断更改端帧,直到播放到最后为止-这就是您的号码。 componentDidMount() {
// Or set a specific startFrame and endFrame with:
// this.animation.play(0, 100);
}
一个箭头函数,它返回值并更改进度状态。您可以将动画帧速率设置为在同一帧上开始和停止。
animateIt = (value) => {
//this.animation.reset();
this.setState({progress: value})
this.animation.play(value, value);
}
您的乐透组件
<LottieView
ref={animation => {
this.animation = animation;
}}
style={{ height: 400, width: '100%' }}
source={require('../assets/lottie-animations/animation.json')}
/>
滑块将最大值设置为等于动画的最后一帧。在我的情况下是40。滑块也调用箭头函数并返回值。
<Slider
style={{ width: '100%', height: 40 }}
minimumValue={0}
maximumValue={40}
onValueChange={(value) => this.animateIt(value)}
/>