1

我正在尝试将 MDC 应用程序栏添加到我的应用程序中,由 MaterialComponents 的自定义子类定义UINavigationController。我在他们的Github 页面上进行了简洁的描述:

使用应用栏最简单的集成路径是通过 MDCAppBarNavigationController。此 API 是 UINavigationController 的子类,它会自动将 MDCAppBarViewController 实例添加到每个推送到它的视图控制器上,除非已经存在应用栏或灵活标题。

使用 MDCAppBarNavigationController 时,您至少需要使用委托配置添加的应用栏的背景颜色。

navigationController.pushViewController(<#T##viewController: UIViewController##UIViewController#>, animated: <#T##Bool#>)

// MARK: MDCAppBarNavigationControllerDelegate

func appBarNavigationController(_ navigationController: MDCAppBarNavigationController,
                                willAdd appBarViewController: MDCAppBarViewController,
                                asChildOf viewController: UIViewController) {
  appBarViewController.headerView.backgroundColor = <#(UIColor)#>
}

在我的故事板中,我添加了一个并在身份检查UINavigationController器中将其身份设置为。MDCAppBarNavigationController

在我的根视图控制器中,我实现MDCAppBarNavigationControllerDelegate

class MyViewController: UIViewController {
  override func viewDidLoad() {
    super.viewDidLoad()
    title = "My app"
    if let nav = navigationController as? MDCAppBarNavigationController {
      print("[MyViewController] Setting delegate MDCAppBarNavigationControllerDelegate")
      nav.delegate = self
    }
  }

  // MARK: MDCAppBarNavigationControllerDelegate
  func appBarNavigationController(_ navigationController: MDCAppBarNavigationController,
                                    willAdd appBarViewController: MDCAppBarViewController,
                                    asChildOf viewController: UIViewController) {
      print("Setting app bar color")
      appBarViewController.headerView.backgroundColor = .red
  }
}

当我运行应用程序时,我看到一个普通的导航栏,并且从未调用过委托方法。我究竟做错了什么?

4

1 回答 1

1

经过不同的尝试后,我通过创建自定义MDCAppBarNavigationController并将其设置为我UINavigationController的故事板(身份选项卡->类)使其工作

这是我的自定义 MDCAppBarNavigationController:

import MaterialComponents.MDCAppBarNavigationController

class MaterialNavigationController: MDCAppBarNavigationController {

    override func viewDidLoad() {
        super.viewDidLoad()

        delegate = self
    }
}

extension MaterialNavigationController: MDCAppBarNavigationControllerDelegate {
  func appBarNavigationController(_ navigationController: MDCAppBarNavigationController, willAdd appBarViewController: MDCAppBarViewController, asChildOf viewController: UIViewController) {

    appBarViewController.applyTheme()
    appBarViewController.navigationBar.applyTheme()
  }
}
于 2019-04-16T13:24:40.580 回答