码迷,mamicode.com
首页 > 移动开发 > 详细

iOS TabeView 头视图和尾视图不滑动的实现

时间:2015-09-25 20:03:56      阅读:201      评论:0      收藏:0      [点我收藏+]

标签:

因项目有需求不能让section中的头尾视图滑动,顾根据网上的一些资料和自己整理的思路,已实现了不滑动效果,上代码,啥都说了,搞了2个小时都是泪。。。。

1.创建一个tableview

_mainTableView = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, kScreenWidth, kScreenHeight - 64) style:UITableViewStylePlain];//带导航栏-64
_mainTableView.backgroundColor = [UIColor clearColor];
_mainTableView.dataSource = self;
_mainTableView.delegate  = self;
_mainTableView.sectionHeaderHeight = 40;//headView高
_mainTableView.sectionFooterHeight = 64;//footerView高
_mainTableView.contentInset = UIEdgeInsetsMake(0, 0, -64, 0);//加载的时候需要底部视图

2. 实现scrollView代理协议

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    CGFloat sectionHeaderHeight = 64;//设置headView和footerView的最大值

    if (scrollView.contentOffset.y<=sectionHeaderHeight&&scrollView.contentOffset.y>=0) {//headerView刚开始的滑动
        scrollView.contentInset = UIEdgeInsetsMake(-scrollView.contentOffset.y, 0, -sectionHeaderHeight, 0);
    }
    else if (scrollView.contentOffset.y>=sectionHeaderHeight && scrollView.contentOffset.y + 64 < scrollView.contentSize.height - scrollView.frame.size.height) {//中间的滑动
        scrollView.contentInset = UIEdgeInsetsMake(-sectionHeaderHeight, 0, -sectionHeaderHeight, 0);
        
    }else if(scrollView.contentOffset.y + 64 >= scrollView.contentSize.height - scrollView.frame.size.height && scrollView.contentOffset.y < scrollView.contentSize.height - scrollView.frame.size.height){//footerView结束的时候的滑动
        scrollView.contentInset = UIEdgeInsetsMake(0, 0,-(scrollView.contentSize.height - scrollView.frame.size.height - scrollView.contentOffset.y) , 0);
    }
}

 

iOS TabeView 头视图和尾视图不滑动的实现

标签:

原文地址:http://www.cnblogs.com/yyzanll/p/4839061.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!