我尝试制作一个循环无限的脉冲动画视图。以下视图实现了该动画。但我想在动画时更新动画持续时间。实际上它不会更新循环动画。向 useEffect 依赖项添加持续时间无法正常工作,因为它刷新了当前动画圆圈。
像这个(来源):
这是我当前的代码:
const LoopPulseView = (props: {duration: number;}) => {
const nbPulse = 6;
const [pulses, setPulses] = useState([] as any);
const [duration, setDuration] = useState(props.duration);
const [delay] = useState(duration / nbPulse);
useEffect(() => {
setDuration(props.duration);
}, [props.duration]);
const scaleOut = {
0: {
opacity: 1,
scale: 1,
},
1: {
opacity: 0,
scale: 1.5,
},
};
useEffect(() => {
const newPulses = [];
for (let p = 0; p < nbPulse; p++) {
const view = (
<Animatable.View
key={p}
duration={duration}
delay={delay * p}
style={[styles.pulse, pulseStyle]}
animation={scaleOut}
iterationCount={'infinite'}
useNativeDriver={true}
/>
);
newPulses.push(view);
}
setPulses(newPulses);
}, []);
return (
<View style={containerStyle}>
<View style={pulseWrapperStyle}>
{pulses.map((pulse: any) => {
return pulse;
})}
</View>
</View>
);
};
export default LoopPulseView;