Swift - 使用EventKit操作"提醒事项"(1、查询出所有提醒)
作者:hangge | 2016-08-01 09:00
(本文代码已升级至Swift3)
我原来写过一篇文章,介绍如何对系统日历事件(Event)进行操作(原文地址:Swift - 使用EventKit获取系统日历事件,添加事件)
接下来演示如何使用 EventKit 对系统里的提醒事项(Reminder)进行操作,本文先介绍如何获取系统里所有的提醒。
1,效果图
程序启动后会把所有的提醒事项加载出来,并显示在表格中。(第一次启动会需要访问授权)

2,配置info.plist
从 iOS10 起,苹果增强对用户的安全和隐私的保护。在申请很多私有权限的时候都需要添加描述。我们这里需要访问提醒事项,那就需要在 info.plist 添加相关的描述字段。

3,样例代码
import UIKit
import EventKit
class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {
var eventStore: EKEventStore!
var reminders: [EKReminder]!
var tableView:UITableView?
override func viewDidLoad() {
super.viewDidLoad()
//创建表视图
self.tableView = UITableView(frame: self.view.frame, style:.plain)
self.tableView!.delegate = self
self.tableView!.dataSource = self
self.view.addSubview(self.tableView!)
// 在取得提醒之前,需要先获取授权
self.eventStore = EKEventStore()
self.reminders = [EKReminder]()
self.eventStore.requestAccess(to: .reminder) {
(granted: Bool, error: Error?) in
if granted{
// 获取授权后,我们可以得到所有的提醒事项
let predicate = self.eventStore.predicateForReminders(in: nil)
self.eventStore.fetchReminders(matching: predicate, completion: {
(reminders: [EKReminder]?) -> Void in
self.reminders = reminders
print(self.reminders.count)
DispatchQueue.main.async{
self.tableView?.reloadData()
}
})
}else{
print("获取提醒失败!需要授权允许对提醒事项的访问。")
}
}
}
//在本例中,只有一个分区
func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
//返回表格行数(也就是返回控件数)
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return self.reminders.count
}
//创建各单元显示内容(创建参数indexPath指定的单元)
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath)
-> UITableViewCell {
let cell = UITableViewCell(style: .subtitle,
reuseIdentifier: "myCell")
let reminder:EKReminder! = self.reminders![indexPath.row]
//提醒事项的内容
cell.textLabel?.text = reminder.title
//提醒事项的时间
let formatter = DateFormatter()
formatter.dateFormat = "yyyy-MM-dd"
if let dueDate = reminder.dueDateComponents?.date{
cell.detailTextLabel?.text = formatter.string(from: dueDate)
}else{
cell.detailTextLabel?.text = "N/A"
}
return cell
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
}
全部评论(1)
好像ios9不行呢 是不是这个只能用在ios10以上呢???航哥辛苦☺️
站长回复:都是可以用的,我刚又找了台iOS9的手机测试了下,是没问题的。