기능 및 API 개요

Android 14에는 개발자를 위한 훌륭한 기능과 API가 도입되었습니다. 다음은 앱의 기능을 알아보고 관련 API를 시작하는 데 도움이 됩니다.

추가된 API, 수정된 API, 삭제된 API에 관한 자세한 목록은 API 차이점 보고서를 참고하세요. 추가된 API에 관한 자세한 내용은 Android API 참조를 참고하세요. Android 14의 경우 API 수준 34에 추가된 API를 찾아보세요. 플랫폼 변경이 앱에 영향을 줄 수 있는 분야에 관해 알아보려면 Android 14를 타겟팅하는 앱모든 앱의 Android 14 동작 변경사항을 확인해야 합니다.

다국어 지원

앱별 언어 설정

Android 14에서는 Android 13(API 수준 33)에서 도입된 앱별 언어 기능을 다음과 같은 추가 기능으로 확장합니다.

  • 앱의 localeConfig 자동으로 생성: Android 스튜디오 Giraffe Canary 7 및 AGP 8.1.0-alpha07부터 앱이 앱별 언어 설정을 자동으로 지원하도록 구성할 수 있습니다. Android Gradle 플러그인은 프로젝트 리소스를 기반으로 LocaleConfig 파일을 생성하고 최종 매니페스트 파일에 이에 대한 참조를 추가하므로 더 이상 수동으로 파일을 만들거나 업데이트할 필요가 없습니다. AGP는 앱 모듈의 res 폴더에 있는 리소스 및 모든 라이브러리 모듈 종속 항목을 사용하여 LocaleConfig 파일에 포함할 언어를 결정합니다.

  • 앱의 localeConfig 동적 업데이트: LocaleManager에서 setOverrideLocaleConfig()getOverrideLocaleConfig() 메서드를 사용하여 기기의 시스템 설정에서 앱의 지원되는 언어 목록을 동적으로 업데이트합니다. 앱에서 현지화에 서버 측 푸시를 활용하는 경우 이러한 유연성을 사용하여 지역별 지원되는 언어 목록을 맞춤설정하거나 A/B 실험을 실행하거나 업데이트된 언어 목록을 제공합니다.

  • 입력 방식 편집기(IME)의 앱 언어 공개 상태: IME는 getApplicationLocales() 메서드를 활용하여 현재 앱의 언어를 확인하고 IME 언어를 해당 언어와 일치시킬 수 있습니다.

Grammatical Inflection API

有 30 亿人在使用区分性别的语言,此类语言的语法类别(例如名词、动词、形容词和介词)会根据您交谈所涉及的人或物的性别而变化。传统上,许多区分性别的语言使用阳性语法性别作为默认或通用性别。

以错误的语法性别来称呼用户,例如以阳性语法性别来称呼女性,可能会对她们的表现和态度产生负面影响。相比之下,界面语言如果能正确反映用户的语法性别,就可以提高用户互动度,并提供更个性化、更自然的用户体验。

为帮助您针对区分性别的语言构建以用户为中心的界面,Android 14 引入了 Grammatical Inflection API,让您无需重构应用便能添加对语法性别的支持。

지역 설정

지역 설정을 통해 사용자는 온도 단위, 한 주의 첫째 날, 번호 매기기 시스템을 맞춤설정할 수 있습니다. 미국에 거주하는 유럽인은 온도 단위로 화씨보다 섭씨를 선호하고, 앱이 미국의 기본값인 일요일이 아닌 월요일을 한 주의 시작으로 간주하는 것을 선호할 수 있습니다.

