0

我在 SwiftUI 中创建了一个应用程序。

视图是结构,但我需要了解视图控制器,因为它是呈现一些特殊警报所必需的。

我看到在我的项目中有 AppDelegate 和 SceneDelegate。

我找到了这个

let contentView = ContentView()

    // Use a UIHostingController as window root view controller.
    if let windowScene = scene as? UIWindowScene {
        let window = UIWindow(windowScene: windowScene)
        window.rootViewController = UIHostingController(rootView: contentView)
        self.window = window
        window.makeKeyAndVisible()
    }

所以我想将视图控制器引用传递给其他视图。

window.rootViewController 是传递和使用的正确值吗?

4

2 回答 2

1

可能的解决方案是将托管视图控制器作为环境键注入,因此它可以在任何ContentView内部层次结构级别上可用。

这是一个演示。使用 Xcode 12 / iOS 14 测试。

  1. 声明环境密钥
struct RootViewControllerKey: EnvironmentKey {
    static let defaultValue: UIViewController? = nil
}

extension EnvironmentValues {
    var rootViewController: UIViewController? {
        get { self[RootViewControllerKey.self] }
        set { self[RootViewControllerKey.self] = newValue }
    }
}
  1. 将环境注入ContentView
if let windowScene = scene as? UIWindowScene {
    let window = UIWindow(windowScene: windowScene)

    let rootController = UIHostingController(rootView: AnyView(EmptyView()))
    rootController.rootView = AnyView(contentView
        .environment(\.rootViewController, rootController))
    window.rootViewController = rootController

    self.window = window
    window.makeKeyAndVisible()
}
  1. 在里面使用
struct ContentView: View {
    // can be used here as well

    var body: some View {
      TestSubView()
    }
}

struct TestSubView: View {
    @Environment(\.rootViewController) var viewController // for demo here!!

    var body: some View {
      Text("Demo")
        .onAppear {
          print(String(describing: self.viewController))
        }
    }
}
于 2020-09-19T10:45:51.087 回答
0

我不知道这个答案是否是一个合适的解决方案,但它对我很有效,所以使用它时要小心。

class func getTopMostViewController() -> UIViewController? {
    var topMostViewController = UIApplication.shared.keyWindow?.rootViewController

    while let presentedViewController = topMostViewController?.presentedViewController {
        topMostViewController = presentedViewController
    }

    return topMostViewController
}

使用类似的值

let viewController=getTopMostViewController()
viewController.present(...

来自 StackOverflow 的回答:

获取最顶层的 UIViewController

于 2021-05-04T12:53:50.957 回答