借助 Ambient API,您的应用可以将环境设备连接到用户的 Google 相册账号,并显示用户选择的照片。
Ambient API 流程
下面详细介绍了 Ambient API 如何连接设备,然后检索和显示媒体项:
检查现有设备(推荐):在创建新设备之前,建议先检查当前用户是否已有设备。您的应用应维护内部用户与 Google 提供的
deviceId之间的映射,以用于用户通过您的应用创建的任何设备。如果找到用户的deviceId,您可以继续刷新其授权令牌(如果需要)。启动 OAuth 2.0 授权(并可选择创建设备):通过请求授权代码来开始 OAuth 2.0 for TV and Limited Input Devices 流程。
创建新设备:您的应用通过调用
CreateDevice并提供有效的 v4 UUID,在用户的 Google 相册账号中创建设备。成功创建设备后,API 将返回一个包含 Google 分配的
deviceId的AmbientDevice对象。对于您的应用来说,存储此deviceId并将其与用户相关联至关重要。显示
settingsUri:AmbientDevice对象包含settingsUri。向用户显示此 URI(通常以二维码的形式),用户可以使用移动设备扫描该 URI。此 URI 会将用户定向到 Google 相册应用,用户可以在其中配置要在氛围设备上显示的媒体来源(例如相册)。轮询
mediaSourcesSet:您的应用应定期调用GetDevice方法(提供deviceId),以检查环境设备的状况。监控AmbientDevice响应中的mediaSourcesSet字段。最初为 false。当用户在 Google 相册应用中成功选择媒体来源后,此字段将更改为 true。
AmbientDevice响应包含一个pollingConfig,其中包含一个pollInterval,您应将其用作轮询频率的指南。检索媒体项:当
mediaSourcesSet返回 true 时,应用可以开始提取用户选择的媒体项。调用
ListMediaItems方法,并提供deviceId。该 API 将返回一个ListMediaItemsResponse,其中包含AmbientMediaItem对象列表。每个AmbientMediaItem都包含详细信息,例如id、createTime和包含其他元数据的MediaFile对象。MediaFile包含一个baseUrl,您可以使用它来提取媒体项的实际字节。如需详细了解其他baseUrl参数,请参阅列出和检索媒体项指南。显示媒体项:使用
MediaFile中的baseUrl下载媒体内容并在环境设备上显示。
重要注意事项
设备限制和管理:
- 设备限制:请注意,每个应用用户最多只能使用 100 台设备。
- 设备活动和令牌:您需要管理设备和用户授权令牌的生命周期。请考虑设备保持活跃状态的时间,以及在设备变为不活跃状态或令牌过期时,您将如何处理令牌刷新或重新授权。
如需了解更多详情,请参阅创建和管理设备指南。
处理媒体项:
- 媒体内容项使用情况:了解如何使用
baseUrl正确提取和处理媒体内容项内容,包括任何必要的身份验证或参数。 - 错误处理:为 API 调用实现可靠的错误处理,包括设备为
NOT_FOUND的情况、未设置媒体源时的FAILED_PRECONDITION以及达到设备限制时的RESOURCE_EXHAUSTED等场景。
列出和检索媒体内容指南包含更多详细信息,包括有关内容政策和过滤的信息。
后续步骤
- 配置应用:验证您是否拥有必要的凭据,以及是否已为适用于电视和输入受限的设备的 OAuth 2.0 配置应用。
- 查看 Ambient API 参考文档:探索详细的参考文档,了解所有可用的方法、请求和响应参数以及错误代码。