SiriKit框架详细解析(五) —— 编程指南之Intents和Intents UI扩展(一)

SiriKit框架详细解析(五) —— 编程指南之Intents和Intents UI扩展(一),第1张

SiriKit是您通过Siri提供内容的一种方式。 它还允许您向 Maps 应用添加对服务的支持。 要支持 SiriKit ,您可以使用 Intents 框架和 Intents UI 框架来实现一个或多个扩展,然后将这些扩展包含在iOS应用程序中。 当用户通过Siri或Maps请求特定类型的服务时,系统会使用您的扩展来提供这些服务。

仅当您的应用程序实现以下类型的服务之一时才添加SiriKit支持:

汽车制造商可以使用 CarPlay intents 允许用户使用语音命令控制汽车功能。

每种类型的服务代表您可以支持的功能域,每个域定义一个或多个意图供您支持。 意图是表示用户意图的对象。 Siri和Maps创建意图对象以响应用户请求,并使用任何用户指定的信息填充它们。 例如,发送消息的意图可能包括消息的接收者和内容。 您使用intent对象提供适当的响应并执行相关的任务。 有关支持的域及其意图的更多信息,请参阅 Intents Domains 。

Siri 和 Maps 通过两种不同类型的扩展与您的应用服务进行互动:

您必须提供 Intents 扩展才能支持 SiriKit 。您的Intents扩展程序负责处理意图并提供Siri和Maps可用于与用户通信的信息。提供 Intents UI 扩展是可选的,但是通过Siri与您的应用进行交互的方式对您的用户来说似乎很熟悉。例如,Intents UI扩展可以显示横幅和其他特定于应用的信息,以强化您的应用正在提供响应。

有关用于实现Intents扩展的类的信息,请参阅 Intents Framework Reference 。有关用于实现 Intents UI 扩展的协议的信息,请参阅 Intents UI Framework Reference 。

Siri处理将用户的语音请求转换为扩展可以处理的可 *** 作意图所需的语言处理和语义分析。 Siri和Maps应用程序管理所有用户交互,并使用标准系统界面向用户显示结果。 您的角色主要是提供要显示的数据。 如果您的应用程序包含Intents UI扩展,您还可以提供自定义界面来补充默认系统界面。

乘车预订和餐厅预订主要由 Maps 应用程序处理,尽管用户也可以使用Siri预订游乐设施。 您的Intents扩展程序处理源自Maps应用程序的交互,其处理方式与处理来自Siri的请求的方式相同。 如果您自定义用户界面,您的 Intents UI 扩展可以根据请求来自Siri还是Maps来进行不同的配置。

Siri 和 Maps 通过您的 Intents 扩展程序与您的应用互动。 Intents扩展的入口点是 INExtension 对象,其唯一的工作是将Siri指向能够响应用户请求的对象。实现 Intents 扩展时,您经常使用三种类型的对象:

当您的扩展程序有意图处理时,Siri会询问您的 INExtension 对象是否有能够处理该意图的对象。处理程序对象可以是您想要的任何类型,但它必须实现处理给定意图所需的特定方法。每个 intent 都有一个与其处理程序必须采用的关联协议。该协议的方法分为三组:解决方法,确认方法和处理方法。您可以实现所需的方法,并向Siri提供有关您计划如何处理意图的信息。

图2-1说明了Siri与扩展中的处理程序对象之间的高级别流程。在该示例中,当用户要求使用乘车预订服务预订乘车时,Siri创建具有乘坐参数的意图对象并将其发送给处理者。处理程序将intent对象中的数据解析为可用于完成行程的值。当所有骑行参数都已解决后,Siri要求处理者确认其计划如何处理乘坐请求并执行任何最终验证。在确认阶段,处理程序提供一个响应对象,其中包含骑行的详细信息,Siri可能会向用户显示。如果用户接受了乘坐,Siri要求乘车请求处理者处理该意图。处理程序通过预订车辆并回复预订车辆的详细信息来回应。

有关如何创建扩展的一般信息,请参阅 App Extension Programming Guide 。

要支持 SiriKit ,请在您的iOS应用中添加 Intents extension 。

Xcode提供的 Intents 扩展模板包含一个 INExtension 子类供您自定义。 您可以使用该类来创建处理意图所需的处理程序对象。 Siri使用您的扩展的 Infoplist 文件来发现它支持的意图。 Xcode提供的 Infoplist 文件主要是配置的,但您必须修改它的一部分以指定扩展程序处理的意图。

这个key是必需的。您可以支持给定域中的所有或部分意图,并且您的扩展可以支持任意数量的域。该值必须包含扩展支持的所有 intent 类。

此键是可选的。该值包含您需要解锁设备的 intent 类的子集。如果处理意图涉及访问磁盘上的受保护文件或 *** 纵敏感用户数据,则可能在此列表中包含 intent 。

实现扩展的行为涉及以下任务:

