三、Reminders 读写

简介

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值