将事件填充到 Tableview (Swift)
Populating Events in to Tableview (Swift)
我正在尝试将我的日常活动填充到表格视图中。我已经建立了联系。 (数据源、委托和表视图)但事件值返回 0。
抱歉,如果在其他地方有人问过这个问题。我需要一点帮助。
这是我的代码。
导入 UIKit
导入 EventKit
导入 EventKitUI
class MainViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
var eventStore: EKEventStore?
var events = [EKEvent]()
var startDate = NSDate()
var endDate = NSDate()
var cellIdentifier = "cell"
@IBOutlet var tableView: UITableView!
override func viewDidLoad() {
super.viewDidLoad()
automaticallyAdjustsScrollViewInsets = false
self.tableView.dataSource = self
self.tableView.delegate = self
self.tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: cellIdentifier);
//self.tableView.reloadData()
self.eventStore = EKEventStore()
fetchEvents { (arr:[EKEvent]) in
print(arr)
self.events = arr
//reload table
}
self.tableView.reloadData()
}
func fetchEvents(completed: ([EKEvent]) -> ()) {
eventStore!.requestAccessToEntityType(EKEntityType.Event, completion: {
granted, error in
let startDt = NSDate(timeIntervalSinceNow: -24 * 60 * 60);
let predicate = self.eventStore!.predicateForEventsWithStartDate(startDt, endDate: NSDate(), calendars: nil)
let events = self.eventStore!.eventsMatchingPredicate(predicate)
completed(events)
})
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
@IBAction func onLoadListButtonClicked(sender: AnyObject)
{
self.performSegueWithIdentifier("LoadTheList", sender: nil)
}
func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
//MARK: UITableViewDataSource
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
//TEST PRINT EVENT COUNT
print("event count (print) \(events.count)")
return events.count
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cellIdentifier = "cell"
let cell:UITableViewCell! = tableView.dequeueReusableCellWithIdentifier(cellIdentifier, forIndexPath: indexPath)
let events:EKEvent! = self.events[indexPath.row]
cell.textLabel!.text = events.title
cell.detailTextLabel!.text = events.startDate.description
print("event cell returned")
return cell
}
}
问题是您的开始日期是 NSDate(timeIntervalSinceNow: 24 * 60 * 60)
,即提前一天,您的结束日期是当前日期;简而言之,您正在检查明天开始和今天结束的活动 ;)
只需使用以下方法即可让活动从昨天开始到今天结束。如需进一步使用,只需将 startDt
更改为任何以前的日期。
func fetchEvents(completed: (NSMutableArray) -> ()) {
eventStore!.requestAccessToEntityType(EKEntityType.Event, completion: {
granted, error in
let startDt = NSDate(timeIntervalSinceNow: -24 * 60 * 60);
let predicate = self.eventStore!.predicateForEventsWithStartDate(startDt, endDate: NSDate(), calendars: nil)
let events = NSMutableArray(array: self.eventStore!.eventsMatchingPredicate(predicate))
completed(events)
})
}
编辑
称其为:
fetchEvents { (arr:NSMutableArray) in
print(arr)
//reload your table
}
根据您的评论:
I think its a breakpoint issue but I did not put a breakpoint. It's so
strange. imgur.com/a/nQGo1 imgur.com/a/MUb4i – bourbon 2 mins ago
我看过你的代码,在 viewDidLoad 中删除 viewWillAppear
方法并在 fetchEvents
函数调用上方添加 self.eventStore = EKEventStore()
。
还有一点很重要,将arr
分配给self.events
,然后重新加载table。我刚刚更改了 return 类型的方法使用如下:
方法:
func fetchEvents(completed: ([EKEvent]) -> ()) {
eventStore!.requestAccessToEntityType(EKEntityType.Event, completion: {
granted, error in
let startDt = NSDate(timeIntervalSinceNow: -24 * 60 * 60);
let predicate = self.eventStore!.predicateForEventsWithStartDate(startDt, endDate: NSDate(), calendars: nil)
let events = self.eventStore!.eventsMatchingPredicate(predicate)
completed(events)
})
}
方法调用:
fetchEvents { (arr:[EKEvent]) in
print(arr)
self.events = arr
//reload table
}
我正在尝试将我的日常活动填充到表格视图中。我已经建立了联系。 (数据源、委托和表视图)但事件值返回 0。 抱歉,如果在其他地方有人问过这个问题。我需要一点帮助。
这是我的代码。
导入 UIKit 导入 EventKit 导入 EventKitUI
class MainViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
var eventStore: EKEventStore?
var events = [EKEvent]()
var startDate = NSDate()
var endDate = NSDate()
var cellIdentifier = "cell"
@IBOutlet var tableView: UITableView!
override func viewDidLoad() {
super.viewDidLoad()
automaticallyAdjustsScrollViewInsets = false
self.tableView.dataSource = self
self.tableView.delegate = self
self.tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: cellIdentifier);
//self.tableView.reloadData()
self.eventStore = EKEventStore()
fetchEvents { (arr:[EKEvent]) in
print(arr)
self.events = arr
//reload table
}
self.tableView.reloadData()
}
func fetchEvents(completed: ([EKEvent]) -> ()) {
eventStore!.requestAccessToEntityType(EKEntityType.Event, completion: {
granted, error in
let startDt = NSDate(timeIntervalSinceNow: -24 * 60 * 60);
let predicate = self.eventStore!.predicateForEventsWithStartDate(startDt, endDate: NSDate(), calendars: nil)
let events = self.eventStore!.eventsMatchingPredicate(predicate)
completed(events)
})
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
@IBAction func onLoadListButtonClicked(sender: AnyObject)
{
self.performSegueWithIdentifier("LoadTheList", sender: nil)
}
func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
//MARK: UITableViewDataSource
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
//TEST PRINT EVENT COUNT
print("event count (print) \(events.count)")
return events.count
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cellIdentifier = "cell"
let cell:UITableViewCell! = tableView.dequeueReusableCellWithIdentifier(cellIdentifier, forIndexPath: indexPath)
let events:EKEvent! = self.events[indexPath.row]
cell.textLabel!.text = events.title
cell.detailTextLabel!.text = events.startDate.description
print("event cell returned")
return cell
}
}
问题是您的开始日期是 NSDate(timeIntervalSinceNow: 24 * 60 * 60)
,即提前一天,您的结束日期是当前日期;简而言之,您正在检查明天开始和今天结束的活动 ;)
只需使用以下方法即可让活动从昨天开始到今天结束。如需进一步使用,只需将 startDt
更改为任何以前的日期。
func fetchEvents(completed: (NSMutableArray) -> ()) {
eventStore!.requestAccessToEntityType(EKEntityType.Event, completion: {
granted, error in
let startDt = NSDate(timeIntervalSinceNow: -24 * 60 * 60);
let predicate = self.eventStore!.predicateForEventsWithStartDate(startDt, endDate: NSDate(), calendars: nil)
let events = NSMutableArray(array: self.eventStore!.eventsMatchingPredicate(predicate))
completed(events)
})
}
编辑
称其为:
fetchEvents { (arr:NSMutableArray) in
print(arr)
//reload your table
}
根据您的评论:
I think its a breakpoint issue but I did not put a breakpoint. It's so strange. imgur.com/a/nQGo1 imgur.com/a/MUb4i – bourbon 2 mins ago
我看过你的代码,在 viewDidLoad 中删除 viewWillAppear
方法并在 fetchEvents
函数调用上方添加 self.eventStore = EKEventStore()
。
还有一点很重要,将arr
分配给self.events
,然后重新加载table。我刚刚更改了 return 类型的方法使用如下:
方法:
func fetchEvents(completed: ([EKEvent]) -> ()) {
eventStore!.requestAccessToEntityType(EKEntityType.Event, completion: {
granted, error in
let startDt = NSDate(timeIntervalSinceNow: -24 * 60 * 60);
let predicate = self.eventStore!.predicateForEventsWithStartDate(startDt, endDate: NSDate(), calendars: nil)
let events = self.eventStore!.eventsMatchingPredicate(predicate)
completed(events)
})
}
方法调用:
fetchEvents { (arr:[EKEvent]) in
print(arr)
self.events = arr
//reload table
}