有关可用意图的列表以及为每个意图实现的关联类和协议,请参阅 Intents Domains 。

在使用Intents扩展程序之前,在注册任何特定于用户的词汇表之前,您的iOS应用程序必须请求授权才能使用Siri。 要请求授权,请执行以下 *** 作:

您的iOS应用首次调用 requestSiriAuthorization: 方法时,系统会显示一条alertd窗,提示用户授权您的应用。d窗包括您在应用的 Infoplist 文件的 NSSiriUsageDescription 键中提供的使用说明字符串。用户可以批准或拒绝您的应用程序的授权请求,并可以稍后在“设置”应用中更改您应用的授权状态。系统会记住您的应用程序的授权状态,以便后续调用 requestSiriAuthorization: 方法不会再次提示用户。

您的 Intents 扩展程序是代表您的应用程序执行的代理程序,应该能够执行与您的应用程序相同的服务。由于您的iOS应用和 Intents 扩展执行许多相同的任务,请考虑以下事项:

要测试 Intents 扩展,必须在设备上运行它。 Xcode支持直接从Xcode项目启动Intents扩展,并在设备上运行时对其进行调试。

当您向项目添加Intents扩展时,Xcode会自动创建一个运行该扩展的 scheme 。

您无法在模拟器中调试 Intents 扩展。

Xcode构建您的应用和扩展,将它们安装在设备上,然后启动Siri。

首次安装您的扩展程序时,Siri可能无法立即识别您的应用扩展程序。您可能需要等待几分钟才能发出任何相关命令。同样,在更新Infoplist文件时,您可能需要等待几分钟,然后Siri才能识别出更改。

您的iOS应用程序使用 Intents 框架执行特定任务:

用户可以为Siri配置与设备其余部分不同的语言。 在iOS应用程序中,系统使用特定于设备的语言设置检索本地化内容。 在 Intents 扩展中,系统使用Siri语言检索本地化内容。 如果您的应用与扩展程序共享本地化内容,则必须使用 Siri 语言共享该内容,您的应用可以使用 INPreferences 类的 siriLanguageCode 方法检索该语言。

有关获取Siri语言的更多信息,请参阅 INPreferences Class Reference 。

在 Intents 扩展中,处理程序对象执行解析,确认和处理Siri发送的intent对象的关键工作。每个intent对象都有一个专门为处理该intent而设计的相关协议。例如, INRequestRideIntent 对象的处理程序采用 INRequestRideIntentHandling 协议。

每种协议的方法分为三组:

实现处理程序时,必须始终实现处理intent的方法。所有其他方法都是可选的,但建议使用。解决和确认方法是您在尝试处理意图之前验证意图内容的机会。您还可以使用这些方法来标识或创建处理意图所需的内部数据对象。

有关意图列表和相应的意图处理协议,请参阅 Intents Domains 。

在意图的解决阶段,Siri要求您的处理程序解析关键参数并确认您打算使用的值。因为说出了来自用户的数据,所以可能存在丢失或模糊的信息。解决阶段是您验证所提供数据的机会,并让Siri知道您是否需要澄清或更多信息。建议您为给定的处理程序协议实现所有解析方法。虽然您可能不会使用所有参数,但每种方法都会告诉Siri您是否在自己的数据结构中找到了适当的值。

您使用解析结果对象将解析结果传回 SiriKit ,解析结果对象是 INIntentResolutionResult 类的实例。您可能需要解析每种参数类型的不同子类。例如,在以 INPerson 对象的形式解析联系人时,将返回 INPersonResolutionResult 类的实例。实例化子类时,请使用与解析工作结果相对应的创建方法。表3-1列出了可能的结果,并说明了何时使用每种结果。

Table 3-1 Possible outcomes when resolving intent parameters

解析参数时,尝试尽快达成成功的解决方案。 询问更多信息会导致额外的用户交互以及对处理程序的额外调用,从而导致延迟并可能使用户感到沮丧。 相反,尝试根据用户的模式和习惯选择合理的值,并仅在需要时要求消除歧义或确认。

Listing 3-1 显示了乘坐预订应用程序的示例,该应用程序验证了乘车的下车位置。 如果存在一个下车位置,则该方法返回一个成功的结果;否则,该方法返回表示需要该值的结果。

与SiriKit的交互通过您的 Intents 应用扩展程序进行,您可以在iOS或watchOS应用程序包中进行。 Intents app 扩展程序处理与SiriKit的大多数交互,但您的应用程序需要了解这些交互,并且在某些情况下可能会在实现这些交互时发挥积极作用。

配置Xcode项目需要几个步骤。 除了向项目添加 Intents 应用扩展目标外,您还必须对应用进行一些小的更改。

启用Siri功能可为您的应用添加一组权利。 App Store要求任何包含Intents扩展程序的iOS应用程序或watchOS应用程序都存在这些权利。

在Xcode中打开您的应用程序项目。

