有关Nav和Tab属性和方法的一些细节记录

状态栏的设置

情形:设置欢迎页影藏,首页显示:
在info.plist里增加 Status bar is initially hidden,设置为yes
然后在首页或者父类控制器里设置

    // MARK: - 状态栏
    override var prefersStatusBarHidden: Bool{
        return false
    }

这里需要注意第二个方法:
1、如果ViewController不是UINavigationController的子类,调用 preferredStatusBarStyle 是可以改变状态栏文字的颜色,相反则不能;

因为 UINavigationController 有自己的状态栏,需要自己管理所以它的子类是不会走 preferredStatusBarStyle 方法;如果想要某个VC 改变,可以使用 UINavigationBar.barStyle属性

self.navigationController?.navigationBar.barStyle = .black

或者 //隐藏导航栏后 系统会调用 preferredStatusBarStyle 方法

self.navigationController.navigationBarHidden=YES;

标题

  //tab和nav的title会全部更改:
    self.title = @"首页";
   //nav会更改 tab不会更改:
    self.navigationItem.title = @"首页";

导航栏颜色

    //修改导航栏的颜色
    self.navigationController.navigationBar.barTintColor = [UIColor orangeColor];

导航栏下个界面返回按钮

    //修改导航栏下个界面返回按钮的文字 注意 修改的是下一个界面的返回按钮:
    self.navigationItem.backBarButtonItem = [[UIBarButtonItem alloc] initWithTitle:@"返回" style:UIBarButtonItemStylePlain target:nil action:nil];

导航栏返回按钮图片

// 修改导航栏返回按钮的图片 返回按钮图片大小为42*42 这里不能直接按照下面的方式设置,不然当界面上有弹框UIAlertController时,图片会向下偏移:
        let leftBBi = UIBarButtonItem(title: "", style: .plain, target: self, action: #selector(personalSettingBack))
        leftBBi.image = UIImage(named: "nav_back")
        leftBBi.tintColor = HHGK_WHITE_COLOR
        self.navigationItem.leftBarButtonItem = leftBBi

// 正确的做法应该是自定义一个按钮, 然后设置为leftBarButtonItem:
        let backBtn = UIButton(type: .custom)
        backBtn.setImage(UIImage.init(named: "nav_back"), for: .normal)
        backBtn.tintColor = HHGK_WHITE_COLOR
        backBtn.frame = CGRect(x: 0, y: 0, width: 42, height: 42)
        backBtn.addTarget(self, action: #selector(personalSettingBack), for: .touchUpInside)
        
        let backBBi = UIBarButtonItem.init(customView: backBtn)
        
        self.navigationItem.leftBarButtonItem = backBBi

导航栏文字样式

    //修改导航栏中间文字的样式:
    [self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor whiteColor],NSFontAttributeName:[UIFont systemFontOfSize:16]}];
swift:
    self.navigationBar.titleTextAttributes = [NSForegroundColorAttributeName:UIColor.white]

工具栏的颜色:

 //修改工具栏的颜色:
    self.tabBarController.tabBar.barTintColor = [UIColor grayColor];
//修改工具栏下面文字的颜色:
    self.tabBarController.tabBar.tintColor = [UIColor blackColor];  

透明

//把顶部这个navigationbar设置为透明呢,能够让下面的图片显示出来,但是返回按钮不透明:
    [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault];

线条

 //去掉导航栏下面的线条:
    self.navigationController.navigationBar.shadowImage = [UIImage new];

未选中与选中时的图片

//设置UITabBarItem未选中与选中时的图片:
   [_hotTabItem setFinishedSelectedImage:[UIImage imageNamed:@"1_selected"] withFinishedUnselectedImage:[UIImage imageNamed:@"1"]];

badgeValue

//设置UITabBarItem的badgeValue:
  //指定界面
   [self.tabBarController.tabBar.items objectAtIndex:2].badgeValue = [NSString stringWithFormat:@"%ld", ++ goodsCount];
  //当前界面
        _mine.navigationController.tabBarItem.badgeValue = [NSString stringWithFormat:@"%ld", count];
  //为0时清除
      _mine.navigationController.tabBarItem.badgeValue = nil;

tabBar样式

//设置tabBar样式

[[UITabBarItemappearance]setTitleTextAttributes:@{NSForegroundColorAttributeName:[selfmyThemeColor]}forState:UIControlStateSelected];

[[UITabBarItemappearance]setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColorredColor]}forState:UIControlStateNormal];

//选中的颜色(图片+图片下面文字的颜色,iOS8.0以后被废弃了)

self.tabBarController.tabBar.selectedImageTintColor= [selfmyThemeColor];

//未选中的颜色(图片+图片下面文字的颜色,没被废弃)

self.tabBarController.tabBar.unselectedItemTintColor= [UIColorgreenColor];

dismiss回到目标控制器

// dismiss方式回到目标控制器:
/*
(1) presentedViewController:The view controller that is presented by this view controlller(read-only),被本视图控制器present出来的的视图控制器(只读)
(2) presentingViewController:The view controller that presented this view controller. (read-only),present出来本视图控制器的视图控制器(只读)
*/
        UIViewController *vc = self.presentingViewController;
        while (![vc isKindOfClass:[TFTravelllerLoginViewController class]]) {
        
            vc = vc.presentingViewController;
        }
        
        [vc dismissViewControllerAnimated:YES completion:nil];

push到下个界面隐藏tabBar pop回去显示tabBar

// 注意是设置目标控制器的hidesBottomBarWhenPushed属性
EaseMessageViewController *messageVc = [[EaseMessageViewController alloc] initWithConversationChatter:contactName conversationType:EMConversationTypeChat];
messageVc.hidesBottomBarWhenPushed = YES;
[self.navigationController pushViewController:messageVc animated:YES];

pop回到目标控制器

//pop方式回到目标控制器:
        for (UIViewController *disVc in self.navigationController.viewControllers) {
            
            if ([disVc isKindOfClass:[TFTravelllerLoginViewController class]]) {
                [self.navigationController popToViewController:disVc animated:YES];
            }
        }

UISearchBar自定义

    searchBar.backgroundImage = [CzyTools imageWithColor:[UIColor colorWithHexString:@"#F5F5F5"]];
    searchBar.backgroundColor = [UIColor clearColor];
    [searchBar setSearchFieldBackgroundImage:[CzyTools imageWithColor:[UIColor colorWithHexString:@"#F5F5F5"]] forState:UIControlStateNormal];
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • 相逢不饮空杯去,洞口桃花也笑人。 朋友难得,好朋友更难得,几十年的好朋友更是难得,所以应当好好珍惜面前的朋友,所有...
    九小飞阅读 668评论 4 0
  • 参考书目 《用图秀演讲》 一个精彩的故事可以为演讲增色。如何讲好故事呢?书中给我们分享了一个讲故事的好办法,即“美...
    萌小Q在路上阅读 281评论 8 9
  • 今年暑假小叔从浙江回来看望爷爷奶奶,去年因为手头上还有事情,所以就没有回家。不经意间就是两个...
    晨曦朦胧岁月静好阅读 333评论 1 3
  • 我上辈子大概是个车夫。 小时候一旦汽车飞驰而过,定会猛嗅一口浓烈的汽油味,叫一声“好香”。有次到镇上的...
    维扬客阅读 174评论 0 2