2

私のコードには2つの問題があります。

一つはコンパイルエラー[型 'Page1' の値を期待される要素型 '_' に変換できません] が★で示されています。

もう1つは、戻るボタンを押すと、アラートシートが表示されている間にページ2(青)が消えることです。("Page1(page: self.$page)" をコメントアウトし、ソースをビルド) 予想される動作は、アラート ボタン (Yes) が押されるまで Page2(blue) が消えないことです。

これらの問題を解決する方法を誰か教えてもらえますか?

import SwiftUI

struct PageViewController: UIViewControllerRepresentable {
    var controllers: [UIViewController]
    @Binding var currentPage: Int

    func makeCoordinator() -> Coordinator {
        Coordinator(self)
    }

    func makeUIViewController(context: Context) -> UIPageViewController {
        let pageViewController = UIPageViewController(
            transitionStyle: .pageCurl,
            navigationOrientation: .vertical)
        pageViewController.dataSource = context.coordinator
        pageViewController.delegate = context.coordinator

        return pageViewController
    }

    func updateUIViewController(_ pageViewController: UIPageViewController, context: Context) {
        pageViewController.setViewControllers(
            [controllers[currentPage]], direction: .forward, animated: true)
    }

    class Coordinator: NSObject, UIPageViewControllerDataSource, UIPageViewControllerDelegate {
        var parent: PageViewController

        init(_ pageViewController: PageViewController) {
            self.parent = pageViewController
        }

        func pageViewController(
            _ pageViewController: UIPageViewController,
            viewControllerBefore viewController: UIViewController) -> UIViewController?
        {
            guard let index = parent.controllers.firstIndex(of: viewController) else {
                return nil
            }
            if index == 0 {
                return nil
            }
            return parent.controllers[index - 1]
        }

        func pageViewController(
            _ pageViewController: UIPageViewController,
            viewControllerAfter viewController: UIViewController) -> UIViewController?
        {
            guard let index = parent.controllers.firstIndex(of: viewController) else {
                return nil
            }
            if index + 1 == parent.controllers.count {
                return nil
            }
            return parent.controllers[index + 1]
        }

        func pageViewController(_ pageViewController: UIPageViewController, didFinishAnimating finished: Bool, previousViewControllers: [UIViewController], transitionCompleted completed: Bool) {
            if completed,
                let visibleViewController = pageViewController.viewControllers?.first,
                let index = parent.controllers.firstIndex(of: visibleViewController)
            {
                parent.currentPage = index
            }
        }
    }
}


struct PageView<Page: View>: View {
    var viewControllers: [UIHostingController<Page>]
    @Binding var currentPage: Int

    init(_ views: [Page], currentPage: Binding<Int>) {
        self._currentPage = currentPage
        self.viewControllers = views.map { UIHostingController(rootView: $0) }
    }

    var body: some View {
        PageViewController(controllers: viewControllers, currentPage: $currentPage)
    }
}


struct ContentView: View {
    @State var page: Int = 0

    var body: some View {
        VStack {
            PageView([
                Page1(page: self.$page), // ★ error
                Page2(page: self.$page)// ★ error
            ], currentPage: $page)
        }
    }
}


struct Page1: View{
    @Binding var page: Int
    var body: some View {
        ZStack{
            Color.red
            VStack{
                Text("page1")
                Button (
                    action: { self.page += 1 }
                ){
                    Image(systemName: "forward")
                        .accentColor(Color.yellow)
                }
            }
        }
    }
}


struct Page2: View{
    @State private var showingAlert: Bool = false
    @Binding var page: Int
    var body: some View {
        ZStack{
            Color.blue
            VStack{
                Text("page2")
                Button (
                    action: { self.showingAlert.toggle() }
                ){
                    Image(systemName: "backward")
                        .accentColor(Color.yellow)
                }
            }
            .alert(isPresented: $showingAlert) {
                Alert(
                    title: Text("Confirm"),
                    message: Text("Back?"),
                    primaryButton:
                    .default(Text("Yes"),
                             action:{ self.page -= 1 }
                    ),
                    secondaryButton:
                    .cancel(Text("No"))
                )//alert
            }//alert
        }
    }
}
4

1 に答える 1