iOS-UITableView HeaderView随Cell一起移动

我们在使用TableView的时候,有时会设置HeaderView,当我们滑动的时候,HeaderView不会随Cell滑出屏幕,而是会固定到导航栏下面。今天我们要实现HeaderView随滑动一起滑出屏幕显示。

方法:通过设置TableView的EdgeInset使HeaderView向上偏移,从而隐藏HeaderView,那么我们只需要设置EdgeInset的顶部数据就好了,我们需要计算出需要设置多少?

 

TableView继承自ScrollView,当滑动的时候,会有一个偏移量 contentOffSet。对于第一个Section来说,我们需要将EdgeInset的顶部值设置为contentOffSet即可,之后的Section设置为HeaderView的高度即可

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    CGFloat headerViewHeight = 80.0;
    
    if (scrollView.contentOffset.y < headerViewHeight && scrollView.contentOffset.y >= 0) {
        scrollView.contentInset = UIEdgeInsetsMake(- scrollView.contentOffset.y, 0, 0, 0);
    } else if (scrollView.contentOffset.y >= headerViewHeight) {
        scrollView.contentInset = UIEdgeInsetsMake(- headerViewHeight, 0, 0, 0);
    }
}

 

posted @ 2019-09-21 08:42  sims  阅读(847)  评论(0编辑  收藏  举报