
Intent的概念
Siri做完語(yǔ)音識(shí)別和語(yǔ)義分析之后,將結(jié)構(gòu)化語(yǔ)音分析結(jié)果打包成一個(gè)某個(gè)領(lǐng)域(Domain)的意圖(Intent),然后交給支持這個(gè)意圖(Intent)的第三方應(yīng)用(比如微信),第三方應(yīng)用被啟動(dòng),從傳入的Intent中獲取相應(yīng)的信息,完成操作。
例如,上圖演示中提到了的例句 “I need to send a message to Nancy via WeChat saying I'll be five minutes late",
- 領(lǐng)域 (Domain):Messaging
- 意圖 (Intent):Send a message (INSendMessageIntent)
- 意圖參數(shù) (Intent Parameter)
- 收件人(recipients):Nancy
- 消息內(nèi)容(content):I'll be five minutes late
按照蘋(píng)果官方的iOS文檔,現(xiàn)在SiriKit共支持7個(gè)領(lǐng)域的共計(jì)22種意圖:
- 語(yǔ)音通話 VoIP Calling:打電話、發(fā)起視頻電話、查通話記錄
- 信息 Messaging:發(fā)信息、搜索信息
- 照片搜索 Photo Search:搜索照片、播放照片幻燈片
- 個(gè)人之間的付款 Payments:向某人付款、向某人收款
- 健身 Workouts:開(kāi)始健身、暫停健身、恢復(fù)健身、結(jié)束健身、取消健身
- 打車 Ride Booking:查看附近可用的車輛、訂車、查看訂單
- 車載 CarPlay:切換音頻輸入源、空調(diào)、除霜、座椅加熱、FM調(diào)臺(tái) (只針對(duì)汽車廠商)
IntentsExtension
Siri通過(guò)Intents extension的擴(kuò)展方式和我們的應(yīng)用進(jìn)行交互。
其中,類型為INExtension的對(duì)象扮演著Intents extension擴(kuò)展中直接協(xié)同Siri對(duì)象共同響應(yīng)用戶請(qǐng)求的關(guān)鍵角色。
1.選中我們的應(yīng)用,進(jìn)入項(xiàng)目總覽界面,新增一個(gè)TARGET
2.選擇Application Extension中的Intents extension
3.下一步,指定擴(kuò)展的名字,語(yǔ)言及其他配置項(xiàng)
4.如果要自定義siri交互的UI,需要勾選Include UI Extension
5.完成


創(chuàng)建的Targe都會(huì)有一個(gè)plist文件

plist文件中,NSExtension是擴(kuò)展配置NSExtensionAttributes包含IntentsSupported和IntentsRestrictedWhileLocked兩個(gè)配置項(xiàng),分別是支持的Intent和鎖屏?xí)r限制使用的Intent,這里我們配置的都是發(fā)送信息的Intent。
鎖屏的時(shí)候,出于安全考慮,限制通過(guò)Siri方式訪問(wèn)一些信息,可以保護(hù)用戶隱私。
NSExtensionPrincipalClass指定了處理Intent的類UCIntentsHandler,他主要的工作就是根據(jù)不同的Intent,返回相應(yīng)的Intent處理對(duì)象。

處理一個(gè)Intent對(duì)象需要3個(gè)處理環(huán)節(jié):Resolve,Confirm,Handle
UCSendMessageIntentHandler實(shí)現(xiàn)了INSendMessageIntentHandling協(xié)議,協(xié)議中的方法就是這3個(gè)處理環(huán)節(jié)。
看一下這三個(gè)環(huán)節(jié)都做了什么事情

Resolve:將語(yǔ)音解析后INIntent對(duì)象中的關(guān)鍵信息提取出來(lái),進(jìn)行處理。不同Intent的協(xié)議需要處理的信息是不同的。
SendMessageIntent需要處理recipients,content


