是否可以只向一个方向滚动? 我有一个功能,可以检测用户滚动的方向。
但是我无法弄清楚如何设置标记,如果用户没有回答问题,那么它将不允许他向左滚动?
谢谢
答案 0 :(得分:1)
您可以使用react-native-directed-scrollview
软件包
包装: https://www.npmjs.com/package/react-native-directed-scrollview
此软件包具有scrollTo({x: 100, y: 100, animated: true})
方法。
如果您将x轴坐标限制为您的条件,则可以。
所以尝试这样的事情,
if(isAnswered == false){
scrollTo({x: /*x-axis position*/, y: /*y-axis position*/, animated: true})
}
注意:您可以将false
传递给animated
参数。这是可选的。
答案 1 :(得分:0)
如果您使用默认的本机scrollview
,则可以轻松启用或禁用它
<ScrollView
scrollEnabled ={this.state.shouldScorll}
>
...
</ScrollView>
但是我不认为可以将方向设置为始终垂直向下
答案 2 :(得分:0)
我创建了一个小示例,仅允许向右滚动。当然,该示例可以适于允许在特定条件下向左滚动。在代码中,我标记了添加这种条件的位置。
该示例包括两个主要部分。
检测滚动方向
请参阅代码注释以获取解释
handleScroll(event){
// WIDTH originates from Dimensions.get('screen').width
const endOfView = event.nativeEvent.contentSize.width - WIDTH;
const positionX = event.nativeEvent.contentOffset.x;
const positionY = event.nativeEvent.contentOffset.y;
// check if we are scrolling left, also detect if we are at the end of the scrollview
// MARKED: check other conditions here to allow scrolling again
if(this.state.lastPositionX > positionX && endOfView > positionX){
// we are scrolling left, disable scroll, reset the current position
this.setState({ lastPositionX: positionX, lastPositionY: positionY, allowScroll: false });
// scroll back to last valid position. Important! Otherwise users may be able to scroll left
this._scrollview.scrollTo({x: this.state.lastPositionX, y: this.state.lastPositionY});
//call the timer to enable scroll again
this.callTimer();
}else{
// we are scrolling right, everthing is fine
this.setState({ lastPositionX: positionX, lastPositionY: positionY });
}
}
再次启用滚动:
我们正在使用计时器在指定的时间后再次启用滚动。
timerFn() {
// clear the timer again, otherwise the timer will fire over and over again
clearInterval(this.state.timer);
//enable scroll and reset timer
this.setState({allowScroll: true, timer: null });
}
callTimer() {
if (this.state.timer == null ){
// no timer is available, we create a new one. Maybe you have to fine tune the duration
let timer = setInterval(() => this.timerFn(), 1000);
this.setState({timer});
}
}
渲染:
<SafeAreaView style={styles.container}>
<ScrollView
horizontal
scrollEventThrottle={15}
scrollEnabled={this.state.allowScroll}
onScroll={(event) => this.handleScroll(event)}
ref={view => this._scrollview = view}
>
<View style={{width: WIDTH, backgroundColor: 'red'}} />
<View style={{width: WIDTH, backgroundColor: 'green'}} />
<View style={{width: WIDTH, backgroundColor: 'blue'}} />
</ScrollView>
</SafeAreaView>