iOS10新特性——SiriKit

苹果官网文档是这样描述的:

In order to support SiriKit, apps must support one of the following domains:

  • VoIP calling(语音、视频呼叫)
  • Messaging(信息通讯)
  • Payments(支付)
  • Photo(查找图片)
  • Workouts(健身)
  • Ride booking(预约出行)
  • Car commands (automotive vendors only)
  • CarPlay (automotive vendors only)
  • Restaurant reservations (requires additional support from Apple)
Paste_Image.png
Paste_Image.png
Paste_Image.png
Paste_Image.png
Paste_Image.png
Paste_Image.png
意图(Intents)

SiriKit 将上述六种行为描述为六种类型的意图(Intents),提供对应的Intent.framework和用于UI展示的IntentUI.framework两个工具包方便开发者实现上述功能。

意图的种类

查看苹果官方文档

意图的生命周期

一个典型的Intent事件的处理过程中有这三个步骤ResolveConfirmHandle

  1. Resolve阶段。在Siri获取到用户的语音输入之后,生成一个INIntent对象,将语音中的关键信息提取出来并且填充对应的属性。这个对象在稍后会传递给我们设置好的INExtension子类对象进行处理,根据子类遵循的不同协议来选择不同的解决方案。

  2. Confirm阶段。在上一个阶段通过handlerForIntent:(INIntent *)返回了处理Intent的对象,此阶段会依次调用confirm打头的实例方法来判断Siri填充的信息是否完成。匹配的判断结果包括Exactly one matchTwo or more matches以及No match三种情况。这个过程中可以让Siri向用户征求更具体的参数信息。

  3. Handle阶段。在confirm方法执行完成之后,Siri进行最后的处理阶段,生成答复对象,并且向此Intent对象确认处理结果然后执显示结果给用户看。

创建Intents Extension

SiriKit通过添加App Extension的方式来完成集成,这是一种独立于应用本身运行的代码结构,作为应用的扩展功能,只有在需要的时候系统会唤醒这些Extension代码来执行任务,然后在执行完毕之后将其杀死。

条件:

  • iOS10
  • Xcode8
  • 真机调试

新增Targets

开启Siri组件

Paste_Image.png

注意SiriKitDemo Extension中的info.plist文件

  • IntentsSupported 支持的意图类型,默认支持三种Messaging类型
  • IntentsRestrictedWhileLocked 锁屏支持的意图类型,默认为空
  • NSExtensionPrincipalClass 处理意图的类,需继承自INExtension
    Paste_Image.png

授权

  1. 在主App目录的info.plist中,新增Key-Value
    Paste_Image.png
  2. 在需要请求授权时,调用以下方法:
[INPreferences requestSiriAuthorization:^(INSiriAuthorizationStatus status) {
        switch (status) {
            case INSiriAuthorizationStatusNotDetermined: {
                NSLog(@"未决定");
                break;
            }
            case INSiriAuthorizationStatusRestricted: {
                NSLog(@"权限受限制");
                break;
            }
            case INSiriAuthorizationStatusDenied: {
                NSLog(@"拒绝授权");
                break;
            }
            case INSiriAuthorizationStatusAuthorized: {
                NSLog(@"已授权");
                break;
            }
        }
    }];
  1. 启动应用,请求授权对话框如下:


    IMG_0136.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容