이러한 환경설정에 관한 새로운 Android 설정 메뉴는 사용자에게 앱 환경설정을 변경할 수 있는 쉽게 검색 가능한 중앙 집중식 위치를 제공합니다. 이러한 환경설정은 백업 및 복원에도 유지됩니다. 여러 API 및 인텐트(예: getTemperatureUnitgetFirstDayOfWeek)는 앱에 사용자 환경설정에 대한 읽기 액세스 권한을 부여하므로 앱에서 정보를 표시하는 방식을 조정할 수 있습니다. ACTION_LOCALE_CHANGEDBroadcastReceiver를 등록하여 지역 설정이 변경될 때 언어 구성 변경을 처리할 수도 있습니다.

이러한 설정을 찾으려면 설정 앱을 열고 시스템 > 언어 및 입력 > 지역 설정으로 이동하세요.

Android 시스템 설정의 지역 설정 화면
Android 시스템 설정의 지역 설정 온도 옵션

접근성

비선형 글꼴 크기 200%로 조정

从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍功能选项。

为防止屏幕上的大文本元素放大放大, 应用非线性缩放曲线。这种放大策略意味着大号文本的放大比例不会与较小的文本相同。非线性字体放大有助于保持不同大小元素之间的比例层次结构,同时缓解高级别线性文本放大存在的问题(例如文本被截断或文本因非常大的显示大小而难以阅读)。

使用非线性字体放大测试应用

在设备的无障碍设置中启用最大字号,以测试应用。

如果您已使用放大像素 (sp) 单位来定义文字大小,那么这些 其他选项和扩缩方面的改进会自动应用到 。不过,您仍应使用 启用字体大小 (200%),以确保应用采用 且可以适应较大字号,并且不会影响易用性。

要启用 200% 字号,请按以下步骤操作:

  1. 打开“设置”应用,然后依次前往无障碍 > 显示大小和文字
  2. 字号选项中,点按加号 (+) 图标,直到启用最大字号设置,如本部分随附的图片所示。

针对文本大小使用放大像素 (sp) 单位

请务必始终以 sp 为单位指定文字大小。当应用使用 sp 单位时,Android 可以应用用户的首选文本大小,并相应地进行缩放。

请勿为内边距使用 sp 单位,也不要假定内边距来定义视图高度:使用非线性字体放大 sp 尺寸可能并不成比例,因此 4sp + 20sp 可能并不等于 24sp。

转换放大像素 (sp) 单位

使用 TypedValue.applyDimension() 从 sp 单位转换为像素,并使用 TypedValue.deriveDimension() 将像素转换为 sp。这些方法会自动应用适当的非线性放大曲线。

避免对公式进行硬编码,使用以下代码 Configuration.fontScaleDisplayMetrics.scaledDensity。因为字体缩放 非线性的,则 scaledDensity 字段不再准确。fontScale 字段应仅用于提供信息, 使用单个标量值进行扩缩。

为 lineHeight 使用 sp 单位

始终使用 sp 单位定义 android:lineHeight dp 为 dp,因此行高会随文本一起缩放。否则,如果文本使用 sp,但 lineHeight 使用 dp 或 px,则文本不会缩放,并且看起来很拥挤。TextView 会自动更正 lineHeight,以便实现您的目标 比例会得到保留,但前提是 textSizelineHeight 以 sp 为单位进行定义。

카메라 및 미디어

이미지용 울트라 HDR

标准动态范围 (SDR) 与高动态范围 (HDR) 图片质量对比示意图。

Android 14 新增了对高动态范围 (HDR) 图片的支持,可在拍摄照片时保留更多来自传感器的信息,从而实现鲜艳的色彩和更高的对比度。Android 使用 Ultra HDR 格式,该格式与 JPEG 图片完全向后兼容,可让应用与 HDR 图片无缝互操作,并根据需要以标准动态范围 (SDR) 显示这些图片。

当您的应用选择为其 activity 窗口使用 HDR 界面(通过清单条目或通过在运行时调用 Window.setColorMode())时,框架会自动在界面中以 HDR 格式渲染这些图片。您还可以在受支持的设备上拍摄压缩的 Ultra HDR 静态图片。从传感器中恢复的颜色越多,后期编辑的灵活性就越高。与 Ultra HDR 图片关联的 Gainmap 可用于使用 OpenGL 或 Vulkan 渲染这些图片。

