我选择了一个不同的选项 - 子类 NSHostingController 以便它提供自己作为环境变量。
struct SwiftUIView: View {
@EnvironmentObject var host:HSHostWrapper
var body: some View {
Button("Dismiss") {
host.controller?.dismiss(self)
}
}
}
let controller = HSHostingController(rootView: SwiftUIView())
这是通过以下 HSHostingController 实现的(在HSSwiftUI 包中可用)
import Foundation
import SwiftUI
#if os(iOS) || os(tvOS)
import UIKit
public typealias ViewController = UIViewController
public typealias HostingController = UIHostingController
#elseif os(OSX)
import AppKit
public typealias ViewController = NSViewController
public typealias HostingController = NSHostingController
#endif
public class HSHostWrapper:ObservableObject {
public weak var controller:ViewController?
}
/// allows root view (and children) to access the hosting controller by adding
/// @EnvironmentObject var host:HSHostWrapper
/// then e.g. host.controller?.dismiss()
public class HSHostingController<Content>:HostingController<ModifiedContent<Content,SwiftUI._EnvironmentKeyWritingModifier<HSHostWrapper?>>> where Content : View {
public init(rootView:Content) {
let container = HSHostWrapper()
let modified = rootView.environmentObject(container) as! ModifiedContent<Content, _EnvironmentKeyWritingModifier<HSHostWrapper?>>
super.init(rootView: modified)
container.controller = self
}
required init?(coder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
}