版本记录
版本号 | 时间 |
---|---|
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 manager
,primaryHome属性为nil,而homes属性为空数组。 homeManagerDidUpdateHomes:方法在应用程序到达前台时也被调用,并且在后台进行更改。 homeManagerDidUpdateHomes:方法应该重新加载与家庭相关的所有数据。
观察homes的改变
- 将
home manager
代理协议和home manager
属性添加到您的类接口。
- 将
@interface AppDelegate () <HMHomeManagerDelegate>
@property (strong, nonatomic) HMHomeManager *homeManager;
@end
- 创建home manager对象并设置代理
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
self.homeManager = [[HMHomeManager alloc] init];
self.homeManager.delegate = self;
return YES;
- 当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的更改
- 将home代理协议添加到您的类接口。
@interface HomeViewController () <HMHomeDelegate>
@end
- 设置配件的代理
home.delegate = self;
- 实现HMHomeDelegate协议,例如,实现home:didAddAccessory:和home:didRemoveAccessory:方法来更新显示附件的视图。 要获得附件所属的room,请使用 HMAccessory类中的room属性。 (附件的默认room由roomForEntireHome方法返回。)
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中所述。
观察指定的配件的更改
- 在类的接口中添加配件代理协议
@interface AccessoryViewController () <HMAccessoryDelegate>
@end
- 设置配件的代理
accessory.delegate = self;
- 实现协议 HMAccessoryDelegate,例如,实现accessoryDidUpdateReachability:方法,以启用或者关闭配件控制。
- (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。
后记
本篇已结束,后面更精彩~~~