日魂月魄

导航

objective-c UITableview 自定义滑操(原创)

本人开发的开发者技术变现资源聚集地,大家支持下,下面是网址

https://www.baiydu.com

 

 

滑动删除在当前的ios版本中已经支持了,但是遇到复杂的比如,滑动后的功能有多个,并不是删除功能,那么你就得自己写,我说得没错吧..........

 其实关于滑删嘛,在以前的项目中也遇到过,当时ios还不支持滑删,所以只有看自己的了,当时我是在code4app上下的案例修改的,所以此功能以前也做好过,但是可悲的是android那边的程序员在网上下来案例后修改不出项目需求效果,固这个功能最后被项目经历是阉割了。。。。。

岁月如梭,公司已换了多个呵呵.....

 当前公司这个项目又涉及到cell滑动功能操作,虽然当前ios已自带了滑动删除,但是他并不能完全满足当前项目要求,所以又得看自己得了,这次我没打算去网上下案例,因为这个项目时间并不那么紧迫,所以就自己写了哦。。。。。。。。。。 (下面进入主题)

 

今天我给大家讲解的重点是我实现这个功能的思路,想让大家理解的也是我实现的思路, 当我用这个思路实现这个功能后,再想想上次做这个功能时,从网上下那案例是多么的不值得我留恋.....

 先贴图我公司实现的功能如下:

   

 懂的人都知道,一看这玩意用ios自带的滑操是不行的呵呵 

首先内容展示的控件是UITableView

三个cell其实是一个cell的三种不同状态,如果这个你都不知道,你下面就别继续看了...

第一个为选中状态:就是用户要提交的地址  

第二个为没选中状态:

第三个就是我们cell滑动后出现的效果,当这部分功能滑动出现后,我们需要隐藏掉小圆圈button

 

下面就是我这篇文章要讲的重点了

cell中展示的每一个控件,都是add 到一个scrollview中,然后将scrollview add到cell中

 cell滑动后展示的宽度(70就是cell滑动后延伸的宽度),需要增加到scrollview的 contentsize中去.下面是代码   

   

    UIScrollView *ContentView=[[UIScrollView alloc]initWithFrame:CGRectMake(0, 0, DEVICE_Width , 79)];

   [ContentView setContentSize:CGSizeMake(DEVICE_Width+70,79 )];

    [ContentView setBackgroundColor:[UIColor whiteColor]];

    [ContentView setShowsHorizontalScrollIndicator:NO];

   ContentView.scrollEnabled=YES;

  

  

先将scrollview的代理引入 <UIScrollViewDelegate>

然后需要实现下面的代理: 


//ScrollView代理
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    _recordCurrentOffsetX=scrollView.contentOffset.x;
    
}


//拖拽开始和腿拽结束,这两个代理都必须加上,否则无法执行enddragging
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
    
}

- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
    if (!decelerate)
    {
        NSArray *backGroundViewChilrendArray=scrollView.subviews;
        
        if (_recordCurrentOffsetX<70) {
            [scrollView setContentOffset:CGPointMake(0, scrollView.contentOffset.y) animated:YES];
            
            for (int i=0;i<backGroundViewChilrendArray.count; i++) {
                if ([[backGroundViewChilrendArray objectAtIndex:i] isKindOfClass:[UIButton class]]) {
                    UIButton *button=[backGroundViewChilrendArray objectAtIndex:i] ;
                    if (button.tag==11010) {
                        button.hidden=NO;
                        break;
                        
                    }
                }
            }
            
        }
        else
        {
            
            for (int i=0;i<backGroundViewChilrendArray.count; i++) {
                if ([[backGroundViewChilrendArray objectAtIndex:i] isKindOfClass:[UIButton class]]) {
                    UIButton *button=[backGroundViewChilrendArray objectAtIndex:i] ;
                    if (button.tag==11010) {
                        button.hidden=YES;
                        break;
                        
                    }
                }
            }
        }
        
    }
    
}


- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView
{
    
  
    
}
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
{
       NSArray *backGroundViewChilrendArray=scrollView.subviews;
    
    if (_recordCurrentOffsetX<70) {
        [scrollView setContentOffset:CGPointMake(0, scrollView.contentOffset.y) animated:YES];
        
        for (int i=0;i<backGroundViewChilrendArray.count; i++) {
            if ([[backGroundViewChilrendArray objectAtIndex:i] isKindOfClass:[UIButton class]]) {
                UIButton *button=[backGroundViewChilrendArray objectAtIndex:i] ;
                if (button.tag==11010) {
                    button.hidden=NO;
                    break;
                    
                }
            }
        }

    }
    else
    {
        
        for (int i=0;i<backGroundViewChilrendArray.count; i++) {
            if ([[backGroundViewChilrendArray objectAtIndex:i] isKindOfClass:[UIButton class]]) {
                UIButton *button=[backGroundViewChilrendArray objectAtIndex:i] ;
                if (button.tag==11010) {
                    button.hidden=YES;
                    break;
                    
                }
            }
       }
    }
    
}
   if (_recordCurrentOffsetX<70) {}

 _recordCurrentOffsetX:是一个记录uiscrollview偏移量x坐标的cgfloat变量字段

上面这句代码是判断当前scrollview偏移量的 ,上面代码中的 <70 ------ 70就是我们uiscrollview增加出的那部分偏移量宽度 存放滑删功能的部分。

如果偏移量小于70了,我们就将偏移量设置为0,不展示出滑动删除部分


 

 

for (int i=0;i<backGroundViewChilrendArray.count; i++) {
                if ([[backGroundViewChilrendArray objectAtIndex:i] isKindOfClass:[UIButton class]]) {
                    UIButton *button=[backGroundViewChilrendArray objectAtIndex:i] ;
                    if (button.tag==11010) {
                        button.hidden=NO;
                        break;
             }
}

 上面一部分代码是当执行完uiscrolview代理后,我们根据是否显示了滑操扩展部分来隐藏或显示 小圆圈按钮.

 

 

最开始我用了手势来做这个功能,cell add的是UIView,不是scrollview,然后给UIView增加相应的手势, 逻辑相对复杂,做出来之后有一个bug,就是当我上拉下拉这个uitableview刷新时(根本不怎么执行,而是执行contentview上绑定的手势),如果我将border的宽度设置为0,那么就完全不执行了,为什么我想我不说各位也知道。而且以前我下那案例也是用手势写的,那个案例虽然解决了,我用手势的困惑,但是体验完全不好,而且cell上add了很多层,实现代码之多。。。。我今天讲的重点就是:当项目涉及到自己写cell的滑操功能时,可选我这思路,只需要在UITableView的每个cell中add一个UIScrollView,然后将所有展示的内容控件都add到scrollview上,然后将滑动多出的宽度,增加到UIScrollView的contensize中去,再调几个代理 就完全搞定呵呵.....(此cell滑操方法我当前好像还没见网络上有人使用过,大多是使用手势)

 

 本人创业做的一款androidApp, 下载量已经有2000多万,各种当前热门的网络手机奖励红包全部集成,另外还有热门电影和淘宝高额优惠券!很适合各类型的用户。

 

  

 

 

 

 

 

 

posted on 2015-07-19 14:24  L-H  阅读(1055)  评论(0编辑  收藏  举报