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 横幅事件集成