如何将背景颜色设置为透明,以便显示运营商信息,时间和电池状态

时间:2017-02-13 07:27:47

标签: ios swift webview statusbar

我正在使用WKWebView在我的Swift 3+应用程序中打开网页。 我不使用故事板或XIB。

当我的webview加载时,它会隐藏运营商信息,蜂窝网络信号强度指示器(点),WiFi / 4G连接指示灯,时间和电池状态,因为黑色背景颜色(默认设置)

我想在顶部状态栏下方显示我的网页视图。 我使用UIApplication.shared.statusBarFrame.height获取了状态栏的高度 (预计它是20,并且确认如此)

我怎样才能让两者都显得很好? (白色背景/透明度) 这样用户可以在顶部查看状态栏信息,然后按预期查看webview。

Controller.swift

import UIKit
import WebKit

class MyWebViewController: UIViewController, WKNavigationDelegate {
    var urlString:String? = nil
    let myWebView = WKWebView(frame:CGRect(x: 0, y: 32+UIApplication.shared.statusBarFrame.height, width: UIScreen.main.bounds.width, height: UIScreen.main.bounds.height-32-UIApplication.shared.statusBarFrame.height))
    let button = UIButton(frame: CGRect(x:UIScreen.main.bounds.width - 100,y:50,width:50,height:50))
    let navpath = UITextView(frame:CGRect(x: 0, y: UIApplication.shared.statusBarFrame.height, width: UIScreen.main.bounds.width, height: 32))

    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.isOpaque=true
        self.view.backgroundColor = UIColor.clear
        print("status bar height : \(UIApplication.shared.statusBarFrame.height)")
        button.backgroundColor = UIColor.red
        button.setTitle("close", for: .normal)
        myWebView.navigationDelegate = self
        myWebView.autoresizingMask = [.flexibleWidth, .flexibleHeight]
        myWebView.load(NSURLRequest(url: targetUrl as URL) as URLRequest)
        view.addSubview(myWebView)
        button.autoresizingMask = [.flexibleWidth, .flexibleHeight]
        navpath.autoresizingMask = [.flexibleWidth, .flexibleHeight]
        view.addSubview(navpath)
        myWebView.addSubview(button)
    }
    func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
        //print(navigationAction.navigationType)
        let navReq = navigationAction.request
        let targetUrl = navReq?.url
        let link = targetUrl?.absoluteString
        print("targetURL : \(targetUrl)\n link : \(link)")
        navpath.text=link
        //self.myWebView.load(navReq)
        decisionHandler(.allow)
    }
}

旋转时,绿色电池指示灯隐藏。我也想解决这个问题。 navpath(地址栏textholder)和按钮(关闭)也放错了地方,我想我需要autolayout / constraintmanager等。

当前样本加载duckduckgo

肖像

portrait

景观

landscape

另外,让我知道UITextView是否是显示地址栏(网页的URL)的好选择,或者我应该使用UILabel或其他东西,可能更好,navigationBar?但是,我想这需要storyboard / xib。

1 个答案:

答案 0 :(得分:0)

您可以为视图设置prefferedStatusBarStylehttps://developer.apple.com/reference/uikit/uiviewcontroller/1621416-preferredstatusbarstyle

在ViewController中:

override var preferredStatusBarStyle: UIStatusBarStyle {
    return .lightContent
}

如果不同的视图具有不同的状态栏样式,您可以使用setNeedsStatusBarAppearanceUpdate()更新它,例如。在viewDidAppear

https://developer.apple.com/reference/uikit/uiviewcontroller/1621354-setneedsstatusbarappearanceupdat