카메라 확장 프로그램의 확대/축소, 초점, Postview 등

Android 14 升级并改进了相机扩展程序,让应用能够处理更长的处理时间,从而支持在受支持的设备上使用计算密集型算法(例如弱光摄影)来改善图片。这些功能可让用户在使用相机扩展功能时获得更出色的体验。这些改进的示例包括:

인센서 줌

CameraCharacteristics 中的 REQUEST_AVAILABLE_CAPABILITIES_STREAM_USE_CASE 包含 SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW 时,您的应用可以使用高级传感器功能,将剪裁后的 RAW 数据流的像素与全视野范围相同,方法是将 CaptureRequest 与将数据流用例设置为 CameraMetadata.SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW 的 RAW 目标搭配使用。通过实现请求替换控件,更新后的相机可让用户在其他相机控件准备就绪之前使用缩放控件。

무손실 USB 오디오

Android 14 支持无损音频格式,可通过 USB 有线耳机提供发烧友级体验。您可以查询 USB 设备的首选混音器属性,注册监听器以监听首选混音器属性的更改,以及使用 AudioMixerAttributes 类配置混音器属性。此类表示音频混音器的格式,例如声道掩码、采样率和行为。该类允许直接发送音频,而无需混音、调节音量或处理效果。

개발자 생산성 및 도구

인증 관리자

Android 14 将 Credential Manager 添加为平台 API,并通过使用 Google Play 服务的 Jetpack 库,向后额外支持 Android 4.4(API 级别 19)设备。Credential Manager 旨在通过 API 使用用户配置的凭据提供程序检索和存储凭据,让用户更轻松地登录。Credential Manager 在单个 API 中支持多种登录方法,包括用户名和密码、通行密钥和联合登录解决方案(如“使用 Google 账号登录”)。

通行密钥具有许多优势。例如,通行密钥是基于业界标准构建的,可在各种不同的操作系统和浏览器生态系统中使用,并且可用于网站和应用。

如需了解详情,请参阅 Credential Manager 和通行密钥文档以及介绍 Credential Manager 和通行密钥的博文

헬스 커넥트

헬스 커넥트는 사용자 건강/피트니스 데이터를 위한 기기 내 저장소입니다. 이를 통해 사용자는 자주 사용하는 앱 간에 데이터를 공유할 수 있으며, 한곳에서 이러한 앱과 공유할 데이터를 제어할 수 있습니다.

Android 14 이전 버전의 Android를 실행하는 기기에서는 Google Play 스토어에서 헬스 커넥트를 앱으로 다운로드할 수 있습니다. Android 14부터 헬스 커넥트는 플랫폼의 일부가 되며 별도의 다운로드 없이 Google Play 시스템 업데이트를 통해 업데이트를 수신합니다. 이를 통해 헬스 커넥트를 자주 업데이트할 수 있으며 앱은 Android 14 이상을 실행하는 기기에서 헬스 커넥트를 사용할 수 있다는 점을 활용할 수 있습니다. 사용자는 시스템 설정에 통합된 개인 정보 보호 설정을 통해 기기의 설정에서 헬스 커넥트에 액세스할 수 있습니다.

사용자는 Android 14 이상을 실행하는 기기에서 별도의 앱을 다운로드하지 않고도 헬스 커넥트를 사용할 수 있습니다.
사용자는 시스템 설정을 통해 건강 및 피트니스 데이터에 액세스할 수 있는 앱을 제어할 수 있습니다.

