iOS 导航栏相关问题 导航!!!!!!!!!!!!!!!

1. 导航栏添加搜索框   

 CGRect mainViewBounds =self.navigationController.view.bounds;

    UISearchBar *customSearchBar = [[UISearchBaralloc]initWithFrame:CGRectMake(CGRectGetWidth(mainViewBounds)/2-((CGRectGetWidth(mainViewBounds)-120)/2),CGRectGetMinY(mainViewBounds)+22,CGRectGetWidth(mainViewBounds)-80,40)];

    customSearchBar.delegate =self;

    customSearchBar.showsCancelButton =NO;

    customSearchBar.searchBarStyle =UISearchBarStyleMinimal;

    // 整个背景颜色

//    customSearchBar.backgroundColor = [UIColor whiteColor];

    // 光标颜色

//    customSearchBar.tintColor = [UIColor whiteColor];

    [self.navigationController.viewaddSubview: customSearchBar];

2. 导航栏放置多个按钮

UIBarButtonItem *anotherButton = [[UIBarButtonItem alloc]initWithTitle:@"first" style:UITabBarSystemItemContactstarget:self action:@selector(one:)];

    UIBarButtonItem *anotherButton2 = [[UIBarButtonItem alloc]initWithTitle:@"second" style:UITabBarSystemItemContactstarget:self action:@selector(two:)];

    [self.navigationItem setLeftBarButtonItems:[NSArrayarrayWithObjects: anotherButton,anotherButton2,nil]];

3. 自定义导航按钮和标题

    UIButton * leftBtn = [UIButton buttonWithType:UIButtonTypeRoundedRect];

    leftBtn.frame =CGRectMake(0,0,83,40);

    //    leftBtn.backgroundColor = [UIColor greenColor];

    [leftBtn setTintColor:[UIColor whiteColor]];

    [leftBtn setImageEdgeInsets:UIEdgeInsetsMake(0, -50, 0, 0)];

    [leftBtn setImage:[UIImage imageNamed:@"goback_normal"]forState:UIControlStateNormal];

    [leftBtn addTarget:self action:@selector(goback)forControlEvents:UIControlEventTouchUpInside];

    UIBarButtonItem * leftItem = [[UIBarButtonItem alloc]initWithCustomView:leftBtn];

    self.navigationItem.leftBarButtonItem = leftItem;

    左右区别:

    self.navigationItem.rightBarButtonItem = rightItem;

    标题:

    UIView * centerView = [[UIViewalloc]initWithFrame:CGRectMake(0,7,110,30)];

    UILabel *titleLabel = [[UILabelalloc]initWithFrame:CGRectMake(0,0,110,30)];

    titleLabel.text =@"选择所在桌位";

    titleLabel.textColor = [UIColorwhiteColor];

    [centerView addSubview:titleLabel];

    self.navigationItem.titleView = centerView;

4.  自定义导航栏背景颜色

    [self.navigationController.navigationBarsetBackgroundImage:[UIImageimageNamed:@"topbar"]forBarMetrics:UIBarMetricsDefault];

5.  隐藏系统导航栏

    self.navigationController.navigationBarHidden = NO;

6. 让新的view覆盖导航栏
[[UIApplication sharedApplication].keyWindow addSubview:yourView];

7.系统的返回箭头一般是这样的:先去掉返回标题。

[objc]  view plain  copy
  1. UIBarButtonItem *back = [[UIBarButtonItem alloc] init];  
  2. back.title = @"";  
  3. self.navigationItem.backBarButtonItem = back;  




然后,替换:

[objc]  view plain  copy
  1. [[UIBarButtonItem appearance] setBackButtonBackgroundImage:[UIImage imageNamed:@"icon-erji"] forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];  


结果:





接着,设置一下图片:

[objc]  view plain  copy
  1. UIImage *backImage = [[UIImage imageNamed:@"icon-erji"] resizableImageWithCapInsets:UIEdgeInsetsMake(02500)];  
  2. [[UIBarButtonItem appearance] setBackButtonBackgroundImage:backImage forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];  


结果:




好了!


发现,点击红框右下角的地方都能返回。



方法一

在当前页面加入下面方法

- (void)viewWillAppear:(BOOL)animated{

    [super viewWillAppear:animated];

    [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];

    //去掉导航栏底部的黑线

    self.navigationController.navigationBar.shadowImage = [UIImage new];

}

如果仅设置当前页导航透明,需加入下面方法

- (void)viewWillDisappear:(BOOL)animated{

    [super viewWillDisappear:animated];

    [self.navigationController.navigationBar setBackgroundImage:nil forBarMetrics:UIBarMetricsDefault];

    [self.navigationController.navigationBar setShadowImage:nil];

}


需要注意的是:如果返回上一页的操作有动画,则在上一页出现的时候,导航栏的颜色会逐渐变化

方法二

- (void)viewWillAppear:(BOOL)animated{

    [super viewWillAppear:animated];

    [[self.navigationController.navigationBar subviews] objectAtIndex:0].alpha = 0;

}

仅设置当前页面

- (void)viewWillDisappear:(BOOL)animated{

    [super viewWillDisappear:animated];

    [[self.navigationController.navigationBar subviews] objectAtIndex:0].alpha = 1;

}








1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值