要使用UIKit调用SwiftUI,你需要在UIKit项目中使用SwiftUI来构建你的视图。你可以通过创建一个新的SwiftUI View并将其包装在UIHostingController中来实现这一点。下面是一个简单的示例:
首先,创建一个新的SwiftUI View:
import SwiftUIstruct ContentView: View {var body: some View {Text("Hello SwiftUI").font(.largeTitle)}
}
然后,在UIKit项目中创建一个UIHostingController来托管这个SwiftUI View:
import UIKit
import SwiftUIclass ViewController: UIViewController {override func viewDidLoad() {super.viewDidLoad()let contentView = ContentView()let hostingController = UIHostingController(rootView: contentView)addChild(hostingController)view.addSubview(hostingController.view)hostingController.view.translatesAutoresizingMaskIntoConstraints = falseNSLayoutConstraint.activate([hostingController.view.leadingAnchor.constraint(equalTo: view.leadingAnchor),hostingController.view.trailingAnchor.constraint(equalTo: view.trailingAnchor),hostingController.view.topAnchor.constraint(equalTo: view.topAnchor),hostingController.view.bottomAnchor.constraint(equalTo: view.bottomAnchor)])hostingController.didMove(toParent: self)}
}
以上代码将在UIKit项目的ViewController中创建一个UIHostingController,并将其添加为子视图控制器并将其视图添加到当前视图中。
注意,UIHostingController是包装SwiftUI View的UIKit视图控制器。因此,你可以在UIKit项目中使用UIKit的方式来处理UI逻辑,同时仍然能够使用SwiftUI来构建自定义视图。
最后,确保将主窗口(rootViewController)设置为刚刚创建的ViewController:
import UIKit@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {var window: UIWindow?func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {// 创建窗口self.window = UIWindow(frame: UIScreen.main.bounds)// 设置根视图控制器为ViewControllerlet viewController = ViewController()self.window?.rootViewController = viewController// 设置窗口为主窗口并显示self.window?.makeKeyAndVisible()return true}
}
现在,你就可以在UIKit项目中使用SwiftUI来构建视图了。