헬스 커넥트에는 운동 경로와 같은 Android 14의 몇 가지 새로운 기능이 포함되어 있어 사용자가 지도에 시각화할 수 있는 운동 경로를 공유할 수 있습니다. 경로는 일정 기간 내에 저장된 위치 목록으로 정의되며 앱은 운동 세션에 경로를 삽입하여 서로 연결할 수 있습니다. 사용자가 이 민감한 정보를 완전히 제어할 수 있도록 하려면 사용자가 개별 경로를 다른 앱과 공유하도록 허용해야 합니다.

자세한 내용은 헬스 커넥트 문서Android 헬스의 새로운 기능 블로그 게시물을 참고하세요.

OpenJDK 17 업데이트

Android 14 将继续更新 Android 的核心库,以与最新 OpenJDK LTS 版本中的功能保持一致,包括适合应用和平台开发者的库更新和 Java 17 语言支持。

其中包含以下功能和改进:

  • 将大约 300 个 java.base 类更新为支持 Java 17。
  • 文本块 - 为 Java 编程语言引入了多行字符串字面量。
  • instanceof 模式匹配:可让对象在 instanceof 中被视为具有特定类型,而无需任何额外的变量。
  • 密封类:允许您限制哪些类和接口可以扩展或实现它们。

得益于 Google Play 系统更新 (Project Mainline),6 亿多台设备能够接收包含这些更改的最新 Android 运行时 (ART) 更新。我们致力于为应用提供更加一致、安全的跨设备环境,并为用户提供独立于平台版本的新功能。

Java 和 OpenJDK 是 Oracle 及/或其关联公司的商标或注册商标。

앱 스토어 개선사항

Android 14 引入了多个 PackageInstaller API,可帮助应用商店改善其用户体验。

下载之前请求批准安装

安装或更新应用可能需要用户批准。例如,当使用 REQUEST_INSTALL_PACKAGES 权限的安装程序尝试安装新应用时。在之前的 Android 版本中,只有在将 APK 写入安装会话并且提交会话后,应用商店才能请求用户批准。

从 Android 14 开始,requestUserPreapproval() 方法可让安装程序在提交安装会话之前请求用户批准。此项改进可让应用商店将任何 APK 的下载操作推迟到用户批准安装之后。此外,用户批准安装后,应用商店可以在后台下载并安装应用,而不会干扰用户。

承担未来更新的责任

借助 setRequestUpdateOwnership() 方法,安装程序可以向系统表明它打算负责将被安装的应用未来的更新。此 capability 可实现更新所有权强制执行,即仅允许更新所有者为应用安装自动更新。更新所有权强制执行有助于确保用户仅收到来自预期应用商店的更新。

任何其他安装程序(包括使用 INSTALL_PACKAGES 权限的安装程序)都必须获得用户的明确批准,才能安装更新。如果用户决定继续从其他来源安装更新,则会失去更新所有权。

在干扰较少的时段更新应用

应用商店通常希望避免更新正在使用的应用,因为这会导致应用正在运行的进程被终止,而这可能会中断用户正在执行的操作。

从 Android 14 开始,InstallConstraints API 让安装程序可以确保其应用更新在适当的时机进行。例如,应用商店可以调用 commitSessionAfterInstallConstraintsAreMet() 方法来确保仅在用户不再与相应应用互动时才进行更新。

无缝安装可选拆分

借助拆分 APK,应用的功能可以通过单独的 APK 文件提供,而不是以单体式 APK 的形式提供。借助拆分 APK,应用商店可以优化不同应用组件的提供。例如,应用商店可能会根据目标设备的属性进行优化。自在 API 级别 22 中引入以来,PackageInstaller API 一直支持拆分。

在 Android 14 中,setDontKillApp() 方法可让安装程序指明在安装新的拆分项时应用的运行进程不应终止。应用商店可以使用此功能,在用户使用应用时无缝安装应用的新功能。

앱 메타데이터 번들

从 Android 14 开始,Android 软件包安装程序可让您指定应用元数据(例如数据安全做法),以在 Google Play 等应用商店页面上架。

사용자가 기기 스크린샷을 찍을 때 감지

