简介
提醒是一种与时间和地点相关联的任务。提醒与日历中的事件有相似之处,但提醒可以被标记为完成状态,并且提醒可能不需要精确的跨越某一个时间段。
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:
本文介绍了如何使用EKReminder API在iOS应用中实现提醒事项功能,包括建立与eventstore的连接、获取不同状态的提醒、创建和编辑提醒以及保存和删除提醒等关键步骤。
926

被折叠的 条评论
为什么被折叠?



