我正在尝试找出一种方法来暂时(即在单个拖动手势期间)禁用 UITableView
上的滚动,然后重新启用它以使其选择在它停止的地方。
我的原因是我有一个手势识别器来监控拖动,如果用户将手指拖动到表格顶部上方,我想用手指向上调整表格的大小,到一个点,然后停止调整大小并再次继续滚动。
当然,我不希望表格在调整大小时滚动,因为这有效地实现了滚动本身(通过移动整个表格 View 而不是内部可滚动内容),但是我不知道如何这样做的方式是允许手势在某个点之后再次生效(或者如果用户在表格上向下拖动)。
有没有办法暂时禁用/阻止手势而不导致它失败或彻底取消?
也许我可以编写一个 UITableView
的子类,它可以拦截手势并根据需要忽略它们。我应该重写什么方法来做到这一点?
更新:
我最终以不同的方式解决了这个问题,即在每次手势更改时简单地调整表格 View 的 contentOffset
。我担心这可能看起来很“紧张”,但它实际上工作得非常顺利。不过,我会留下这个问题,因为我仍然很好奇这是否可以做到。
应@BrunoGalinari 的要求,这是我在 UITableView
上处理平移手势而不破坏表格 View 的内在滚动的主要部分。
tableViewExpanded
是在两种布局状态(展开与否)之间切换并适当调整 bottomViewHeightConstraint
常量的本地属性。将其设置为自身只会将约束重新调整为两个有效值之一,因为它在平移期间也会受到影响。
- (void)handlePanUIPanGestureRecognizer*)sender {
static CGFloat initialBottomViewY;
static CGFloat initialTableViewContentOffsetY;
static CGFloat initialTouchPointY;
CGPoint touchPoint = [sender locationInView:self.view];
CGFloat splitOffset = touchPoint.y - initialBottomViewY;
BOOL inEffect = ( sender == self.tableViewPan && touchPoint.y < initialBottomViewY ) || ( sender == self.mapViewPan && touchPoint.y > initialBottomViewY );
switch ( sender.state ) {
case UIGestureRecognizerStateBegan: {
initialBottomViewY = self.bottomView.y;
initialTableViewContentOffsetY = self.tableView.contentOffset.y;
initialTouchPointY = touchPoint.y;
break;
}
case UIGestureRecognizerStateEnded: {
self.dragVelocity = [sender velocityInView:self.view].y;
if ( inEffect ) {
if ( ABS( splitOffset ) > 60.f ) { // adjust
if ( sender == self.mapViewPan && touchPoint.y > initialBottomViewY )
self.tableViewExpanded = NO;
else if ( sender == self.tableViewPan && touchPoint.y < initialBottomViewY )
self.tableViewExpanded = YES;
else
self.tableViewExpanded = self.tableViewExpanded;
} else
self.tableViewExpanded = self.tableViewExpanded; // spring back
}
break;
}
case UIGestureRecognizerStateChanged: {
if ( inEffect ) {
self.tableView.contentOffset = CGPointMake( self.tableView.contentOffset.x, initialTableViewContentOffsetY + initialTouchPointY - initialBottomViewY );
self.bottomViewHeightConstraint.constant = self.view.height - touchPoint.y;
self.annotationToSelect = nil;
[self adjustMapAnimated:NO];
}
break;
}
default: {
break;
}
}
}
这是窗口的外观,以了解放置方式:
关于ios - 在拖动期间暂时禁用 UITableView 滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28376493/
欢迎光临 OGeek|极客世界-中国程序员成长平台 (http://ogeek.cn/) | Powered by Discuz! X3.4 |