添加 Intents 应用程序扩展目标提供了构建Intents扩展所需的初始文件,并配置您的Xcode项目以构建该扩展并将其包含在您的应用程序包中。

将 Intents 扩展目标添加到项目后,配置Xcode提供的默认 Infoplist 文件以指定您支持的意图。 SiriKit使用扩展程序的 Infoplist 文件中的信息来确定要路由到您的扩展程序的意图。

在iOS中包含 IntentsRestrictedWhileLocked 键是可选的。您可以使用它来扩充需要解锁设备的意图列表。某些意图(例如涉及金融交易的意图)总是要求解锁用户的设备。对于这些意图,Siri会自动要求用户解锁设备,无论您是否将其包含在 IntentsRestrictedWhileLocked 键下。在 watchOS 中,所有意图都要求解锁设备。

当用户的话语模糊以至于它解析为多个意图时,SiriKit会使用 IntentsSupported 键中的意图顺序来确定发送给您的应用的意图。 通过将最相关的那些放在数组前面,先组织您的意图列表。 当Intents扩展支持具有相似语义的多个域时,优先考虑意图尤其重要。 例如,支持电话和消息传递意图的应用程序可能会选择通过发起呼叫来优先发送消息。

某些意图可能需要为您的Xcode项目或您的应用程序执行其他配置步骤。 例如,在实施乘车预订应用程序时, Maps 希望您提供描述服务的覆盖范围的 GeoJSON 文件。 有关任何特殊要求的信息,请参阅参考文档。

Xcode支持直接从Xcode项目启动 Intents app 扩展,并在模拟器或设备上运行时对其进行调试。 要运行和调试Intents扩展:

首次安装扩展程序时,Siri可能无法立即识别您的应用程序扩展程序,您可能需要等待几分钟才能发出任何相关命令。 同样,在更新扩展程序的 Infoplist 文件时,您可能需要等待几分钟,然后Siri才能识别出任何更改。

DLL文件(Dynamic Linkable Library 即动态链接库文件),是一种可执行文件,它允许程序共享执行特殊任务所必需的代码和其他资源 比较大的应用程序都由很多模块组成,这些模块分别完成相对独立的功能,它们彼此协作来完成整个软件系统的工作。可能存在一些模块的功能较为通用,在构造其它软件系统时仍会被使用。在构造软件系统时,如果将所有模块的源代码都静态编译到整个应用程序 EXE 文件中,会产生一些问题:一个缺点是增加了应用程序的大小,它会占用更多的磁盘空间,程序运行时也会消耗较大的内存空间,造成系统资源的浪费;另一个缺点是,在编写大的 EXE 程序时,在每次修改重建时都必须调整编译所有源代码,增加了编译过程的复杂性,也不利于阶段性的单元测试。 Windows 系统平台上提供了一种完全不同的较有效的编程和运行环境,你可以将独立的程序模块创建为较小的 DLL 文件,并可对它们单独编译和测试。在运行时,只有当 EXE 程序确实要调用这些 DLL 模块的情况下,系统才会将它们装载到内存空间中。这种方式不仅减少了 EXE 文件的大小和对内存空间的需求,而且使这些 DLL 模块可以同时被多个应用程序使用。Windows 自己就将一些主要的系统功能以 DLL 模块的形式实现。 一般来说,DLL 是一种磁盘文件,以dll、DRV、FON、SYS 和许多以 EXE 为扩展名的系统文件都可以是 DLL。它由全局数据、服务函数和资源组成,在运行时被系统加载到调用进程的虚拟空间中,成为调用进程的一部分。如果与其它 DLL 之间没有冲突,该文件通常映射到进程虚拟空间的同一地址上。DLL 模块中包含各种导出函数,用于向外界提供服务。DLL 可以有自己的数据段,但没有自己的堆栈,使用与调用它的应用程序相同的堆栈模式;一个 DLL 在内存中只有一个实例;DLL 实现了代码封装性;DLL 的编制与具体的编程语言及编译器无关。

采纳哦

可以通过下面两个属性:

tableLayoutPanel1RowStyles[0]Height += 10;

tableLayoutPanel1ColumnStyles[0]Width += 10;

来找到任意一个单元修改它的行高度和列宽度。在窗口运行期间,任何时候都可以去修改这两个值。

查看文件的系统依赖,可以用dependency

walker打开。

查看二进制内容,可以用utraedit编辑器打开。

查看机器码程序,可以c++或debug打开。

以上就是关于SiriKit框架详细解析(五) —— 编程指南之Intents和Intents UI扩展(一)全部的内容,包括:SiriKit框架详细解析(五) —— 编程指南之Intents和Intents UI扩展(一)、SiriKit框架详细解析(三)—— 创建Intents App扩展(一)、应用程序扩展〈dll>是什么意思等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9304567.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-27
下一篇 2023-04-27

发表评论

登录后才能评论

评论列表(0条)

保存