HomeKit框架详细解析(六) —— 观察HomeKit数据库更改 Observing HomeKit Database Changes

版本记录

版本号 时间
V1.0 2018.01.30

前言

目前全世界都在积极投入AI领域,我国的互联网公司也是积极在AI方面进行投入布局,比如BAT以及今日头条等互联网公司都有自己的AI实验室。这里面和AI相关的目前可见的比如说智能家居,比如小米就出一款智能音响,苹果公司在这方面也不甘落后,推出框架HomeKit,接下来几篇我们就一起看一下这个框架。感兴趣的可以参考上面几篇文章。
1. HomeKit框架详细解析(一) —— 基本概览
2. HomeKit框架详细解析(二) —— HomeKit介绍 Introduction to HomeKit
3. HomeKit框架详细解析(三) —— 启用HomeKit Enabling HomeKit
4. HomeKit框架详细解析(四) —— 获取Home的布局 Getting the Home Layout
5. HomeKit框架详细解析(五) —— 创建Homes并添加配件 Creating Homes and Adding Accessories

观察HomeKit数据库的变化 - Observing HomeKit Database Changes

每个home里有一个HomeKit数据库。 如下图所示,数据库与用户的iOS设备安全地同步,并可能与被授权访问家庭的访客用户iOS设备同步。 为了向用户显示最新的数据,您的应用程序需要观察对此数据库的更改。


About HomeKit Delegation Methods - 关于HomeKit代理方法

HomeKit使用delegation design pattern来通知您的App对HomeKit对象的更改。通常,如果您的应用程序使用完成处理程序参数调用HomeKit方法,并且方法成功,则关联的委托消息将发送到在相同或远程iOS设备上运行的其他HomeKit应用程序。这些应用程序甚至可以由iOS设备上的访客用户运行。如果您的应用程序启动更改,则代理消息不会发送到您的应用程序。因此,将代码添加到完成处理程序和关联的代理方法中以根据需要重新加载数据和更新视图。如果Home布局显着变化,请重新加载有关该家庭的所有信息。在完成处理程序的情况下,在更新应用程序之前检查方法是否成功。 HomeKit还会调用委托方法来通知您的应用程序对家庭网络状态的更改。

例如,如果(1)响应用户操作,(2)您的应用程序调用addRoomWithName:completionHandler:并且不发生错误,(3)完成处理程序应该(4)更新家庭的视图。如果成功,HomeKit(5)将home:didAddRoom:消息发送给其他应用程序中的家庭代理。因此,你的 home:didAddRoom:方法也应该(6)更新家庭的视图。

应用程序需要在前台接收这些委托消息。 当您的应用在后台时,更改不会进行批处理。 如果您的应用程序在后台,而另一个应用程序成功地将room添加到home中,则您的应用程序不会收到home:didAddRoom:消息。 当您的应用程序进入前台时,您的应用程序会收到一个homeManagerDidUpdateHomes:消息,它会通知您的应用程序重新加载其所有数据。


Observing Changes to the Collection of Homes - 观察Homes的更改

要在主home或住宅集合发生更改时接收委托消息,请设置home manager代理并实施HMHomeManagerDelegate协议。

所有应用程序都需要实现homeManagerDidUpdateHomes:方法,该方法在HomeKit完成对home的初始获取后调用。 在调用此方法之前,对于新创建的home managerprimaryHome属性为nil,而homes属性为空数组。 homeManagerDidUpdateHomes:方法在应用程序到达前台时也被调用,并且在后台进行更改。 homeManagerDidUpdateHomes:方法应该重新加载与家庭相关的所有数据。

观察homes的改变

    1. home manager代理协议和home manager属性添加到您的类接口。
@interface AppDelegate () <HMHomeManagerDelegate>
 
@property (strong, nonatomic) HMHomeManager *homeManager;
 
@end
    1. 创建home manager对象并设置代理
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    self.homeManager = [[HMHomeManager alloc] init];
    self.homeManager.delegate = self;
 
    return YES;
    1. 当home更改时,实现代理方法,例如,如果多个视图控制器显示有关homes的信息,则可以发布更改通知,以更新所有视图。
- (void)homeManagerDidUpdateHomes:(HMHomeManager *)manager {
    // Send a notification to the other objects
    [[NSNotificationCenter defaultCenter] postNotificationName:@"UpdateHomesNotification" object:self];
}
 
- (void)homeManagerDidUpdatePrimaryHome:(HMHomeManager *)manager {
    // Send a notification to the other objects
    [[NSNotificationCenter defaultCenter] postNotificationName:@"UpdatePrimaryHomeNotification" object:self];
}

视图控制器注册更改通知并执行相应的操作。

[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(updateHomes:) name:@"UpdateHomesNotification" object:nil];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(updatePrimaryHome:) name:@"UpdatePrimaryHomeNotification" object : nil];

观察单个home的更改 - Observing Changes to Individual Homes

显示home信息的视图控制器应该是home对象的代理,并在home更改时更新其视图。

观察指定的home的更改

    1. 将home代理协议添加到您的类接口。
@interface HomeViewController () <HMHomeDelegate>
 
@end
    1. 设置配件的代理
home.delegate = self;

Bridge Note: When you add a bridge to a home, the accessories behind the bridge are automatically added to the home. Your delegate receives a home:didAddAccessory: message for each accessory behind the bridge, but your delegate doesn’t receive a home:didAddAccessory: message for the bridge. 桥连注意:当您添加桥到home中时,桥后面的配件会自动添加到home中。 您的代理收到一个家庭:home:didAddAccessory:消息为桥后面的每个附件,但您的代理不会收到一个桥的home:didAddAccessory:消息。


Observing Changes to Accessories - 观察配件的更改

配件的状态可以随时改变。 附件可能无法到达,可能超出范围,或可能被关闭。 相应地更新用户界面以反映配件的当前状态,特别是如果您的应用允许用户控制配件。

在这些步骤中,假设您已经从HomeKit数据库中检索了一个附件对象,如Getting the Accessories in a Room中所述。

观察指定的配件的更改

    1. 在类的接口中添加配件代理协议
@interface AccessoryViewController () <HMAccessoryDelegate>
 
@end
    1. 设置配件的代理
accessory.delegate = self;
- (void)accessoryDidUpdateReachability:(HMAccessory *)accessory {
    if (accessory.reachable == YES) {
       // Can communicate with the accessory
    } else {
       // The accessory is out of range, turned off, etc
    }
}

如果显示服务状态及其特征,请实施以下代理方法以相应更新视图:

要获取配件的服务,请参阅 Accessing Services and Their Characteristics

后记

本篇已结束,后面更精彩~~~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容