Ich versuche, meine täglichen Ereignisse in Tableview zu bevölkern. Ich habe die Verbindungen hergestellt. (Datenquelle, Delegat und Tabellenansicht) Aber der Wert des Ereignisses gibt 0 zurück. Entschuldigung, wenn das woanders gefragt wurde. Ich brauche ein wenig Hilfe.Ereignisse in Tableview einlagern (Swift)
Hier ist mein Code.
Import UIKit Import EventKit Import EventKitUI
Klasse 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
}
}
danke! Können Sie sagen, wo sollte ich diese Funktion verwenden? zur Anzeigedidload? Tut mir leid, ich bin neu in Swift. – sashatheitguy
Ja, Sie können dies in viewDidLoad verwenden – Shardul
Entschuldigung für viele Fragen. Ich habe so eine Funktion in viewdidload aufgerufen. self.functionname() aber jetzt konnte ich das nicht tun. self.fetchEvents() "fehlendes Argument für Parameter # 1 im Aufruf" Problem, das ich habe. Ich versuche das. self.fetchEvents (abgeschlossen: (NSMutableArray) ->()) { } aber nicht – sashatheitguy