React Native Animated 基于多个值插入不透明度
React Native Animated interpolate opacity based on multiple values
我有一个 React Native Animated.view 组件,我想根据滚动视图的位置对其不透明度进行插值。但是,我想使用两个值(x 和 y)而不是一个来插入不透明度。
<Animated.View
style={[
{
opacity: this.state.scrollX.interpolate({
inputRange: [0, 414, 828],
outputRange: [0, 1, 1]
})
},
{
opacity: this.state.scrollY.interpolate({
inputRange: [-168, -167, -166, -85, -84],
outputRange: [1, 1, 1, 0, 0]
})
}
]}
>
<Text>Content....</Text>
</Animated.View>
这当然行不通,因为一个不透明度值会覆盖另一个,但它清楚地表明了我想要实现的目标。
你可以用 Animated.add() 来代替它。
<Animated.View
style={[
{
opacity: Animated.add(scrollX, scrollY).interpolate({
inputRange: [],
outputRange: []
})
},
]}
>
我有一个 React Native Animated.view 组件,我想根据滚动视图的位置对其不透明度进行插值。但是,我想使用两个值(x 和 y)而不是一个来插入不透明度。
<Animated.View
style={[
{
opacity: this.state.scrollX.interpolate({
inputRange: [0, 414, 828],
outputRange: [0, 1, 1]
})
},
{
opacity: this.state.scrollY.interpolate({
inputRange: [-168, -167, -166, -85, -84],
outputRange: [1, 1, 1, 0, 0]
})
}
]}
>
<Text>Content....</Text>
</Animated.View>
这当然行不通,因为一个不透明度值会覆盖另一个,但它清楚地表明了我想要实现的目标。
你可以用 Animated.add() 来代替它。
<Animated.View
style={[
{
opacity: Animated.add(scrollX, scrollY).interpolate({
inputRange: [],
outputRange: []
})
},
]}
>