支持不同SwiftUI视图类型的UIHostingController数组



我正在遵循https://developer.apple.com/tutorials/swiftui/interfacing-with-uikit,我试图将我的页面视图附加到UIHostingControllers数组,而当我这样做时一切都有效:

PageView(pages: [Text("hi"), Text("hello!")])

当视图类型不同时,我得到"Failed to produce diagnostic for expression; please file a bug report":

PageView(pages: [Text("hi"), SomeOtherView()])

下面是我的代码:

PageViewController

struct PageViewController<Page: View>: UIViewControllerRepresentable {
var pages: [Page]
@Binding var currentPage: Int
func makeCoordinator() -> Coordinator {
Coordinator(self)
}
func makeUIViewController(context: Context) -> UIPageViewController {
let pageViewController = UIPageViewController(
transitionStyle: .scroll,
navigationOrientation: .horizontal
)
pageViewController.dataSource = context.coordinator
pageViewController.delegate = context.coordinator
return pageViewController
}
func updateUIViewController(_ pageViewController: UIPageViewController, context: Context) {
pageViewController.setViewControllers(
[context.coordinator.controllers[currentPage]], direction: .forward, animated: true)
}
class Coordinator: NSObject, UIPageViewControllerDataSource, UIPageViewControllerDelegate {
var parent: PageViewController
var controllers = [UIViewController]()
init(_ pageViewController: PageViewController) {
parent = pageViewController
controllers = parent.pages.map { UIHostingController(rootView: $0.navigationBarHidden(true)) }
for viewController in controllers {
viewController.view.backgroundColor = .clear
}
}
func pageViewController(_ pageViewController: UIPageViewController, viewControllerBefore viewController: UIViewController) -> UIViewController? {
guard let index = controllers.firstIndex(of: viewController) else { return nil }
//swiping back on page 0
if index == 0 {
return nil
}
return controllers[index - 1]
}
func pageViewController(_ pageViewController: UIPageViewController, viewControllerAfter viewController: UIViewController) -> UIViewController? {
guard let index = controllers.firstIndex(of: viewController) else { return nil }
//swiping forward on last page
if index + 1 == controllers.count {
return nil
}
return controllers[index + 1]
}
func pageViewController(_ pageViewController: UIPageViewController, didFinishAnimating finished: Bool, previousViewControllers: [UIViewController], transitionCompleted completed: Bool) {
if completed,
let visibleViewController = pageViewController.viewControllers?.first,
let index = controllers.firstIndex(of: visibleViewController) {
parent.currentPage = index
}
}
}
}

浏览页
struct PageView<Page: View>: View {
var pages: [Page]
@State private var currentPage = 0
var body: some View {
PageViewController(pages: pages, currentPage: $currentPage)
Text("Current page = (currentPage)")
}
}

可能有一种更聪明的方法来对视图数组进行类型擦除,但也可以使用AnyView包装不同类型的视图:

PageView(pages: [AnyView(Text("hi")), AnyView(SomeOtherView())])

相关内容

  • 没有找到相关文章

最新更新