项目需求是这样的:需要在scrollView上加载三个TableView,第一个TableView的cell又要实现左滑删除功能。最后的解决效果图如下:
首先分析需求:我是需要在第一个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];
最后demo地址