导航栏,黑线,translucent Tab

隐藏navigationitem中的buttonitem

self.navigationItem.rightBarButtonItem.customView.hidden = YES;

 

 "Illegal property type, c for appearance setter, _installAppearanceSwizzleF  

在iOS8下没问题,但到了iOS7一运行就crash。

之后找到原因,是因为这一行代码:

[[UINavigationBar appearance] setTranslucent:NO]

这是一个很奇怪的问题,iOS7不支持这种写法(iOS8是没问题的),不知是苹果有意为之还是bug,似乎iOS7中,[UINavigationBar appearance]是没有translucent属性的。

 

self.navigationController.navigationBar.translucent = NO;

 

tab push时隐藏

self.tabBarController.hidesBottomBarWhenPushed = YES;

 

隐藏导航栏 [[self navigationController] setNavigationBarHidden:NO animated:NO];

ios7 uinavigationbar下面的黑线

 

IOS 实现自定义的导航栏背景以及自定义颜色的状态栏(支持7.0以及低版本)

摘录:

//创建一个高20的假状态栏背景

UIView *statusBarView = [[UIView alloc] initWithFrame:CGRectMake(0, -20, 320, 20)];

//将它的颜色设置成你所需要的,这里我选择了黑色,表示我很沉稳

    statusBarView.backgroundColor=[UIColor blackColor];

//这里我的思路是:之前不理想的状态是状态栏颜色也变成了导航栏的颜色,但根据这种情况,反而帮助我判断出此时的状态栏也是导航栏的一部分,而状态栏文字浮于上方,因此理论上直接在导航栏上添加一个subview就是他们中间的那一层了。

//推得这样的代码:

    [self.navigationController.navigationBar addSubview:statusBarView];

 

IOS7的状态栏和导航栏 很好

search bar位置调整:

self.navigationItem.titleView = search;

覆盖自定义view的setframe方法

- (void)setFrame:(CGRect)frame

{

    CGRect t = CGRectMake(kNavTitleViewX, frame.origin.y, kScreenW - 2 * kNavTitleViewX, frame.size.height);

    [super setFrame:t];

    NSLog(@"seachBar frame:%@",NSStringFromCGRect(frame));

}

参考资料 stackoverflow

 

iOS隐藏导航栏底部的线条& UINavigationBar小技巧

隐藏返回按钮后面的文字

[[UIBarButtonItem appearance] setBackButtonTitlePositionAdjustment:UIOffsetMake(0, -60)
                                                         forBarMetrics:UIBarMetricsDefault];

设置导航栏底部线条颜色的代码:

UINavigationBar *navigationBar = self.navigationController.navigationBar; 
[navigationBar setBackgroundImage:[[UIImage alloc] init] forBarPosition:UIBarPositionAny barMetrics:UIBarMetricsDefault]; //此处使底部线条颜色为红色
[navigationBar setShadowImage:[UIImage imageWithColor:[UIColor redColor]]];

posted @ 2014-11-03 09:35  阿哲工具箱diqqxu  阅读(370)  评论(0编辑  收藏  举报