目前,我有一个使用FSCalendar
的简单日历应用,我想每天显示与日期数组匹配的事件。加载视图后,它会根据数组中的内容正确显示事件。添加新日期后,我通过设置断点来验证数组是否添加了新日期,最后我调用了calendar.reloadData()
函数。
class ViewController: UIViewController {
let calendarA = FSCalendar()
var calendarDaysEvent: [String] = []
// Result with the events of the selected day
var dayEvents: Results<EventsCompleted>?
override func viewDidLoad() {
super.viewDidLoad()
//.../
calendarA.dataSource = self
calendarA.delegate = self
self.calendarA.reloadData()
loadEventsCompleted()
loadEventsPerDay()
}
@IBAction func addItem(_ sender: UIButton) {
// Adds new item to the database
}
func randomHexColor() -> String {
// get the hex color
}
func hexStringToUIColor (hex:String) -> UIColor {
// hexColor to UI
}
func loadEventsCompleted() {
dayEvents = realm.objects(EventsCompleted.self)
eventsTableView.reloadData()
}
func loadEventsPerDay(){
// calendarDays
let id = dayEvents?.count ?? 0
if id != 0 {
print("ID: \(id)")
for x in 1...id {
calendarDaysEvent.append(dayEvents![x-1].date)
}
calendarA.reloadData() // Although I call it here, it is not called
// All the database functions for those things work normally
} else {
print("No events on the calendar")
}
}
}
仅在调用onViewDidLoad函数时才调用numberOfEventsFor
函数。
extension ViewController: FSCalendarDelegate, FSCalendarDataSource {
func calendar(_ calendar: FSCalendar, didSelect date: Date, at monthPosition: FSCalendarMonthPosition) {
print("Selected \(date)") //2020-01-15 23:00:00 +0000
print("Formatted date: \(date.toDateString(dateFormat: "yyyy-MM-dd"))")
}
func calendar(_ calendar: FSCalendar, numberOfEventsFor date: Date) -> Int {
if calendarDaysEvent.count != 0 {
if calendarDaysEvent.contains(date.toDateString(dateFormat: "yyyy-MM-dd")) {
return 1
} else {
return 0
}
} else {
return 0
}
}
}
当我在return 1
函数的唯一一个numberOfEventsFor
情况下设置断点时,它永远不会触发。我试图找到reloadData的工作方式,并且看起来它重新创建了视图,这意味着它也应该重新加载事件。我不确定来自扩展名的reloadData函数是否做错了什么。
我删除了一些我认为不相关的代码,但是如果您认为它可以帮助提供进一步的上下文,请在此处添加。
答案 0 :(得分:3)
所以这是一个愚蠢的问题。无法更新日历状态的原因是因为我没有为日历创建出口。