您的位置:首页 > 其它

三、Reminders 读写

2015-05-03 16:11 106 查看

简介

提醒是一种与时间和地点相关联的任务。提醒与日历中的事件有相似之处,但提醒可以被标记为完成状态,并且提醒可能不需要精确的跨越某一个时间段。

EKReminder 从EKCalendarItem类继承,所以你可以使用相同的方法展现提醒。比如:可以使用方法addAlarm来添加alarm;或者使用方法addRecurrenceRule来设置重复规则

获取Reminders

首先,你需要建立与event store之间的连接,就像日历事件中的操作一样。

同样, 在IOS6及以后,需要获取Calendar database的权限

[store requestAccessToEntityType:EKEntityTypeReminder completion:^(BOOL granted, NSError *error) {
// handle access here
//异步回调
}];


使用谓词获取提醒事件

接口: fetchRemindersMatchingPredicate:(NSPredicate *)predicate
completion:(void (^)(NSArray *reminders))completion


谓词的创建有三种方式:

1.查找未完成的提醒

predicateForIncompleteRemindersWithDueDateStarting:ending:calendars:

如果starting为nil,则表示从最开始查找;如果ending为nil,则表示查找到最后;同理,如果都为nil,则表示查找所有的未完成提醒

2.查找完成的提醒

predicateForCompleteRemindersWithDueDateStarting:ending:calendars:

如果starting为nil,则表示从最开始查找;如果ending为nil,则表示查找到最后;同理,如果都为nil,则表示查找所有的已完成提醒

3.查找所有提醒

predicateForRemindersInCalendars:

获取提醒
NSPredicate *predicate = [store predicateForRemindersInCalendars:nil];

[store fetchRemindersMatchingPredicate:predicate completion:^(NSArray *reminders) {
for (EKReminder *reminder in reminders) {
// do something for each reminder
// 与日历事件不同的是,该方法为异步回调,不需要另外开线程
//如果想要停止获取的操作,return cancelFetchRequest
}
}];


使用唯一标识获取提醒事件

接口:calendarItemWithIdentifier


该方法可以获取日历事件和提醒事件,而 eventWithIdentifier:只可以获取日历事件。

创建和编辑提醒

创建:

+ (EKReminder *)reminderWithEventStore:(EKEventStore *)eventStore


跟日历事件相似,提醒可以通过时间或位置进行触发

编辑:

与时间相关的属性:

1.startDateComponents

2.dueDateComponents

与完成状态相关的属性:BOOL completed。设置为YES时表示完成,同时会自动将完成时间设置为当前时间

保存和删除提醒

保存和删除提醒与日历事件类似

保存:

saveReminder:commit:error:

删除:

removeReminder:commit:error:
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  提醒 Reminder