TV 应用开发入门

TV 应用使用的结构与手机和平板电脑应用相同。这种相似性意味着,您可以修改现有应用,使其同样可以在 TV 设备上运行,也可以根据您已经在构建 Android 应用方面掌握的知识创建新的应用。

重要提示:您的应用必须符合特定要求,才有资格成为 Google Play 上的 Android TV 应用。如需了解详情,请参阅 TV 应用质量中所列的要求。

本指南介绍了如何准备用于构建 TV 应用的开发环境,以及使应用能够在 TV 设备上运行所需的最少量更改。

如需了解如何设计 TV 应用,请参阅为 TV 设计。另请参阅 Android TV GitHub 代码库中的示例应用。

确定媒体格式支持

如需了解 Android TV 支持的编解码器、协议和格式,请参阅以下文档:

设置 TV 项目

本部分介绍如何设置 TV 项目,无论您是要修改现有 Android 应用以使其在 TV 设备上运行,还是要创建新的 TV 应用。如果您已有 Android 应用,通过添加 Android TV 支持,您可以在重复使用现有应用架构的同时设计 TV 界面。

声明 TV Activity

旨在于 TV 设备上运行的应用必须在其清单中声明 TV 启动器 Activity。它使用 CATEGORY_LEANBACK_LAUNCHER intent 过滤器来执行此操作。此过滤器会将您的应用标识为支持 TV,并让 Google Play 将其识别为 TV 应用。当用户在其 TV 主屏幕上选择您的应用时,此 intent 会识别要启动的 activity。

以下代码段展示了如何在清单中添加此 intent 过滤器:

<application
  android:banner="@drawable/banner" >
  ...
  <activity
    android:name="com.example.android.MainActivity"
    android:label="@string/app_name" >

    <intent-filter>
      <action android:name="android.intent.action.MAIN" />
      <category android:name="android.intent.category.LAUNCHER" />
    </intent-filter>
  </activity>

  <activity
    android:name="com.example.android.TvActivity"
    android:label="@string/app_name"
    android:theme="@style/Theme.Leanback">

    <intent-filter>
      <action android:name="android.intent.action.MAIN" />
      <category android:name="android.intent.category.LEANBACK_LAUNCHER" />
    </intent-filter>

  </activity>
</application>

本例中的第二个 activity 清单条目指定它是要在 TV 设备上启动的 activity。

注意:如果您不在应用中添加 CATEGORY_LEANBACK_LAUNCHER intent 过滤器,那么在 TV 设备上运行 Google Play 的用户将看不到您的应用。此外,如果您的应用没有此过滤器,当您使用开发者工具将其加载到 TV 设备上时,该应用不会出现在 TV 界面中。

TV 应用的界面或现有应用的 TV 部分必须提供简单的界面,以便用户在距离电视 10 英尺的地方使用遥控器轻松导航。如果您要修改现有应用以便在 TV 上使用,请不要使用您用于手机和平板电脑的 TV 活动布局。如需了解有关设计 TV 应用的准则,请参阅为 TV 设计。如需详细了解 TV 界面布局的最低实现要求,请参阅构建 TV 布局

声明 TV 设备支持

通过声明 android.software.leanback 功能,声明您的应用是专为 Android TV 打造的。

如果您的应用同时在移动设备和 TV 上运行,请将 required 属性值设置为 false。如果您将 required 属性值设为 true,Google Play 只会将您的应用提供给 Android TV OS。

<manifest>
    <uses-feature android:name="android.software.leanback"
        android:required="false" />
    ...
</manifest>

将触摸屏声明为非必备条件

目标平台为 TV 设备的应用不依赖触摸屏进行输入。为明确这一点,您的 TV 应用的清单必须声明 android.hardware.touchscreen 功能并非必备功能。此设置会将您的应用标识为能够在 TV 设备上运行,并且您的应用必须在 Google Play 中被视为 TV 应用。以下代码示例展示了如何添加此清单声明:

<manifest>
    <uses-feature android:name="android.hardware.touchscreen"
              android:required="false" />
    ...
</manifest>

注意:您必须在应用清单中声明触摸屏并非必需,如此示例代码所示。否则,您的应用不会出现在 TV 设备上的 Google Play 中。

提供主屏幕图标和横幅

Android TV 应用必须针对每种本地化版本提供主屏幕图标和横幅图片。图标或横幅可用作显示在主屏幕上的应用和游戏行中的应用启动点,具体取决于 Android TV 设备。

如需将其添加到您的应用中,请按如下方式在清单中描述图标和横幅:

<application
    ...
    android:icon="@mipmap/ic_launcher"
    android:banner="@drawable/banner" >
    ...
</application>

主屏幕图标

与所有 Android 应用一样,Android TV 应用也必须提供主屏幕图标。如需了解有关为应用设计理想启动点的最佳实践以及详细的资源要求,请参阅 Android TV 应用图标和横幅指南

可以将 android:banner 属性与 <application> 标记一起使用,为所有应用 Activity 提供默认横幅;或者将 android:banner 属性与 <activity> 标记一起使用,为特定 Activity 提供横幅。

对于横幅,请使用尺寸为 320 x 180 像素的 xhdpi 资源。文字必须包含在图片中。如果您的应用支持多种语言,您必须针对每种受支持的语言提供单独的带文字的横幅版本。

