• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - 在拖动期间暂时禁用 UITableView 滚动

[复制链接]
菜鸟教程小白 发表于 2022-12-13 05:16:37 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我正在尝试找出一种方法来暂时(即在单个拖动手势期间)禁用 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/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap