将子视图作为背景添加到导航栏

时间:2016-06-21 20:26:03

标签: ios swift2 uinavigationbar

我在我的应用程序中使用导航控制器,我正在尝试将进度条作为导航栏的背景。我创建了UIView的子类来创建我的进度条,这很好。

现在,当我构建导航栏项目时,我将进度条添加为导航栏的SubView,以及2个按钮。这也很好用!

问题是,当我点击我的桌面视图的一行时,这会使视图控制器变为现实,当我单击“返回”按钮时,我的进度条现在位于导航栏中的按钮顶部。

以下是我设置导航栏项目的代码:

    let progressBar = ScrollProgress(frame: CGRect(x: 0, y: -20, width: self.navigationController!.navigationBar.frame.width, height: self.navigationController!.navigationBar.frame.height + 20), section: nil)
    progressBar.tag = 10
    progressBar.pourcentage = 92

    self.navigationController!.navigationBar.addSubview(progressBar)

    let menuButton = UIBarButtonItem(title: "Menu", style: UIBarButtonItemStyle.Plain, target: revealViewController(), action: #selector(SWRevealViewController.revealToggle(_:)))
    self.navigationItem.leftBarButtonItem = menuButton

    let favorisButton = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.Bookmarks, target: revealViewController(), action: #selector(SWRevealViewController.rightRevealToggle(_:)))
    self.navigationItem.rightBarButtonItem = favorisButton

    self.navigationItem.title = "Demo App"

你可以在这里看到它工作正常,进度条占我导航栏宽度的92%,并且在按钮和标题下面:

enter image description here

然后当我点击我的tableview的一行时,这会将segue执行到另一个ViewController,它运行正常:

enter image description here

当我点击后退按钮(Retour)时,我的进度条显示在顶部...

enter image description here

我无法找出为什么子视图顺序正在发生变化。我试图用self.navigationController!.navigationBar.exchangeSubviewAtIndex将我的子视图替换为正确的索引,它可以工作,但标题在转换结束时闪烁(但按钮没有闪烁)。

还有其他方法可以做到这一点,还是我做错了什么?

任何帮助将不胜感激!

1 个答案:

答案 0 :(得分:1)

您不仅可以尝试添加进度条,还可以将其插入导航条insertSubview(view: UIView, at: Int)的最底部。这对我有用。

self.navigationController!.navigationBar.insertSubview(progressBar, at: 0)