更改启动器颜色

注意:在 Android 12 及更高版本中,Android TV 应用不支持使用 SplashScreen 平台 API 构建的自定义启动画面动画。

当 TV 应用启动时,系统会显示类似于不断扩大的实心圆的动画。要自定义此动画的颜色,请将 TV 应用或 Activity 的 android:colorPrimary 属性设置为特定颜色。此外,还要将两个过渡重叠属性设置为 true,如主题背景资源 XML 文件中的以下代码段所示:

<resources>
    <style ... >
      <item name="android:colorPrimary">@color/primary</item>
      <item name="android:windowAllowReturnTransitionOverlap">true</item>
      <item name="android:windowAllowEnterTransitionOverlap">true</item>
    </style>
</resources>

如需详细了解如何使用主题和样式,请参阅样式和主题

构建 Android TV OS 应用

大多数 AndroidX 库都可以用于 Android TV。使用架构组件,如 ViewModel 用于管理生命周期感知型界面数据,使用 Room 与本地 SQLite 数据库集成,集成方式与移动设备集成。

大多数 AndroidX 库都支持 Android TV。TV 应用可以使用与移动应用相同的架构组件。您甚至可以在不同类型的设备之间共享组件,因此只需专门提供 TV 应用的呈现逻辑即可。

Compose for TV

使用 Jetpack Compose 构建 TV OS 界面。Compose 是用于界面开发的现代 Android 平台。除了核心 Compose 库之外,Compose for TV 库还提供了专为大屏幕设计的专用组件:

请参阅在 Android TV 上使用 Jetpack Compose,了解如何使用 Compose for TV 构建 TV 应用。

Leanback 界面工具包(不推荐)

Leanback 界面工具包历来提供专为使用 Android View 和 fragment 的 TV 设备提供的 API 和界面微件:

请参阅使用 Leanback 界面工具包,了解如何使用 Leanback 界面工具包构建 TV 应用。

运行 TV 应用

运行您的应用是开发过程的一个重要环节。您可以在配置为支持 USB 调试或使用虚拟 TV 设备的 TV 设备上运行您的应用。

在实体设备上运行

按照以下步骤设置您的 TV 设备:

  1. 使用 USB 数据线将您的 TV 设备连接到开发计算机。如果需要,请参阅设备制造商提供的文档。
  2. 在您的 TV 设备上,转到设置
  3. 设备行中,选择关于
  4. 滚动到构建并选择构建多次,直到您看到“您现在已处于开发者模式!”这一消息。
  5. 返回设置。在偏好设置行中,选择开发者选项
  6. 依次选择调试 > USB 调试,然后选择开启
  7. 返回 TV 主屏幕。

要在 TV 设备上测试您的应用,请执行以下操作:

  1. 在 Android Studio 中,选择您的项目,然后点击工具栏中的 Run 图标
  2. Select Deployment Target 窗口中,选择您的 TV 设备,然后点击 OK

在虚拟设备上运行

Android SDK 中的 AVD 管理器提供了一些设备定义,让您能够创建用于运行和测试应用的虚拟 TV 设备。

如需创建虚拟 TV 设备,请执行以下操作:

  1. 启动 AVD 管理器。如需了解详情,请参阅创建和管理虚拟设备
  2. 在 AVD Manager 对话框中,点击 Device Definitions 标签。
  3. 选择其中一个 Android TV 设备定义,然后点击 Create AVD
  4. 选择模拟器选项,然后点击 OK 以创建 AVD。

    注意:为使 TV 模拟器设备达到最佳性能,请使用 x86 模拟器并启用 Use Host GPU 选项。此外,还应使用虚拟设备加速(如果可用)。如需详细了解模拟器的硬件加速,请参阅为 Android 模拟器配置硬件加速

如需在虚拟 TV 设备上测试您的应用,请执行以下操作:

  1. 在 Android Studio 中,选择您的项目,然后点击工具栏中的 Run 图标
  2. Select Deployment Target 窗口中,选择您的虚拟 TV 设备,然后点击 OK

如需详细了解如何使用模拟器,请参阅 在 Android 模拟器上运行应用。如需详细了解如何将应用从 Android Studio 部署到虚拟设备,请参阅调试应用

让您的 TV 应用以免安装体验的形式运行

免安装体验可让用户轻松试用您的 TV 应用,并且有助于提高采用率。

如需将您的 TV 应用设置为在 Android TV 设备或模拟器上作为免安装应用运行,请先按照相关说明创建支持免安装体验的 app bundle

接下来,在 TV 应用的 MainActivityintent-filter 中,确保 AndroidManifest.xml 中声明了 LAUNCHERLEANBACK_LAUNCHER

<activity
    android:name="com.example.android.MainActivity"
    android:label="@string/app_name" >

    <intent-filter>
      <action android:name="android.intent.action.MAIN" />
      <category android:name="android.intent.category.LAUNCHER" />
      <category android:name="android.intent.category.LEANBACK_LAUNCHER" />
    </intent-filter>
  </activity>

您的 TV 应用现已配置为运行免安装体验。

准备要发布您的 TV 应用

查看 TV 应用核对清单,了解准备 TV 应用以进行发布和分发的后续步骤。