Tổng quan về các tính năng và API

Android 14 mang đến cho nhà phát triển các tính năng và API tuyệt vời. Nội dung sau đây giúp bạn tìm hiểu các tính năng cho ứng dụng cũng như làm quen với các API có liên quan.

Để biết danh sách chi tiết về các API đã thêm, sửa đổi và xoá, hãy đọc báo cáo điểm khác biệt về API. Để biết thông tin chi tiết về các API đã thêm, hãy truy cập Tài liệu tham khảo về API cho Android. Đối với Android 14, hãy tìm các API đã được thêm vào API cấp 34. Để tìm hiểu những khía cạnh mà những thay đổi của nền tảng có thể ảnh hưởng đến ứng dụng của bạn, hãy nhớ tham khảo các thay đổi về hành vi của Android 14 đối với ứng dụng nhắm đến Android 14tất cả ứng dụng.

Quốc tế hoá

Lựa chọn ưu tiên về ngôn ngữ cho mỗi ứng dụng

Android 14 expands on the per-app language features that were introduced in Android 13 (API level 33) with these additional capabilities:

  • Automatically generate an app's localeConfig: Starting with Android Studio Giraffe Canary 7 and AGP 8.1.0-alpha07, you can configure your app to support per-app language preferences automatically. Based on your project resources, the Android Gradle plugin generates the LocaleConfig file and adds a reference to it in the final manifest file, so you no longer have to create or update the file manually. AGP uses the resources in the res folders of your app modules and any library module dependencies to determine the locales to include in the LocaleConfig file.

  • Dynamic updates for an app's localeConfig: Use the setOverrideLocaleConfig() and getOverrideLocaleConfig() methods in LocaleManager to dynamically update your app's list of supported languages in the device's system settings. Use this flexibility to customize the list of supported languages per region, run A/B experiments, or provide an updated list of locales if your app utilizes server-side pushes for localization.

  • App language visibility for input method editors (IMEs): IMEs can utilize the getApplicationLocales() method to check the language of the current app and match the IME language to that language.

API Biến tố ngữ pháp

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

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

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

Lựa chọn ưu tiên theo khu vực

Regional preferences enable users to personalize temperature units, the first day of the week, and numbering systems. A European living in the United States might prefer temperature units to be in Celsius rather than Fahrenheit and for apps to treat Monday as the beginning of the week instead of the US default of Sunday.

New Android Settings menus for these preferences provide users with a discoverable and centralized location to change app preferences. These preferences also persist through backup and restore. Several APIs and intents—such as getTemperatureUnit and getFirstDayOfWeek— grant your app read access to user preferences, so your app can adjust how it displays information. You can also register a BroadcastReceiver on ACTION_LOCALE_CHANGED to handle locale configuration changes when regional preferences change.

To find these settings, open the Settings app and navigate to System > Languages & input > Regional preferences.

Regional preferences screen in Android system settings.
Temperature options for regional preferences in Android system settings.

Hỗ trợ tiếp cận

Điều chỉnh tỷ lệ phông chữ phi tuyến tính lên đến 200%

Kể từ Android 14, hệ thống sẽ hỗ trợ việc chuyển tỷ lệ phông chữ lên đến 200%, mang đến cho người dùng thị lực kém thêm một số chế độ hỗ trợ tiếp cận phù hợp với Nguyên tắc hỗ trợ tiếp cận nội dung trên web (WCAG).

Để ngăn các thành phần văn bản cỡ lớn trên màn hình bị chuyển tỷ lệ quá lớn, hệ thống sẽ áp dụng một đường cong tỷ lệ phi tuyến tính. Chiến lược điều chỉnh tỷ lệ này có nghĩa là văn bản lớn không chuyển tỷ lệ theo cùng mức độ với văn bản nhỏ hơn. Việc chuyển tỷ lệ phông chữ phi tuyến tính giúp duy trì hệ phân cấp tỷ lệ giữa các phần tử có kích thước khác nhau, đồng thời giảm thiểu các vấn đề với việc chuyển tỷ lệ văn bản tuyến tính ở mức cao (chẳng hạn như văn bản bị cắt hoặc văn bản trở nên khó đọc hơn do kích thước trên màn hình cực kỳ lớn).

