iOS 解决cell滑动删除和scrollView左右滑动之间的冲突

//联系人:石虎  QQ: 1224614774昵称:嗡嘛呢叭咪哄


项目需求是这样的:需要在scrollView上加载三个TableView,第一个TableView的cell又要实现左滑删除功能。最后的解决效果图如下:


效果图.gif

首先分析需求:我是需要在第一个TableView上实现左滑删除cell功能,这需求直接把网上的给出的解决方案:(通过设置手势代理,实现view相应多个手势)给拒之门外。
所以我采取了个比较笨的方法:
1、一上来把scrollView的enable属性设置成no,然后给当前view加一个屏幕边缘滑动手势,通过判断这个手势的移动来动态改变scrollView的偏移量,当手势结束的时候,判断scrollView的偏移量:如果偏移量大于屏幕一半,则打开scrollView的enable属性,关闭手势的enable属性;

// 如果是第一页的话:
// 判断偏移量:
// 如果偏移量>屏幕宽一半:scrollView偏移量为当前scrollView的宽度,scrollView响应,手势不响应

// 如果不是第一页的话:
// scrollView一直相应
- (void)panGrAction:(UIScreenEdgePanGestureRecognizer *)sender
{
//    NSLog(@"====");

    if (self.scrollView.contentOffset.x<self.view.bounds.size.width) {
        CGPoint first = [sender translationInView:self.view];
        self.scrollView.contentOffset = CGPointMake(fabs(first.x), 0);
    }
    if (sender.state == UIGestureRecognizerStateBegan) {
        NSLog(@"开始");
    }else if (sender.state == UIGestureRecognizerStateEnded){
        NSLog(@"结束");
        NSInteger count = self.scrollView.contentOffset.x / self.view.bounds.size.width;

        CGFloat rest_point = self.scrollView.contentOffset.x - (self.view.bounds.size.width * count);
        if (rest_point > self.view.bounds.size.width * 0.5) {
            CGFloat off_x;
            if (self.scrollView.contentSize.width > self.view.bounds.size.width * (count+1)) {
                off_x = self.view.bounds.size.width * (count+1);
            }else{
                off_x = self.view.bounds.size.width * count;
            }
            self.scrollView.contentOffset = CGPointMake(off_x, 0);
        }else{
            self.scrollView.contentOffset = CGPointMake(self.view.bounds.size.width * count, 0);
        }


        if (!(self.scrollView.contentOffset.x<self.view.bounds.size.width)) {
            self.scrollView.scrollEnabled = YES;
            self.panGr.enabled = NO;
        }
    }
}

2、在通过监听scrollView的结束减速方法监听scrollView的偏移量,当发现scrollView偏移到第一页的时候,再关闭scrollView的enable属性,打开手势的enable属性。

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
    NSLog(@"结束减速");
    if ((self.scrollView.contentOffset.x<self.view.bounds.size.width)) {
        self.scrollView.scrollEnabled = NO;
        self.panGr.enabled = YES;
    }
}
扩展1

自定义设置cell的滑动删除
从iOS8以后,我们可以采取下面的这个方法

- (BOOL)tableView:(UITableView *)tableView canEditRowAtIndexPath:(NSIndexPath *)indexPath
{
    return YES;
}

-(NSArray<UITableViewRowAction*>*)tableView:(UITableView *)tableView editActionsForRowAtIndexPath:(NSIndexPath *)indexPath
{

    UITableViewRowAction *rowAction = [UITableViewRowAction rowActionWithStyle:UITableViewRowActionStyleDefault title:@"取消收藏" handler:^(UITableViewRowAction * _Nonnull action, NSIndexPath * _Nonnull indexPath) {
        NSLog(@"收藏点击事件,%ld", indexPath.row);
    }];

    UITableViewRowAction *rowAction2 = [UITableViewRowAction rowActionWithStyle:UITableViewRowActionStyleDefault title:@"顶置" handler:^(UITableViewRowAction * _Nonnull action, NSIndexPath * _Nonnull indexPath) {
        NSLog(@"顶置按钮点击事件,%ld", indexPath.row);
    }];

    rowAction.backgroundColor = kRandomColor;

    NSArray *arr = @[rowAction,rowAction2];

    return arr;
}
扩展2

如果你的需求是最后一个TableView实现cell的滑动删除,那么直接实现一个代理方法,并且在scrollView定义的时候,加上两句代码,即可完成

// 重写下面方法,为了让Scrollview可以识别多个手势
// 此方法返回YES时,手势事件会一直往下传递,不论当前层次是否对该事件进行响应
- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer
{
    return gestureRecognizer.state != 0 ? YES : NO;
}

// scrollView需要设置的地方
        [scrollView setDelaysContentTouches:NO];
        [scrollView setCanCancelContentTouches:NO];

谢谢!!!
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值