Swiftui 如何在FSCalendar中使用@published和@observed?

Swiftui 如何在FSCalendar中使用@published和@observed?,swiftui,combine,fscalendar,Swiftui,Combine,Fscalendar,例如,如何从FSCalendar中获取selectedDate struct CalendarController: UIViewControllerRepresentable { func makeCoordinator() -> Coordinator { Coordinator(self) } func makeUIViewController(context: UIViewControllerRepresenta

例如,如何从FSCalendar中获取selectedDate

struct CalendarController: UIViewControllerRepresentable {
    
    func makeCoordinator() -> Coordinator {
        Coordinator(self)
    }
    
    
    func makeUIViewController(context: UIViewControllerRepresentableContext<CalendarController>) 
        -> calendars {
        let calendarViewController = calendars()
        return calendarViewController
    }
    
    func updateUIViewController(_ uiViewController: calendars, context: 
    UIViewControllerRepresentableContext<CalendarController>) {
    }

    
    func updateUIViewController(_ uiViewController: CalendarController, context: 
    UIViewControllerRepresentableContext<CalendarController>) {
    }

    class Coordinator: NSObject {
        var parent: CalendarController
        init(_ calendarViewController: CalendarController) {
            self.parent = calendarViewController
        }
    }
}

class calendars: UIViewController, FSCalendarDelegate, ObservableObject  {
    var calendar = FSCalendar()
    @Published var selectedData : Date?
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        calendar.delegate = self
    }

    override func viewDidLayoutSubviews() {
        super.viewDidLayoutSubviews()
        calendar.frame = CGRect(x: 0, y: 0, width: view.frame.size.width, height: 
    view.frame.size.width)
        view.addSubview(calendar)
    }
    
    func calendar(_ calendar: FSCalendar, didSelect date: Date, at monthPosition: 
    FSCalendarMonthPosition)  {
        print("didSelect date: \(date)")
        selectedData = date
    }
}

struct CalendarView: View {
  
    var body: some View{
        CalendarController().padding().frame(alignment: .top)
    }
    }


    struct Calendar_Previews: PreviewProvider {
    static var previews: some View {
        CalendarView()
        
    }
}
下面的工作

由于我是iOS新手,斯威夫特,我无法理解委托的诀窍

协调类应实施它以使其工作

''' 导入快捷键 导入UIKit 导入日历 进口联合收割机

结构CalendarController:UIViewControllerRepresentable{

@Binding var selectedDate : Date?

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

func makeUIViewController(context: Context) -> calendars {
    let calendar = calendars()
    calendar.calendar.delegate = context.coordinator 
    return calendar
   }

func updateUIViewController(_ uiViewController: calendars, context: Context) {
   }

 }

class calendars: UIViewController {
var calendar = FSCalendar()
var selectedDate : Date?

override func viewDidLoad() {
    super.viewDidLoad()
    
    calendar.delegate = self // delegate
}

override func viewDidLayoutSubviews() {
    super.viewDidLayoutSubviews()
    calendar.frame = CGRect(x: 0, y: 0, width: view.frame.size.width, height: 
 view.frame.size.width)
    view.addSubview(calendar)
}

}

 extension CalendarController {
 class Coordinator: NSObject, FSCalendarDelegate {
    var parent: CalendarController

    init(_ parent: CalendarController) {
        self.parent = parent
    }
    func calendar(_ calendar: FSCalendar, didSelect date: Date, at 
 monthPosition: FSCalendarMonthPosition) {
        print(date)
        parent.selectedDate = date
    }

 }
 }

“”“

我认为在iOS中将视图控制器作为观察对象不是一个好主意。在您的示例中,您正在用代码创建视图控制器的新实例,因此这不是您正在更改的实例,因为我假设它是从故事板创建的。它是swiftui。我尝试使用FSCalendar-在文档中,它是said使用UIViewControllerRepresentable协议。我看到我创建了一个新实例。我没有足够的iOS开发经验如何使其工作。
@Binding var selectedDate : Date?

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

func makeUIViewController(context: Context) -> calendars {
    let calendar = calendars()
    calendar.calendar.delegate = context.coordinator 
    return calendar
   }

func updateUIViewController(_ uiViewController: calendars, context: Context) {
   }

 }

class calendars: UIViewController {
var calendar = FSCalendar()
var selectedDate : Date?

override func viewDidLoad() {
    super.viewDidLoad()
    
    calendar.delegate = self // delegate
}

override func viewDidLayoutSubviews() {
    super.viewDidLayoutSubviews()
    calendar.frame = CGRect(x: 0, y: 0, width: view.frame.size.width, height: 
 view.frame.size.width)
    view.addSubview(calendar)
}

}

 extension CalendarController {
 class Coordinator: NSObject, FSCalendarDelegate {
    var parent: CalendarController

    init(_ parent: CalendarController) {
        self.parent = parent
    }
    func calendar(_ calendar: FSCalendar, didSelect date: Date, at 
 monthPosition: FSCalendarMonthPosition) {
        print(date)
        parent.selectedDate = date
    }

 }
 }