注意: 随着 Android 9.0(API 级别 28)的发布,出现了一个名为 AndroidX 的新版本支持库,它是 Jetpack 的一部分。AndroidX 库包含现有的支持库,并且还包括最新的 Jetpack 组件。
您可以继续使用支持库。历史工件(版本为 27 及更早版本,打包为 android.support.*
)将保留在 Google Maven 上。但是,所有新的库开发将在 AndroidX 库中进行。
我们建议在所有新项目中使用 AndroidX 库。您还应考虑将现有项目迁移到 AndroidX。
在您的开发项目中设置 Android 支持库的方式取决于您要使用的功能以及您的应用要支持的 Android 平台版本范围。
本文档将指导您下载支持库软件包并将库添加到您的开发环境。
支持库现已通过 Google 的 Maven 仓库提供。我们不再支持通过 SDK Manager 下载这些库,并且该功能将很快被移除。
选择支持库
在将支持库添加到您的应用之前,请确定您要包含哪些功能以及要支持的最低 Android 版本。有关不同库提供的功能的更多信息,请参阅支持库功能。
添加支持库
为了使用支持库,您必须在开发环境中修改应用的项目的类路径依赖项。对于要使用的每个支持库,都必须执行此过程。
将支持库添加到您的应用项目
- 在您项目的
settings.gradle
文件中包含 Google 的 Maven 仓库。dependencyResolutionManagement { repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) repositories { google() // If you're using a version of Gradle lower than 4.1, you must // instead use: // // maven { // url 'https://maven.google.com' // } } }
- 对于要使用支持库的每个模块,请在该模块的
build.gradle
文件的dependencies
块中添加该库。例如,要添加 v4 core-utils 库,请添加以下内容dependencies { ... implementation "com.android.support:support-core-utils:28.0.0" }
注意: 使用动态依赖项(例如,palette-v7:23.0.+
)可能会导致意外的版本更新和回归不兼容。我们建议您明确指定库版本(例如,palette-v7:28.0.0
)。
使用支持库 API
为现有框架 API 提供支持的支持库类通常与框架类同名,但位于 android.support
类包中,或带有 *Compat
后缀。
注意: 使用支持库中的类时,请务必从适当的包中导入类。例如,应用 ActionBar
类时
- 使用支持库时为
android.support.v7.app.ActionBar
。 - 仅针对 API 级别 11 或更高版本开发时为
android.app.ActionBar
。
注意: 将支持库包含在您的应用项目中后,我们强烈建议您针对发布版本缩减、混淆和优化您的应用。除了通过混淆保护您的源代码外,缩减功能会移除您应用中包含的任何库中未使用的类,从而尽可能减小应用的下载大小。
有关使用某些支持库功能的更多指南可在 Android 开发者培训课程、指南和示例中找到。有关各个支持库类和方法的更多信息,请参阅 API 参考中的 android.support
包。
清单声明更改
如果您使用支持库增加现有应用对早期 Android API 版本的向后兼容性,请务必更新应用的清单。具体来说,您应将清单中 <uses-sdk>
标签的 android:minSdkVersion
元素更新为新的较低版本号,如下所示
<uses-sdk android:minSdkVersion="14" android:targetSdkVersion="23" />
清单设置告知 Google Play 您的应用可以安装在 Android 4.0(API 级别 14)及更高版本的设备上。
如果您使用 Gradle 构建文件,构建文件中的 minSdkVersion
设置将覆盖清单设置。
plugins { id 'com.android.application' } android { ... defaultConfig { minSdkVersion 16 ... } ... }
在这种情况下,构建文件设置告知 Google Play 您的应用的默认构建变体可以安装在 Android 4.1(API 级别 16)及更高版本的设备上。有关构建变体的更多信息,请参阅构建系统概览。
注意: 如果您包含多个支持库,则最低 SDK 版本必须是任何指定库要求的最高版本。例如,如果您的应用同时包含v14 Preference 支持库和v17 Leanback 库,则您的最低 SDK 版本必须为 17 或更高版本。