SiriKit 学习笔记(三) 解析和处理Intents

你 App 的Indents extension扩展的接口点是INExtension Object,它的主要作用是把indents引导给Siri去处理。

在extension里有三类objects来处理intents


一种Indents Object保存Siri收集的用户数据

一种Handler Object是你自定义的用以解析,确定并处理indents

一种Response object保存你的处理结果


当SiriKit有一个Indent需要处理时,它会请求INExtension寻找一个匹配的Handler,Handler都继承了相应的Protocol协议对应不同种类的indents。

这些Protocols都有相似的结构,有相应的方法解析,确认并处理相应等indent


实现一个handler必须实现相对应处理所配indents的方法,其他方法都为可选方法,利用这些方法优先解析和确认indents,再进行处理。

在进行验证过程中,Siri和用户进行交互获取额外需要的信息


下图为Siri和handler的流程图





向Handler Objects派发Intents


当intent被app接收,SiriKit请求Intents extension提供相应的handler object,SiriKit调用INExtension子类的 handlerForIntent: 方法,这就是你extension的接入点。

这个方法会返回SiriKit解析,确认和处理的Objects


下面代码块显示实现了 handlerForIntent: 方法提供的针对文本信息和VoIP(语音协议)的intents的handler objects。 这个结构同样可以用于其他的不同handler。

你先检查发过来的intent的类并返回相应的handler object。 你可以利用单一handler来处理所有你支持的intents或者创建分别不同的handler针对不同的intent。

下面例子,intents extension为所有文本相关的intents返回同一个handler object,为语音和视频intents返回不同的handler


 
  
 
  
  1. overridefunchandler(forintent:INIntent) -> AnyObject? {
  2. varhandler = nil
  3. ifintentisINSendMessageIntent ||
  4. intentisINSearchForMessagesIntent ||
  5. intentisINSetMessageAttributeIntent {
  6. handler = MyMessageHandler()
  7. }
  8. elseifintentisINStartAudioCallIntent {
  9. handler = MyAudioCallHandler()
  10. }
  11. elseifintentisINStartVideoCallIntent {
  12. handler = MyVideoCallHandler()
  13. }
  14. returnhandler
  15. }


因为你的Intent extension只有被需要的时候调用,所以你的INExtension子类和handler objects应当维持少而精简的信息量。

SiriKit通常会在一次单个intent的处理时要求提供handler object多次,它也许会花一些时间处理所有intent的参数,特别是,当Siri要求用户提供更多信息或解释其参数。

每次要求一个新的handler object保证了handler的有效性,同样也表示handler的方法不应当依赖cache起来的数据,她们应当永远处理新的请求。


解析Intent的参数


每一个解析indent的方法结构必须相同:

从indent object那获得parameter

验证并且去匹配你app的值

初始化合适的INIntentResolutionResult子类与你的解决方案

解决并返回结果


Indents Framework会为每一个parameter定义一个INIntentResolutionResult, 每一个子类必须实现类方法以返回是否完成任务或需要更多信息,

同样父类INIntentResolutionResult会包含解决通常的解决方案。 下面表列出了一些常见的解决方案: 





Table 3-1Possible outcomes when resolving intent parameters

Resolution

Examples

You successfully matched the value.

Specify this resolution if you can use the provided value to handle the intent. You should always strive toward a resolution of parameters, even if that means making educated guesses about what the user meant. For example, if the user specified the name “John” for a person and has only one contact with that name, you could resolve the parameter successfully to that contact. 

See the documentation for the appropriate resolution result object for the name of the method to use for successful results. 

A value was not required.

Specify this resolution when you do not need the value of the parameter to handle the intent. For example, you might return this result when the intent contains a goal for an open workout, which normally has no goal. 

Use the notRequired class method to create your resolution result object.

Values need disambiguation.

Specify this result when you identify two or more possible results and cannot choose one definitively. This result may lead to additional interactions with the user to choose one of the provided values. 

See the documentation for the appropriate resolution result object for the name of the method to use for disambiguating results. 

The value needs user confirmation.

Specify this result when you want the user to confirm the value you chose. Use this result when you identify a value, but you are not completely sure that it is the right value. For example, you might use this result when the value you chose is different than the one the user provided but you think the new value is what the user intended. Siri always asks the user to confirm values for some types of intents, such as those involving financial transactions. 

See the documentation for the appropriate resolution result object for the name of the method to use for confirming results. 

A value is required.

Specify this result when the value is missing for a parameter that you require. For example, you might return this result if the user requests a payment from another person but does not specify the payment amount. 

Use the needsValue class method to create your resolution result object.

The value is unsupported.

Specify this result when your app does not support a specific value or when that value conflicts with the values of other parameters. For example, you might return this result when the user wants to send a payment in Swiss francs but your app requires transactions to be in Euros or US Dollars. 

Use the unsupported class method to create your resolution result object.


下面代码例举了交通出行app如何验证终点位置,如果终点位置提供了并且在服务范围内,方法返回成功结果,如果超出范围会返回不支持该结果。

如果没有提供数据,方法会询问用户输入:




Listing 3-2Resolving a required parameter of an intent

  1. func resolveDropOffLocation(forRequestRide intent: INRequestRideIntent,
  2. with completion: (INPlacemarkResolutionResult) -> Void) {
  3. let location = intent.dropOffLocation
  4. var result : INPlacemarkResolutionResult = nil
  5. if location != nil {
  6. // If the locaiton is valid, use it; otherwise,
  7. // let the user know it is not supported
  8. if self.locationIsInsideServiceArea(location) {
  9. result = INPlacemarkResolutionResult.successWithResolvedValue(location)
  10. }
  11. else {
  12. result = INPlacemarkResolutionResult.unsupported()
  13. }
  14. }
  15. else {
  16. // Ask for the drop-off location.
  17. result = INPlacemarkResolutionResult.needsValue()
  18. }
  19. // Return the result.
  20. completion(result)
  21. }

确认一个Request: SiriKit在所有怕人阿meters被解析完后会进行确认,利用确认方法去验证服务是否可用。实现确认方法并发必须。 User会被prompted confirmation(妈个鸡翻译特么累),Siri在confirmation界面上展示responseobject,用以在真正处理事务前再次确认。 在一些处理比如金融操作,不可返回操作(比如删除信息)等将会用到。
Listing 3-2Resolving a required parameter of an intent

OBJECTIVE-C



  1. func confirmStartWorkout(startWorkout intent: INStartWorkoutIntent,
  2. completion: (INStartWorkoutIntentResponse) -> Void) {
  3. // Make sure the app is ready.
  4. // Provide the response.
  5. let response = INStartWorkoutIntentResponse(code: .ready, userActivity: nil)
  6. completion(response)
  7. }

处理一个Request 最后一步是处理intent, 处理方法有以下两个责任:
  • 处理intent及相关的任务
  • 返结果并返回app处理的过程信息
Listing 3-2Resolving a required parameter of an intent

Swift


  1. func handleStartWorkout(startWorkout intent: INStartWorkoutIntent,
  2. completion: (INStartWorkoutIntentResponse) -> Void) {
  3. let response = INStartWorkoutIntentResponse(code: .continueInApp, userActivity: nil)
  4. completion(response)
  5. }

每一个结果object都支持额外的NSUserActivity Object,伴随如何启动你app的信,如果你不说明这个object,SiriKit会为你创建一个并 插入一个INInteraction Object,如果你想要提供额外信息,你可以自己创建NSUserActivity Object并在userInfo字典中添加信息



Listing 3-2Resolving a required parameter of an intent

OBJECTIVE-C


你可能感兴趣的:(swift_Siri)