Kiểm thử ứng dụng với phông chữ phi tuyến tính

Bật kích thước phông chữ tối đa trong phần cài đặt hỗ trợ tiếp cận của thiết bị để kiểm thử ứng dụng của bạn.

Nếu bạn đã sử dụng đơn vị pixel được điều chỉnh theo tỷ lệ (sp) để xác định cỡ chữ, thì các tuỳ chọn bổ sung và cải thiện tỷ lệ này sẽ tự động được áp dụng cho văn bản trong ứng dụng. Tuy nhiên, bạn vẫn nên kiểm thử giao diện người dùng khi bật cỡ chữ tối đa (200%) để đảm bảo ứng dụng áp dụng đúng cỡ chữ và có thể phù hợp với cỡ chữ lớn hơn mà không ảnh hưởng đến khả năng hữu dụng.

Để bật kích thước phông chữ 200%, hãy làm theo các bước sau:

  1. Mở ứng dụng Cài đặt rồi chuyển đến phần Hỗ trợ tiếp cận > Văn bản và kích thước hiển thị.
  2. Đối với tuỳ chọn Kích thước phông chữ, hãy nhấn vào biểu tượng dấu cộng (+) cho đến khi bật chế độ cài đặt kích thước phông chữ tối đa, như trong hình ảnh kèm theo phần này.

Sử dụng đơn vị pixel được điều chỉnh theo tỷ lệ (sp) đối với kích thước văn bản

Hãy nhớ luôn chỉ định kích thước văn bản theo đơn vị sp. Khi ứng dụng của bạn sử dụng đơn vị sp, Android có thể áp dụng kích thước văn bản mà người dùng ưu tiên và chuyển tỷ lệ văn bản một cách thích hợp.

Đừng sử dụng đơn vị sp cho khoảng đệm hoặc xác định chiều cao chế độ xem giả sử khoảng đệm ngầm định: với kích thước sp theo tỷ lệ phông chữ phi tuyến tính có thể không tỷ lệ, vì vậy 4 sp + 20 sp có thể không bằng 24 sp.

Chuyển đổi đơn vị pixel được điều chỉnh theo tỷ lệ (sp)

Sử dụng TypedValue.applyDimension() để chuyển đổi từ đơn vị sp sang pixel và sử dụng TypedValue.deriveDimension() để chuyển đổi pixel thành sp. Các phương thức này tự động áp dụng đường cong tỷ lệ phi tuyến tính thích hợp.

Tránh mã hoá cứng phương trình bằng cách sử dụng Configuration.fontScale hoặc DisplayMetrics.scaledDensity. Vì việc chuyển tỷ lệ phông chữ là phi tuyến tính, nên trường scaledDensity không còn chính xác nữa. Bạn chỉ nên sử dụng trường fontScale cho mục đích cung cấp thông tin vì phông chữ không còn được điều chỉnh theo tỷ lệ với một giá trị vô hướng duy nhất.

Sử dụng đơn vị sp cholineHeight

Luôn xác định android:lineHeight bằng cách sử dụng đơn vị sp thay vì dp để chiều cao dòng điều chỉnh theo tỷ lệ cùng với văn bản. Ngược lại, nếu văn bản là sp nhưng lineHeight lại ở dạng dp hoặc px, thì văn bản sẽ không được điều chỉnh theo tỷ lệ và trông bị chật. TextView sẽ tự động sửa lineHeight để giữ nguyên tỷ lệ dự định của bạn, nhưng chỉ khi cả textSizelineHeight được xác định theo đơn vị sp.

Máy ảnh và nội dung nghe nhìn

Ultra HDR cho hình ảnh

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

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

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

Thu phóng, Lấy nét, Xem sau và các tính năng khác trong các tiện ích của máy ảnh

