• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

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

原作者: [db:作者] 来自: [db:来源] 收藏 邀请
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

    }


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap