SwiftUI 中的 FSCalendar 集成

Posted

技术标签:

【中文标题】SwiftUI 中的 FSCalendar 集成【英文标题】:FSCalendar integration in SwiftUI 【发布时间】:2020-08-29 23:22:46 【问题描述】:

我目前正在尝试在我的应用程序中添加一个日历界面,当您点击底部的某一天时,它将显示当天事件的详细信息。目前我使用 FSCalendar 作为我的日历。

我意识到这个库是用于 UIKit 的,我必须用可表示的协议包装它才能让它在 SwiftUI 中工作。

我一直在观看 youtube 并查找有关在 SwiftUI 中集成 UIKit 的指南来帮助我做到这一点。这是我目前拥有的:

import SwiftUI
import FSCalendar

CalendarModule.swift:
class CalendarModule: UIViewController, FSCalendarDelegate 
    
    var calendar = FSCalendar()
    
    override func viewDidLoad() 
        super.viewDidLoad()
        calendar.delegate = self
    
    
    override func viewDidLayoutSubviews() 
        super.viewDidLayoutSubviews()
        initCalendar()
        view.addSubview(calendar)
    
    
    private func initCalendar() 
        calendar.frame = CGRect(x: 0, y: 0, width: view.frame.size.width, height: view.frame.size.width)
        calendar.appearance.todayColor = UIColor.systemGreen
        calendar.appearance.selectionColor = UIColor.systemBlue
    


struct CalendarModuleViewController: UIViewControllerRepresentable 
    
    typealias UIViewControllerType = UIViewController
    
    func makeUIViewController(context: UIViewControllerRepresentableContext<CalendarModuleViewController>) -> UIViewController 
        let viewController = CalendarModule()
        return viewController
    
    
    func updateUIViewController(_ uiViewController: UIViewController, context: UIViewControllerRepresentableContext<CalendarModuleViewController>) 
    
    
    
    func makeCoordinator() -> Coordinator 
        return Coordinator(self)
    
    
    final class Coordinator: NSObject, FSCalendarDelegate 
        private var parent: CalendarModuleViewController
        
        
        init (_ parent: CalendarModuleViewController) 
            self.parent = parent
        
        
    


struct CalendarModuleView: View 
    
    var body: some View 
        CalendarModuleViewController()
    
    

CalendarView.swift - 在上半部分显示日历,在下半部分显示详细信息:

import SwiftUI

struct CalendarView: View 
    var body: some View 
        NavigationView 
            VStack
                VStack 
                    Spacer()
                    CalendarModuleView()
                    Spacer()
                
                VStack 
                    Spacer()
                    Text("Details")
                    Spacer()
                
            .navigationBarTitle(Text("Calendar"), displayMode: .inline)
                .navigationBarItems(trailing:
                    NavigationLink(destination: CreateEventView().environmentObject(Event())) 
                        Image(systemName: "plus").imageScale(.large)
                    .buttonStyle(DefaultButtonStyle())
            )
        
    


struct CalendarView_Previews: PreviewProvider 
    static var previews: some View 
        CalendarView()
    

ContentView - 只显示我的 CalendarView:

import SwiftUI

struct ContentView: View 

    var body: some View 
        CalendarView()
    


struct ContentView_Previews: PreviewProvider 
    static var previews: some View 
        ContentView()
    

到目前为止,日历看起来是这样的:

日历模块本身可以工作,但我一直在编写协调器来处理代表。特别是 didSelectDate 一个..

当我开始在 Coordinator 类中输入 didSelectDate 并查看我只得到的建议时

func calendar(_ calendar: FSCalendar, didSelect date: Date, at monthPosition: FSCalendarMonthPosition) 
    <#code#>

我是否错误地包装了视图控制器? 或者我应该为 FSCalendar 创建自己的 UIView 和 UIViewController,然后创建 UIViewRepresentable 和 UIViewControllerRepresentable 以在 SwiftUI 中使用?

【问题讨论】:

您提到的和 willSelect 是库中唯一可用于提到的搜索的。所以有什么问题?您要找哪位代表?作为参考,您可以查看解释每个代表的 FSCalendar.h。 这个可以随意定制 -> github.com/yodagamaheshan/DateGrid 【参考方案1】:

这是一个老问题,但仍然存在。

我认为问题在于您将 CalendarModule 分配为代表而不是协调员

你需要编写如下代码:

func makeUIViewController(context: UIViewControllerRepresentableContext<CalendarModuleViewController>) -> UIViewController 
    let viewController = CalendarModule()
    viewController.calendar.delegate = context.coordinator // ->> Add this
    return viewController

之后,你应该可以在 Coordinator 中实现委托方法

【讨论】:

以上是关于SwiftUI 中的 FSCalendar 集成的主要内容,如果未能解决你的问题,请参考以下文章

SwiftUI 中的 Google AdMob 集成

SwiftUI 中的 Google AdMob 横幅事件集成

分配周末日 FSCalendar

如何以编程方式选择日期并在 FSCalendar 上显示

如何在 swift 4 中显示 FSCalendar 上的事件点?

如何在 FSCalendar swift 中禁用用户交互?