Swift - 状态栏颜色显示(字体、背景)

时间:2021-11-30 15:12:47

ios上状态栏 就是指的最上面的20像素高的部分 
状态栏分前后两部分,要分清这两个概念,后面会用到:

  • 前景部分:就是指的显示电池、时间等部分;

  • 背景部分:就是显示黑色或者图片的背景部分;

    如下图:前景部分为白色,背景部分为黑色

注意:这里只涉及到ios7以及更高版本,低版本下面的讲解可能无效。

一、设置statusBar的【前景部分】

简单来说,就是设置显示电池电量、时间、网络部分标示的颜色, 
这里只能设置两种颜色:

  • 默认的黑色(UIStatusBarStyleDefault
  • 白色(UIStatusBarStyleLightContent

可以设置的地方有两个:plist设置里面 和 程序代码里

按照UI给的图,因为背景颜色要突出,所以要求状态栏使用亮色,但实际上默认是黑色

这里使用两种方法:

第一种:你是要全工程的状态栏都要变白色:

操作AppDelegate

1)在info.plist中新增 View-Controller-based status bar appearance 属性,Value选择NO

2)在启动方法func application(...)下调用直接书写

UIApplication.sharedApplication().statusBarStyle = .LightContent

这样就可以把默认的黑色改为白色

启动App,完成,一次设置,所有页面都相同。但是出现对状态栏颜色有不同需求的话 就需要用到第2种方法

第二种:只是部分控制器需要修改状态栏文字的颜色:

操作ViewController

1)同样是对info.plist的操作,同方法1一样新增属性,不过这次的Value为YES

2)在ViewController中,可以重写以下方法即可

override func preferredStatusBarStyle() -> UIStatusBarStyle {

return .LightContent;

}

启动App,完成,更加灵活的操作。

二、设置statusBar的【背景部分】

背景部分,简单来说,就是背景色;改变方法有两种:

系统提供的方法

navigationBarsetBarTintColor接口,用此接口可改变statusBar的背景色

注意:一旦你设置了navigationBar- (void)setBackgroundImage:(UIImage *)backgroundImage forBarMetrics:(UIBarMetrics)barMetrics接口,那么上面的setBarTintColor接口就不能改变statusBar的背景色,statusBar的背景色就会变成纯黑色。

另辟蹊径

创建一个UIView, 
设置该UIView的frame.size 和statusBar大小一样, 
设置该UIView的frame.origin 为{0,-20}, 
设置该UIView的背景色为你希望的statusBar的颜色, 
在navigationBar上addSubView该UIView即可。

例:

info.plist中新增 View-Controller-based status bar appearance 属性,Value选择NO

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {

// Override point for customization after application launch.

window = UIWindow(frame: UIScreen.mainScreen().bounds)

window?.rootViewController = UINavigationController(rootViewController: ViewController())

window?.backgroundColor = UIColor.whiteColor()

window?.makeKeyAndVisible()

// 状态栏字体白色

UIApplication.sharedApplication().statusBarStyle = .LightContent

// 状态栏背景颜色

// 在window上添加一个view保持在最前方, 需要注意的是这个view要在根视图控制器设置之后创建, 不然会出现显示不出来的情况

let stateBarBlockView = UIView(frame: CGRectMake(0, 0, window!.bounds.width, 20))

stateBarBlockView.backgroundColor = UIColor.blackColor()

window?.addSubview(stateBarBlockView)

window?.bringSubviewToFront(stateBarBlockView)

return true

}