【iOS开发】全局设定 UINavigationBar 的 UI

App Screen Shot.png

如图,是个很简明的 UITabBarController 分出3个 UINavigationController,每个 UINavigationController 再跟一个 UITableViewController 的结构。
TabBar 和 NavigationBar 都是以浅海蓝色为背景,文字和按钮为白色的设计。
因为 TabBar 只有一个,直接在 UITabBarController 的代码里写下面这段就可以
(globalBarTintColor是我自定义的浅海蓝色,后面还会出现)

    self.tabBar.tintColor = UIColor.whiteColor()
    self.tabBar.barTintColor = globalBarTintColor

然而 NavigationBar 有三个,甚至还会更多,一个个分别去设定颜色显然耦合性不够低,改起来也很麻烦。
下面给出一种全局统一设定的方法,写在 AppDelegate 文件的 didFinishLaunchingWithOptions 方法里:

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
    
    // NavigationBar 颜色,全局设定
    UINavigationBar.appearance().tintColor = UIColor.whiteColor()
    UINavigationBar.appearance().titleTextAttributes =
        [NSForegroundColorAttributeName:UIColor.whiteColor()]
    UINavigationBar.appearance().barTintColor = globalBarTintColor
    
    return true
}
App Screen Shot2.png

这样做的另外一个好处是,可以直接改掉上图圈出来的 NavigationBar 自带按钮的颜色,如果你直接尝试在某个 ViewController 里写

    self.navigationController!.navigationBar.tintColor = UIColor.whiteColor()

这个按钮的颜色貌似是改不掉的(据我刚刚尝试,是这样的)。

最后:
可以看出,上面的写法,直接是在设定 UINavigationBar 这个类的属性,所以依此类推,其他各种UI效果应该都可以这样全局设定。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值