Android 14 nâng cấp và cải thiện các tiện ích về máy ảnh, cho phép các ứng dụng xử lý thời gian xử lý lâu hơn, nhờ đó cải thiện hình ảnh bằng cách sử dụng các thuật toán tốn nhiều điện toán (như chụp ảnh trong điều kiện ánh sáng yếu) trên những thiết bị được hỗ trợ. Các tính năng này mang đến cho người dùng trải nghiệm mạnh mẽ hơn nữa khi sử dụng các tính năng của tiện ích máy ảnh. Sau đây là một số ví dụ về những điểm cải thiện:

  • Số liệu ước tính độ trễ của quá trình xử lý ảnh chụp động vẫn cung cấp số liệu ước tính chính xác hơn nhiều về độ trễ của quá trình chụp ảnh dựa trên cảnh hiện tại và điều kiện môi trường. Gọi CameraExtensionSession.getRealtimeStillCaptureLatency() để lấy đối tượng StillCaptureLatency có hai phương thức ước tính độ trễ. Phương thức getCaptureLatency() sẽ trả về độ trễ ước tính trong khoảng từ onCaptureStarted đến onCaptureProcessStarted(), và phương thức getProcessingLatency() sẽ trả về độ trễ ước tính từ onCaptureProcessStarted() đến khi khung hình được xử lý cuối cùng hiện có.
  • Hỗ trợ các lệnh gọi lại tiến trình chụp để các ứng dụng có thể hiển thị tiến trình hiện tại của các thao tác xử lý chụp ảnh tĩnh và diễn ra trong thời gian dài. Bạn có thể kiểm tra xem tính năng này có hoạt động với CameraExtensionCharacteristics.isCaptureProcessProgressAvailable hay không. Nếu có, bạn sẽ triển khai lệnh gọi lại onCaptureProcessProgressed() với tiến trình (từ 0 đến 100) được truyền vào dưới dạng tham số.
  • Siêu dữ liệu dành riêng cho tiện ích, chẳng hạn như CaptureRequest.EXTENSION_STRENGTH để quay số hiệu ứng mở rộng, chẳng hạn như mức độ mờ của nền bằng EXTENSION_BOKEH.

  • Tính năng Postview cho tính năng Chụp ảnh tĩnh trong các tiện ích máy ảnh, cung cấp hình ảnh chưa được xử lý nhanh hơn hình ảnh cuối cùng. Nếu tiện ích làm tăng độ trễ xử lý, thì bạn có thể cung cấp hình ảnh chế độ xem sau làm phần giữ chỗ để cải thiện trải nghiệm người dùng và thay thế cho hình ảnh cuối cùng sau này. Bạn có thể kiểm tra xem tính năng này có hoạt động với CameraExtensionCharacteristics.isPostviewAvailable hay không. Sau đó, bạn có thể truyền OutputConfiguration đến ExtensionSessionConfiguration.setPostviewOutputConfiguration.

  • Tính năng hỗ trợ SurfaceView cho phép đường dẫn hiển thị bản xem trước được tối ưu hoá và tiết kiệm pin hơn.

  • Hỗ trợ nhấn để lấy nét và thu phóng trong khi sử dụng tiện ích.

Thu phóng trong cảm biến

CameraCharacteristics 中的 REQUEST_AVAILABLE_CAPABILITIES_STREAM_USE_CASE 包含 SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW 时,您的应用可以使用高级传感器功能,通过使用 CaptureRequest 以及数据流用例设置为 CameraMetadata.SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW 的 RAW 目标,为剪裁后的 RAW 数据流提供与完整视野相同的像素。通过实现请求替换控件,更新后的摄像头让用户可在其他摄像头控件准备就绪之前实现缩放控制。

Âm thanh USB không tổn hao

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

Năng suất và công cụ dành cho nhà phát triển

Trình quản lý thông tin xác thực

Android 14 adds Credential Manager as a platform API, with additional support back to Android 4.4 (API level 19) devices through a Jetpack Library using Google Play services. Credential Manager aims to make sign-in easier for users with APIs that retrieve and store credentials with user-configured credential providers. Credential Manager supports multiple sign-in methods, including username and password, passkeys, and federated sign-in solutions (such as Sign-in with Google) in a single API.

