iOS开发实践ios 开发iOS开发记录

【微博个人页效果】 |那些人追的干货

2015-07-30  本文已影响12179人  袁峥

前言

由于最近在讲导航控制器的内容,因此更新此次文章,讲述的是个人详情页效果。效果如图:

123.gif

一、分析项目组成架构

二、分析微博个人控制器层次结构

1.一眼望去,首先有个tableView,tableView上边有个头部视图和选项卡视图。

tableView效果:穿透导航条。

穿透效果:

穿透导航条.gif

不能穿透效果:


不能穿透演示.gif

2.头部视图(背景图片+头像)和选项卡视图

效果:头部视图和选项卡视图随着tableView拖动而移动,选项卡视图有悬停效果,拖到某个位置就不移动了。

解决方案:

方案1:头部视图和选项卡视图成为tableView的头部视图(tableHeaderView),但是往上拖动,选项卡视图会消失,因此达不到悬停效果。(pass掉这个方案)

方案2:选项卡视图成为tableView的组头部视图,选项卡悬停了。但是,当用户往下拖动的时候,头部视图不应该往下移动,而是y值原地不动。(pass掉这个方案)

最终方案:头部视图和选项卡视图添加到控制器的view上,并且要盖住tableView.

问题:tableView的内容显示不完全?如何显示?
解决:设置tableView顶部额外间距,就会把内容往下挤。
因为内容需要显示到选项卡下面,因此设置顶部间距为头部视图+选项卡视图高度,244.

    #define headH 200
    #define headMinH 64
    #define tabBarH 44

    _lastOffsetY = -(headH + tabBarH);

    self.tableView.contentInset = UIEdgeInsetsMake(headH + tabBarH, 0, 0, 0);

问题:tableView的内容多往下偏移了一点,这是因为在iOS7之后,导航控制器下的所有UIScrollView顶部都会添加额外的滚动区域64。

Snip20150729_1.png

解决:不需要添加额外的滚动区域,设置控制器的属性。

self.automaticallyAdjustsScrollViewInsets = NO;

三、搭建微博个人页界面

1.最里面存放tableView,占据整个控制器的view

2.然后添加顶部头部视图,高度200,宽度自动拉伸,上左右间距为0.

2.1 顶部背景图片,宽高自动拉伸

2.2 头像 水平居中,距离底部64的高度,宽高固定。

3.选项卡在头部视图下边,高度44,宽度自动拉伸,上左右间距为0.

3.1 选项卡参照顶部视图,利用自动布局,可以让一个控件随着参照控件的改变而改变,以后就能做到移动头部视图,选项卡跟着移动了。

Snip20150730_3.png

四、监听tableView的滚动

Snip20150730_1.png
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    CGFloat offsetY = scrollView.contentOffset.y;

    CGFloat delta = offsetY - _lastOffsetY;

    // 往上拖动,高度减少。
    CGFloat height = headH - delta;

    if (height < headMinH) {
        height = headMinH;
    }

    _headHCons.constant = height;

    // 设置导航条的背景图片
    CGFloat alpha = delta / (headH - headMinH);

    // 当alpha大于1,导航条半透明,因此做处理,大于1,就直接=0.99
    if (alpha >= 1) {
        alpha = 0.99;
    }
    _nameLabel.alpha = alpha;
    // 设置导航条的背景图片
    UIImage *image = [UIImage imageWithColor:[UIColor colorWithWhite:1 alpha:alpha]];
    [self.navigationController.navigationBar setBackgroundImage:image forBarMetrics:UIBarMetricsDefault];

}

五、导航条处理

 // 给导航条的背景图片传递一个空图片的UIImage对象
    [self.navigationController.navigationBar setBackgroundImage:[[UIImage alloc] init] forBarMetrics:UIBarMetricsDefault];
// 隐藏底部阴影条,传递一个空图片的UIImage对象
    [self.navigationController.navigationBar setShadowImage:[[UIImage alloc] init]];
// 根据颜色生成一张尺寸为1*1的相同颜色图片
+ (UIImage *)imageWithColor:(UIColor *)color
{
    // 描述矩形
    CGRect rect=CGRectMake(0.0f, 0.0f, 1.0f, 1.0f);

    // 开启位图上下文
    UIGraphicsBeginImageContext(rect.size);
    // 获取位图上下文
    CGContextRef context = UIGraphicsGetCurrentContext();
    // 使用color演示填充上下文
    CGContextSetFillColorWithColor(context, [color CGColor]);
    // 渲染上下文
    CGContextFillRect(context, rect);
    // 从上下文中获取图片
    UIImage *theImage = UIGraphicsGetImageFromCurrentImageContext();
    // 结束上下文
    UIGraphicsEndImageContext();

    return theImage;
}

联系方式

如果你喜欢这篇文章,可以继续关注我,微博:吖了个峥,欢迎交流。
点击这下载源代码

上一篇下一篇

猜你喜欢

热点阅读