To create a more standardized experience for detecting screenshots, Android 14 introduces a privacy-preserving screenshot detection API. This API lets apps register callbacks on a per-activity basis. These callbacks are invoked, and the user is notified, when the user takes a screenshot while that activity is visible.

사용자 환경

Sharesheet 맞춤 작업 및 개선된 순위 지정

Android 14 更新了系统 Sharesheet,以便为用户提供自定义应用操作和信息更丰富的预览结果。

添加自定义操作

对于 Android 14,您的应用可以向其调用的系统 Sharesheet 添加自定义操作

分享表格中自定义操作的屏幕截图。

提高直接共享目标的排名

Android 14 根据来自应用的更多信号来确定直接共享目标的排名,以便为用户提供更实用的结果。为了提供最实用的排名信号,请遵循提高直接共享目标排名的准则。通讯应用还可以报告出站和入站消息的快捷方式使用情况

共享表单中的“直接分享”行,如 1
所示

뒤로 탐색 예측을 위한 내장 및 맞춤 애니메이션 지원

视频:预测性返回动画

Android 13 在开发者选项背后引入了预测性“返回主屏幕”动画。在已启用开发者选项的受支持应用中使用时,滑回手势会显示动画,表明返回手势会使应用退回到主屏幕。

Android 14 包含针对“预测性返回”的多项改进和新指南:

在此 Android 14 预览版中,所有预测性返回功能都是位于开发者选项背后。请参阅与将您的应用迁移到预测性返回有关的开发者指南,以及与创建自定义应用内转换有关的开发者指南

대형 화면 기기 제조업체 앱별 재정의

Per-app overrides enable device manufacturers to change the behavior of apps on large screen devices. For example, the FORCE_RESIZE_APP override instructs the system to resize the app to fit display dimensions (avoiding size compatibility mode) even if resizeableActivity="false" is set in the app manifest.

Overrides are intended to improve the user experience on large screens.

New manifest properties enable you to disable some device manufacturer overrides for your app.

대형 화면 사용자 앱별 재정의

앱별 재정의는 대형 화면 기기에서 앱의 동작을 변경합니다. 예를 들어 OVERRIDE_MIN_ASPECT_RATIO_LARGE 기기 제조업체 재정의는 앱 구성과 관계없이 앱 가로세로 비율을 16:9로 설정합니다.

Android 14 QPR1을 사용하면 사용자가 대형 화면 기기에서 새 설정 메뉴를 통해 앱별 재정의를 적용할 수 있습니다.

앱 화면 공유

借助应用界面共享功能,用户可以在录制屏幕内容时共享应用窗口,而不是整个设备屏幕。

在应用屏幕共享模式下,状态栏、导航栏、通知和其他系统界面元素会从共享显示屏中排除。系统只会分享所选应用的内容。

应用屏幕共享功能可让用户运行多个应用,但将内容共享限制为单个应用,从而提高工作效率并保护隐私。

Pixel 8 Pro의 Gboard에서 LLM 기반 스마트 답장

12월 기능 업데이트가 적용된 Pixel 8 Pro 기기에서 개발자는 Google Tensor에서 실행되는 온디바이스 대규모 언어 모델 (LLM)을 기반으로 하는 Gboard의 고품질 스마트 답장을 사용해 볼 수 있습니다.

이 기능은 WhatsApp, Line, KakaoTalk에서 미국 영어로 제한된 미리보기로 제공됩니다. Gboard를 키보드로 사용하는 Pixel 8 Pro 기기를 사용해야 합니다.

이 기능을 사용해 보려면 먼저 설정 > 개발자 옵션 > AiCore 설정 > Aicore Persistent 사용 설정에서 기능을 사용 설정하세요.

그런 다음 지원되는 앱에서 대화를 열어 수신 메시지에 대한 응답으로 Gboard의 추천 표시줄에 LLM 기반 스마트 답장이 표시되는지 확인합니다.