Passkeys provide many advantages. For example, passkeys are built on industry standards, can work across different operating systems and browser ecosystems, and can be used with both websites and apps.

For more information, see the Credential Manager and passkeys documentation and the blogpost about Credential Manager and passkeys.

Health Connect

Health Connect là một kho lưu trữ trên thiết bị dành cho dữ liệu sức khoẻ và hoạt động thể dục của người dùng. Hộp cát về quyền riêng tư cho phép người dùng chia sẻ dữ liệu giữa các ứng dụng yêu thích, với một nơi duy nhất để kiểm soát dữ liệu mà họ muốn chia sẻ với các ứng dụng này.

Trên các thiết bị chạy phiên bản Android trước Android 14, bạn có thể tải Health Connect xuống dưới dạng ứng dụng trên Cửa hàng Google Play. Bắt đầu từ Android 14, Health Connect là một phần của nền tảng này và nhận các bản cập nhật thông qua bản cập nhật hệ thống Google Play mà không cần tải xuống riêng. Nhờ vậy, Health Connect có thể được cập nhật thường xuyên, và các ứng dụng của bạn có thể dựa vào Health Connect có sẵn trên các thiết bị chạy Android 14 trở lên. Người dùng có thể truy cập vào Health Connect trong phần Cài đặt của thiết bị, trong đó các chế độ kiểm soát quyền riêng tư được tích hợp vào phần cài đặt hệ thống.

Người dùng có thể bắt đầu sử dụng Health Connect mà không cần tải ứng dụng riêng xuống trên thiết bị chạy Android 14 trở lên.
Người dùng có thể kiểm soát ứng dụng nào có quyền truy cập vào dữ liệu sức khoẻ và thể chất của họ thông qua các chế độ cài đặt hệ thống.

Health Connect có một số tính năng mới trong Android 14, chẳng hạn như tuyến đường tập thể dục, cho phép người dùng chia sẻ tuyến đường tập thể dục của họ mà có thể trực quan hoá được trên bản đồ. Tuyến được định nghĩa là danh sách vị trí được lưu trong một khoảng thời gian và ứng dụng của bạn có thể chèn các tuyến đường vào phiên tập thể dục, liên kết chúng với nhau. Để đảm bảo rằng người dùng có toàn quyền kiểm soát đối với dữ liệu nhạy cảm này, họ phải cho phép chia sẻ từng tuyến với các ứng dụng khác.

Để biết thêm thông tin, hãy xem tài liệu về Health Connect (Kết nối sức khoẻ) và bài đăng trên blog về Tính năng mới trong Android Health.

Nội dung cập nhật 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 及/或其关联公司的商标或注册商标。

Những điểm cải tiến cho cửa hàng ứng dụng

Android 14 giới thiệu một số API PackageInstaller cho phép cửa hàng ứng dụng cải thiện trải nghiệm người dùng.

Yêu cầu phê duyệt lượt cài đặt trước khi tải xuống

Có thể việc cài đặt hoặc cập nhật ứng dụng cần phải được người dùng phê duyệt. Ví dụ: khi trình cài đặt sử dụng quyền REQUEST_INSTALL_PACKAGES sẽ tìm cách cài đặt một ứng dụng mới. Trong các phiên bản Android trước, cửa hàng ứng dụng chỉ có thể yêu cầu người dùng phê duyệt sau khi tệp APK được ghi vào phiên cài đặt và phiên đó đã được xác nhận.

Kể từ Android 14, phương thức requestUserPreapproval() sẽ cho phép trình cài đặt yêu cầu người dùng phê duyệt trước khi xác nhận phiên cài đặt. Điểm cải tiến này cho phép cửa hàng ứng dụng trì hoãn việc tải mọi tệp APK xuống cho đến khi người dùng phê duyệt quá trình cài đặt. Hơn nữa, sau khi người dùng phê duyệt việc cài đặt, cửa hàng ứng dụng có thể tải và cài đặt ứng dụng ở chế độ nền mà không làm gián đoạn người dùng.

