1

我有一个 BaseViewController 和一个使用我的 MenuViewController的SideMenu 。有许多可能的“主页”屏幕都继承自同一个 BaseViewController。MenuViewController 也继承自 BaseViewController。

我希望在主屏幕上显示一个叠加层,然后在菜单不再聚焦时消失。到目前为止,我只能让覆盖显示,但不能消失。

如果我点击其中一个菜单项,则覆盖消失,该菜单项执行到 BaseViewController 的适当子类(例如,主屏幕或设置屏幕)。这有效地刷新了屏幕,我想如果我找不到更好的解决方案,我可以保留对调用者的引用并重新回到它。

我尝试过的事情:

  • overlay.removeFromSuperview()
  • view.sendSubview(toBack: overlay)
  • overlay.isHidden = true
  • overlay.alpha = 0.0
  • 进入MenuViewController hideOverlay()
  • super.overlay在 MenuViewController 中使用而不是简单地使用overlayor self.overlay

我可以确认所有代码行都被断点击中,但覆盖视图并没有消失。当我点击使菜单消失时,不会调用 BaseViewController 的 viewWillAppear(),因为它的子类已经在视图中(只是稍微推到一边)。

这是一个最小的可重现示例:

基础视图控制器

import UIKit
import SideMenu

class BaseViewController: UIViewController {

    let overlay = UIView()

    override func viewDidLoad() {
        super.viewDidLoad()

        // Setup
        overlay.frame = self.view.frame
        overlay.backgroundColor = UIColor.clear
        overlay.alpha = 0.5
        overlay.isUserInteractionEnabled = false
        overlay.autoresizingMask = [.flexibleWidth, .flexibleHeight]
        view.addSubview(overlay)
    }

    // WORKS
    func showMenu() {
        // menuLeftNavigationController is MenuViewController.
        self.present(SideMenuManager.menuLeftNavigationController!, animated: true) {
            UIView.animate(withDuration: 0.2) {
                self.overlay.backgroundColor = Constants.Colors.overlayColor // Already defined.
    }

   // PROBLEM IS HERE
   func hideOverlay() {
       UIView.animate(withDuration: 0.2) {
            self.overlay.backgroundColor = UIColor.clear
            self.overlay.setNeedsLayout()
            self.overlay.layoutIfNeeded()

            self.view.setNeedsLayout()
            self.view.layoutIfNeeded()
      }
   }

}

菜单视图控制器

import UIKit
import SideMenu

class MenuViewController: BaseViewController, UITableViewDataSource, UITableViewDelegate {

    @IBOutlet weak var tableView: UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()

        // Tableview boilerplate
    }

    override func viewWillAppear(_ animated: Bool) {
        super.viewWillAppear(animated)
        tableView.reloadData()
    }

    // BREAKPOINTS CONFIRM THIS CODE EXECUTES.
    override func viewWillDisappear(_ animated: Bool) {
        self.hideOverlay()
    }
}
4

1 回答 1

0

viewWillDisappear你打电话时self.hideOverlay,你在你的MenuViewController.

showMenu()被调用时,您呈现MenuViewController然后在呈现视图控制器上设置覆盖背景颜色。

我想,您在这里要做的是在完成MenuViewController, dismiss 方法时做:

if let presentingViewController = self.presentingViewController as? BaseViewController {
    presentingViewController.hideOverlay()
}

希望这是有道理的?

于 2018-10-30T22:44:58.777 回答