Gboard는 기기 내 LLM을 활용하여 더 높은 품질의 스마트 답장을 제공합니다.

그래픽

이제 쿼리하고 보간할 수 있는 경로

Android 的 Path API 是一种强大且灵活的机制,可用于创建和渲染矢量图形,能够描边或填充路径、根据线段或二次曲线或立方曲线构建路径、执行布尔运算以获取更复杂的形状,或同时执行所有这些操作。但有一个限制是,您无法了解 Path 对象中实际包含的内容;该对象的内部信息在创建后对调用方是不透明的。

如需创建 Path,您可以调用 moveTo()lineTo()cubicTo() 等方法来添加路径段。但是,无法询问该路径有哪些片段,因此您必须在创建时保留该信息。

从 Android 14 开始,您可以查询路径以了解其内部内容。首先,您需要使用 Path.getPathIterator API 获取 PathIterator 对象:

Kotlin

val path = Path().apply {
    moveTo(1.0f, 1.0f)
    lineTo(2.0f, 2.0f)
    close()
}
val pathIterator = path.pathIterator

Java

Path path = new Path();
path.moveTo(1.0F, 1.0F);
path.lineTo(2.0F, 2.0F);
path.close();
PathIterator pathIterator = path.getPathIterator();

接下来,您可以调用 PathIterator 逐个遍历片段,并检索每个片段的所有必要数据。以下示例使用了 PathIterator.Segment 对象,它会为您打包数据:

Kotlin

for (segment in pathIterator) {
    println("segment: ${segment.verb}, ${segment.points}")
}

Java

while (pathIterator.hasNext()) {
    PathIterator.Segment segment = pathIterator.next();
    Log.i(LOG_TAG, "segment: " + segment.getVerb() + ", " + segment.getPoints());
}

PathIterator 还有一个非分配版 next(),您可以在其中传入缓冲区来保存点数据。

查询 Path 数据的一个重要用例是插值。例如,您可能想在两个不同的路径之间添加动画(或变形)。为了进一步简化该用例,Android 14 针对 Path 还包含 interpolate() 方法。假设两个路径具有相同的内部结构,interpolate() 方法会使用该插值结果创建一个新的 Path。以下示例返回了一个形状介于 pathotherPath 之间的一半(线性插值为 0.5)的路径:

Kotlin

val interpolatedResult = Path()
if (path.isInterpolatable(otherPath)) {
    path.interpolate(otherPath, .5f, interpolatedResult)
}

Java

Path interpolatedResult = new Path();
if (path.isInterpolatable(otherPath)) {
    path.interpolate(otherPath, 0.5F, interpolatedResult);
}

Jetpack graphics-path 库也为早期版本的 Android 启用了类似的 API。

버텍스 및 프래그먼트 셰이더가 있는 맞춤 메시

Android has long supported drawing triangle meshes with custom shading, but the input mesh format has been limited to a few predefined attribute combinations. Android 14 adds support for custom meshes, which can be defined as triangles or triangle strips, and can, optionally, be indexed. These meshes are specified with custom attributes, vertex strides, varying, and vertex and fragment shaders written in AGSL.

The vertex shader defines the varyings, such as position and color, while the fragment shader can optionally define the color for the pixel, typically by using the varyings created by the vertex shader. If color is provided by the fragment shader, it is then blended with the current Paint color using the blend mode selected when drawing the mesh. Uniforms can be passed into the fragment and vertex shaders for additional flexibility.

캔버스의 하드웨어 버퍼 렌더러

Android의 Canvas API를 사용하여 하드웨어 가속으로 HardwareBuffer에 그리는 것을 지원하기 위해 Android 14에서는 HardwareBufferRenderer를 도입합니다. 이 API는 시스템과의 통신이 포함된 사용 사례에 특히 유용합니다 짧은 지연 시간을 위해 SurfaceControl를 통한 컴포지터 있습니다.