Tuyên bố trách nhiệm đối với các bản cập nhật trong tương lai

Phương thức setRequestUpdateOwnership() cho phép trình cài đặt cho hệ thống biết rằng sau này trình cài đặt dự định sẽ chịu trách nhiệm về các bản cập nhật của ứng dụng đang cài đặt. Tính năng này cho phép thực thi quyền sở hữu bản cập nhật, nghĩa là chỉ chủ sở hữu bản cập nhật mới được phép tự động cài đặt bản cập nhật cho ứng dụng. Việc thực thi quyền sở hữu bản cập nhật giúp đảm bảo rằng người dùng chỉ nhận được bản cập nhật từ cửa hàng ứng dụng dự kiến.

Mọi trình cài đặt khác (bao gồm cả những trình cài đặt sử dụng quyền INSTALL_PACKAGES) đều phải nhận được sự phê duyệt rõ ràng của người dùng để cài đặt bản cập nhật. Nếu người dùng quyết định tiếp tục cập nhật từ một nguồn khác, thì quyền sở hữu bản cập nhật sẽ bị mất.

Cập nhật ứng dụng vào những thời điểm ít gây gián đoạn hơn

Các cửa hàng ứng dụng thường muốn tránh cập nhật một ứng dụng đang được sử dụng, vì việc này dẫn đến việc các quy trình đang chạy của ứng dụng bị dừng, có khả năng làm gián đoạn công việc mà người dùng đang thực hiện.

Kể từ Android 14, InstallConstraints API sẽ cung cấp cho trình cài đặt một cách để đảm bảo quá trình cập nhật ứng dụng diễn ra đúng lúc. Ví dụ: một cửa hàng ứng dụng có thể gọi phương thức commitSessionAfterInstallConstraintsAreMet() để đảm bảo bản cập nhật chỉ được cam kết khi người dùng không còn tương tác với ứng dụng đang được đề cập đến.

Cài đặt các phần phân tách không bắt buộc sao cho liền mạch

Nhờ tệp APK phân tách, nhiều tính năng của một ứng dụng có thể được phân phối trong các tệp APK riêng biệt, thay vì dưới dạng tệp APK nguyên khối. Tệp APK phân tách cho phép cửa hàng ứng dụng tối ưu hoá việc phân phối nhiều thành phần của ứng dụng. Ví dụ: có thể các cửa hàng ứng dụng sẽ tối ưu hoá dựa trên thuộc tính của thiết bị mục tiêu. API PackageInstaller đã hỗ trợ các phần phân tách kể từ khi ra mắt trong API cấp 22.

Trong Android 14, phương thức setDontKillApp() cho phép trình cài đặt cho biết rằng các quy trình đang chạy của ứng dụng sẽ không bị tắt khi các phần phân tách mới được cài đặt. Các cửa hàng ứng dụng có thể sử dụng tính năng này để cài đặt liền mạch các tính năng mới của một ứng dụng trong khi người dùng đang sử dụng ứng dụng đó.

Gói siêu dữ liệu ứng dụng

Kể từ Android 14, trình cài đặt gói Android cho phép bạn chỉ định siêu dữ liệu ứng dụng (ví dụ: các biện pháp đảm bảo an toàn dữ liệu) để đưa vào các trang trên cửa hàng ứng dụng như Google Play.

Phát hiện thời điểm người dùng chụp ảnh màn hình thiết bị

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.

Trải nghiệm người dùng

Các thao tác tuỳ chỉnh trên Trang chia sẻ nội dung và cách cải thiện thứ hạng

Android 14 cập nhật trang chia sẻ nội dung của hệ thống để hỗ trợ các thao tác tuỳ chỉnh trong ứng dụng và các kết quả xem trước giàu thông tin hơn cho người dùng.

Thêm thao tác tuỳ chỉnh

Với Android 14, ứng dụng của bạn có thể thêm thao tác tuỳ chỉnh vào trang chia sẻ nội dung hệ thống mà ứng dụng gọi.

Ảnh chụp màn hình các thao tác tuỳ chỉnh trên trang chia sẻ nội dung.

