OStack程序员社区-中国程序员成长平台

标题: ios - 在拖动期间暂时禁用 UITableView 滚动 [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-13 05:16
标题: ios - 在拖动期间暂时禁用 UITableView 滚动

我正在尝试找出一种方法来暂时(即在单个拖动手势期间)禁用 UITableView 上的滚动,然后重新启用它以使其选择在它停止的地方。

我的原因是我有一个手势识别器来监控拖动,如果用户将手指拖动到表格顶部上方,我想用手指向上调整表格的大小,到一个点,然后停止调整大小并再次继续滚动。

当然,我不希望表格在调整大小时滚动,因为这有效地实现了滚动本身(通过移动整个表格 View 而不是内部可滚动内容),但是我不知道如何这样做的方式是允许手势在某个点之后再次生效(或者如果用户在表格上向下拖动)。

有没有办法暂时禁用/阻止手势而不导致它失败或彻底取消?

也许我可以编写一个 UITableView 的子类,它可以拦截手势并根据需要忽略它们。我应该重写什么方法来做到这一点?

更新:

我最终以不同的方式解决了这个问题,即在每次手势更改时简单地调整表格 View 的 contentOffset。我担心这可能看起来很“紧张”,但它实际上工作得非常顺利。不过,我会留下这个问题,因为我仍然很好奇这是否可以做到。



Best Answer-推荐答案


应@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;
        }
    }
}

这是窗口的外观,以了解放置方式:

enter image description here

关于ios - 在拖动期间暂时禁用 UITableView 滚动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28376493/






欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) Powered by Discuz! X3.4