通過(guò)INIntentResolutionResult實(shí)例返回處理結(jié)果給siri,每一種信息對(duì)應(yīng)一個(gè)確切的子類,比如recipient,對(duì)應(yīng)的INPersonResolutionResult。
每一種resolution result又包含多種構(gòu)造方法,用于表示不同的處理結(jié)果:成功(找到了唯一匹配的收件人),需要解疑(找到了相同姓名的多個(gè)收件人),不存在(沒(méi)有此收件人),當(dāng)然,還有一些其他的狀態(tài),具體的可以閱讀官方文檔。
下面是Confirm的實(shí)現(xiàn)

Confirm里的實(shí)現(xiàn)不是必須的,但是蘋(píng)果強(qiáng)烈建議這么做。開(kāi)發(fā)者可以對(duì)Intent的信息添加一些額外的合理性檢查,再次確認(rèn)用戶的操作。
每一種Intent的處理結(jié)果會(huì)返回對(duì)應(yīng)的IntentResponse,生成對(duì)象的時(shí)候需要設(shè)置user actitvity,默認(rèn)可以設(shè)置為nil,關(guān)于UserActivity下面會(huì)介紹。
Handle code就是具體去執(zhí)行用戶的操作
演示效果就是這樣的
NSUserActivity對(duì)象可以保存一些context,其中的INInteraction屬性也包含了intent的一些信息,當(dāng)主應(yīng)用被siri或者用戶打開(kāi)時(shí),可以通過(guò)NSUserActivity,來(lái)完成一些喚醒操作。這部分蘋(píng)果的文檔上現(xiàn)在介紹的還不是很清楚,我沒(méi)有找到具體的例子和API介紹。估計(jì)和Handoff是類似的。
詞匯定義
定義app的自有詞匯可以幫助siri識(shí)別和你應(yīng)用相關(guān)的用戶命令,改善使用體驗(yàn)。

只能設(shè)置這幾種類型的特有詞匯
- 通訊錄名字
- 照片標(biāo)簽
- 相冊(cè)名稱
- 健身名稱
配置文件需要自己手動(dòng)創(chuàng)建,必須命名為AppIntentVocabulary.plist,放置在應(yīng)用base development language的.lproj路徑下。
添加兩個(gè)鍵在Root元素下ParameterVocabularies和IntentPhrases。plist配置文件中設(shè)置詞匯,只能設(shè)置兩種類型詞匯Ride options和健身名稱。
ParameterVocabularies是近義詞,同音詞定義。這個(gè)比較復(fù)雜,涉及到key值很多,具體查閱文檔吧。
IntentPhrases可以幫助解析intent,往往一個(gè)intent可以有多種表達(dá)方式。
IntentName:
INRequestRideIntent
IntentExamples:

詞匯識(shí)別配置文件的例子

Intent UI Extension
一個(gè)Intent UI Extension可以支持多個(gè)Intent,但是所有這些Intent共用一個(gè)viewcontroller
關(guān)于UI設(shè)計(jì),蘋(píng)果有一些建議,比如避免廣告,有應(yīng)用標(biāo)識(shí)等,具體可以參考官方文檔。創(chuàng)建步驟可以參考Intents Extension,plist只有IntentsSupported。
Intent UI Extension也是通過(guò)Viewcontroller來(lái)管理視圖的,它的PrincipalClass是UIViewController的子類。
生命周期與普通的ViewController類似
這個(gè)ViewController還需要實(shí)現(xiàn) INUIHostedViewControlling協(xié)議,并通過(guò)INInteraction和Sirikit進(jìn)行信息交互,INUIHostedViewControlling協(xié)議只有一個(gè)需要實(shí)現(xiàn)的方法

顯示效果如圖所示

可以看到,自定義的UI和SIRI默認(rèn)的UI重復(fù)了,對(duì)于約車和Message相關(guān)Intent,可以隱藏系統(tǒng)默認(rèn)的UI,此時(shí)需要實(shí)現(xiàn)INUIHostedViewSiriProviding協(xié)議的方法

最終效果