Cải thiện thứ hạng của mục tiêu Chia sẻ trực tiếp

Android 14 sử dụng thêm nhiều tín hiệu từ các ứng dụng để xác định thứ hạng của mục tiêu chia sẻ trực tiếp nhằm đưa ra kết quả hữu ích hơn cho người dùng. Để cung cấp tín hiệu hữu ích nhất cho việc xếp hạng, hãy làm theo hướng dẫn để cải thiện thứ hạng của mục tiêu Chia sẻ trực tiếp. Các ứng dụng liên lạc cũng có thể báo cáo mức sử dụng lối tắt cho các tin nhắn đi và tin nhắn đến.

Hàng Chia sẻ trực tiếp trong trang chia sẻ nội dung, như minh hoạ trong 1

Hỗ trợ ảnh động tích hợp sẵn và ảnh động tuỳ chỉnh cho tính năng Xem trước thao tác quay lại

Video: Ảnh động xem trước thao tác quay lại

Android 13 đã giới thiệu ảnh động xem trước thao tác quay lại màn hình chính dưới hình thức tuỳ chọn dành cho nhà phát triển. Khi vuốt ngược lại, trong một ứng dụng được hỗ trợ và tuỳ chọn dành cho nhà phát triển được bật, sẽ xuất hiện ảnh động chỉ ra rằng cử chỉ vuốt ngược là để thoát khỏi ứng dụng và quay lại màn hình chính.

Android 14 có nhiều điểm cải tiến và hướng dẫn mới về tính năng Xem trước thao tác quay lại:

Đối với bản thử nghiệm Android 14 này, tất cả tính năng Xem trước thao tác quay lại vẫn là tuỳ chọn dành cho nhà phát triển. Xem hướng dẫn dành cho nhà phát triển để di chuyển ứng dụng sang tính năng Xem trước thao tác quay lại, cũng như hướng dẫn dành cho nhà phát triển để tạo các hiệu ứng chuyển đổi tuỳ chỉnh trong ứng dụng.

Chế độ ghi đè cho mỗi ứng dụng của nhà sản xuất thiết bị có màn hình lớn

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.

Ghi đè cho mỗi ứng dụng của người dùng trên màn hình lớn

Chế độ ghi đè cho mỗi ứng dụng sẽ thay đổi hành vi của các ứng dụng trên thiết bị có màn hình lớn. Ví dụ: chế độ ghi đè của nhà sản xuất thiết bị OVERRIDE_MIN_ASPECT_RATIO_LARGE sẽ đặt tỷ lệ khung hình của ứng dụng thành 16:9 bất kể cấu hình của ứng dụng như thế nào.

Android 14 QPR1 cho phép người dùng áp dụng chế độ ghi đè cho mỗi ứng dụng bằng một trình đơn cài đặt mới trên thiết bị có màn hình lớn.

Chia sẻ màn hình ứng dụng

应用屏幕共享功能让用户能够在录制屏幕内容期间共享应用窗口,而非整个设备屏幕。

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

应用屏幕共享可让用户运行多个应用,但仅限单个应用共享内容,从而提高效率和隐私性。

Trả lời thông minh dựa trên LLM trong Gboard trên Pixel 8 Pro

On Pixel 8 Pro devices with the December Feature Drop, developers can try out higher-quality smart replies in Gboard powered by on-device Large Language Models (LLMs) running on Google Tensor.

This feature is available as a limited preview for US English in WhatsApp, Line, and KakaoTalk. It requires using a Pixel 8 Pro device with Gboard as your keyboard.

To try it out, first enable the feature in Settings > Developer Options > AiCore Settings > Enable Aicore Persistent.

Next, open a conversation in a supported app to see LLM-powered Smart Reply in Gboard's suggestion strip in response to incoming messages.

Gboard utilizes on-device LLMs to provide higher-quality smart replies.

Đồ hoạ

Các đường dẫn có thể truy vấn và nội suy được

API Path của Android là một cơ chế mạnh mẽ và linh hoạt để tạo và hiển thị đồ hoạ vectơ, có khả năng vẽ hoặc điền đường dẫn, tạo đường dẫn từ các đoạn đường hoặc đường cong bậc hai hoặc bậc ba, thực hiện thao tác boolean để tạo và hiển thị các hình dạng phức tạp hơn hoặc tất cả các hình dạng này đồng thời. Một hạn chế là khả năng tìm thấy nội dung thực sự trong đối tượng Đường dẫn (Path). Sau khi tạo, nội dung bên trong của đối tượng này được che đi trước các phương thức gọi.

Để tạo Path, hãy gọi các phương thức như moveTo(), lineTo()cubicTo() để thêm các phân đoạn đường dẫn. Nhưng không có cách nào để hỏi đường dẫn đó về các phân đoạn, vì vậy bạn phải giữ lại thông tin đó tại thời điểm tạo.

Kể từ Android 14, bạn có thể truy vấn các đường dẫn để tìm hiểu nội dung bên trong đó. Trước tiên, bạn cần sử dụng Path.getPathIterator API để lấy đối tượng 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();

Tiếp theo, bạn có thể gọi PathIterator để lặp lại từng phân đoạn, truy xuất tất cả dữ liệu cần thiết cho từng phân đoạn. Ví dụ này sử dụng các đối tượng PathIterator.Segment để đóng gói dữ liệu cho bạn:

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 cũng có phiên bản next() không phân bổ, trong đó bạn có thể truyền một bộ đệm để lưu giữ dữ liệu điểm.

Một trong những trường hợp sử dụng quan trọng của việc truy vấn dữ liệu Path là nội suy. Ví dụ: bạn có thể tạo hiệu ứng động (animate) hoặc biến đổi (morph) giữa hai đường dẫn riêng biệt. Để đơn giản hoá trường hợp sử dụng đó hơn nữa, Android 14 cũng tích hợp phương thức interpolate() trên Path. Giả sử hai đường dẫn này có cùng cấu trúc nội bộ, thì phương thức interpolate() sẽ tạo một Path mới với kết quả nội suy đó. Ví dụ này trả về một đường dẫn có hình dạng là một nửa (nội suy tuyến tính .5) giữa pathotherPath:

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);
}

Thư viện graphics-path của Jetpack cũng kích hoạt các API tương tự cho các phiên bản Android cũ.

Lưới tuỳ chỉnh có chương trình đổ bóng mảnh và đỉnh (vertex)

Từ lâu, Android đã hỗ trợ vẽ lưới tam giác có tính năng tô bóng tuỳ chỉnh, nhưng định dạng lưới đầu vào bị giới hạn ở một số tổ hợp thuộc tính được xác định trước. Android 14 hỗ trợ thêm các lưới tuỳ chỉnh (có thể được định nghĩa dưới dạng hình tam giác hoặc dải tam giác) và có thể lập chỉ mục (không bắt buộc). Các lưới này được chỉ định bằng các thuộc tính tuỳ chỉnh, sải bước đỉnh, thay đổi, cũng như chương trình đổ bóng đỉnh và mảnh được viết bằng AGSL.

Chương trình đổ bóng đỉnh xác định các biến đổi, chẳng hạn như vị trí và màu sắc, trong khi chương trình đổ bóng mảnh có thể tuỳ ý xác định màu cho điểm ảnh, thường là bằng cách sử dụng các biến thể do chương trình đổ bóng đỉnh đỉnh tạo ra. Nếu màu được chương trình đổ bóng mảnh cung cấp, thì màu này sẽ được pha trộn với màu Paint hiện tại bằng cách sử dụng chế độ kết hợp đã chọn khi vẽ lưới. Bạn có thể truyền Đồng nhất vào mảnh và chương trình đổ bóng đỉnh để tăng tính linh hoạt.

Trình kết xuất vùng đệm phần cứng cho Canvas

To assist in using Android's Canvas API to draw with hardware acceleration into a HardwareBuffer, Android 14 introduces HardwareBufferRenderer. This API is particularly useful when your use case involves communication with the system compositor through SurfaceControl for low-latency drawing.