Các tính năng và API của Android 10

Android 10 ra mắt các tính năng và chức năng tuyệt vời cho người dùng và nhà phát triển. Tài liệu này nêu bật những tính năng có sẵn cho nhà phát triển.

Để tìm hiểu về các API, hãy đọc báo cáo điểm khác biệt về API hoặc truy cập vào tài liệu tham khảo API Android — tìm các API "được thêm vào API cấp 29". Ngoài ra, hãy nhớ tham khảo các thay đổi về hành vi của Android 10 (đối với ứng dụng nhắm đến API cấp 29tất cả ứng dụng), cũng như các thay đổi về quyền riêng tư để tìm hiểu những thay đổi của nền tảng có thể ảnh hưởng đến ứng dụng của bạn.

Các tính năng bảo mật nâng cao

Android 10 giới thiệu một số tính năng bảo mật, được tóm tắt trong các phần sau.

Cải thiện hộp thoại xác thực bằng sinh trắc học

Android 10 giới thiệu các điểm cải tiến sau đây đối với tính năng hỗ trợ xác thực bằng sinh trắc học:

  • Kiểm tra khả năng xác thực bằng sinh trắc học.
  • Cơ chế dự phòng cho phép người dùng xác thực bằng mã PIN, hình mở khoá hoặc mật khẩu của thiết bị nếu họ không thể xác thực bằng phương thức nhập sinh trắc học.
  • Gợi ý cho hệ thống không yêu cầu người dùng xác nhận sau khi người dùng xác thực bằng phương thức sinh trắc học ngầm ẩn. Ví dụ: bạn có thể yêu cầu hệ thống không cần xác nhận thêm sau khi người dùng xác thực bằng phương thức xác thực khuôn mặt.

Chạy mã DEX được nhúng trực tiếp tại APK

Kể từ Android 10, bạn có thể yêu cầu nền tảng này chạy mã DEX được nhúng trực tiếp tại tệp APK của ứng dụng. Lựa chọn này có thể giúp ngăn chặn một cuộc tấn công nếu kẻ tấn công tìm được cách để can thiệp vào mã đã biên dịch cục bộ trên thiết bị.

Để biết thêm thông tin, hãy xem phần Chạy mã DEX được nhúng ngay từ APK.

Hỗ trợ TLS 1.3

Android 10 hỗ trợ thêm TLS 1.3. TLS 1.3 là bản sửa đổi lớn đối với tiêu chuẩn TLS, bao gồm các lợi ích về hiệu suất và tính bảo mật nâng cao. Các điểm chuẩn của chúng tôi cho thấy rằng TLS 1.3 có thể thiết lập kết nối bảo mật nhanh hơn TLS 1.2 tới 40%.

Để biết thêm thông tin chi tiết về cách triển khai TLS 1.3, hãy xem phần TLS trong trang thay đổi về hành vi đối với tất cả ứng dụng.

API Conscrypt công khai

Kể từ Android 10, trình cung cấp bảo mật Conscrypt bao gồm một API công khai cho chức năng TLS.

Tập hợp các lớp trong android.net.ssl chứa các phương thức tĩnh để truy cập vào chức năng không có trong các API javax.net.ssl chung. Bạn có thể suy ra tên của các lớp này là số nhiều của lớp javax.net.ssl tương ứng. Ví dụ: mã hoạt động trên các thực thể của javax.net.ssl.SSLSocket có thể sử dụng các phương thức từ SSLSockets.

Tính năng kết nối

Android 10 có một số điểm cải tiến liên quan đến kết nối mạng và kết nối.

API kết nối mạng Wi-Fi

Android 10 hỗ trợ thêm các kết nối ngang hàng. Tính năng này cho phép ứng dụng của bạn nhắc người dùng thay đổi điểm truy cập mà thiết bị đang kết nối bằng cách sử dụng WifiNetworkSpecifier để mô tả các thuộc tính của mạng được yêu cầu. Kết nối ngang hàng được dùng cho các mục đích không phải cung cấp mạng, chẳng hạn như cấu hình khởi động cho các thiết bị phụ như Chromecast và phần cứng Google Home.

Để biết thêm thông tin, hãy xem phần Wi-Fi Network Request API để kết nối ngang hàng.

API đề xuất mạng Wi-Fi

Android 10 hỗ trợ thêm cho ứng dụng của bạn để nhắc người dùng kết nối với điểm truy cập Wi-Fi. Bạn có thể cung cấp đề xuất về mạng cần kết nối. Cuối cùng, nền tảng sẽ chọn điểm truy cập nào để chấp nhận dựa trên thông tin đầu vào từ ứng dụng của bạn và các ứng dụng khác.

Để biết thêm thông tin về tính năng này, hãy xem phần Đề xuất Wi-Fi.

Cải thiện chế độ hiệu suất cao và độ trễ thấp của Wi-Fi

Android 10 cho phép bạn cung cấp gợi ý cho modem cơ bản để giảm thiểu độ trễ.

Android 10 mở rộng API khoá Wi-Fi để hỗ trợ hiệu quả chế độ hiệu suất cao và chế độ độ trễ thấp. Chế độ tiết kiệm pin Wi-Fi bị tắt đối với chế độ hiệu suất cao và độ trễ thấp, đồng thời bạn có thể bật tính năng tối ưu hoá độ trễ hơn nữa ở chế độ độ trễ thấp, tuỳ thuộc vào khả năng hỗ trợ của modem.

Chế độ độ trễ thấp chỉ được bật khi ứng dụng đang nhận khoá chạy ở nền trước và màn hình đang bật. Chế độ độ trễ thấp đặc biệt hữu ích cho các ứng dụng trò chơi dành cho thiết bị di động theo thời gian thực.

Tra cứu chuyên biệt trong trình phân giải DNS

Android 10 bổ sung tính năng hỗ trợ gốc cho hoạt động tra cứu DNS chuyên dụng bằng cách sử dụng cả tra cứu văn bản thô và chế độ DNS qua TLS. Trước đây, trình phân giải DNS của nền tảng chỉ hỗ trợ các bản ghi A và AAAA, cho phép chỉ tra cứu địa chỉ IP liên kết với một tên, nhưng không hỗ trợ loại bản ghi nào khác. API DnsResolver cung cấp hoạt động phân giải chung không đồng bộ để bạn có thể tra cứu SRV, NAPTR và các loại bản ghi khác. Lưu ý rằng việc phân tích cú pháp phản hồi sẽ do ứng dụng thực hiện.

Đối với các ứng dụng dựa trên NDK, hãy xem android_res_nsend.

Kết nối Wi-Fi dễ dàng

Android 10 cho phép bạn sử dụng tính năng Kết nối dễ dàng để cấp thông tin xác thực Wi-Fi cho một thiết bị ngang hàng, thay cho WPS đã ngừng hoạt động. Các ứng dụng có thể tích hợp tính năng Dễ dàng kết nối vào quy trình thiết lập và cấp phép bằng cách sử dụng ý định ACTION_PROCESS_WIFI_EASY_CONNECT_URI.

Để biết thêm thông tin về tính năng này, hãy xem phần Wi-Fi Easy Connect.

API kết nối Wi-Fi Direct

Các lớp API WifiP2pConfigWifiP2pManager có bản cập nhật trong Android 10 để hỗ trợ các tính năng thiết lập kết nối nhanh với Wi-Fi Direct bằng thông tin được xác định trước. Thông tin này được chia sẻ qua một kênh phụ, chẳng hạn như Bluetooth hoặc NFC.

Mã mẫu sau đây cho biết cách tạo một nhóm bằng thông tin được xác định trước:

Kotlin

val manager = getSystemService(Context.WIFI_P2P_SERVICE) as WifiP2pManager
val channel = manager.initialize(this, mainLooper, null)

// prefer 5G band for this group
val config = WifiP2pConfig.Builder()
    .setNetworkName("networkName")
    .setPassphrase("passphrase")
    .enablePersistentMode(false)
    .setGroupOperatingBand(WifiP2pConfig.GROUP_OWNER_BAND_5GHZ)
    .build()

// create a non-persistent group on 5GHz
manager.createGroup(channel, config, null)

Java

WifiP2pManager manager = (WifiP2pManager) getSystemService(Context.WIFI_P2P_SERVICE);
Channel channel = manager.initialize(this, getMainLooper(), null);

// prefer 5G band for this group
WifiP2pConfig config = new WifiP2pConfig.Builder()
.setNetworkName("networkName")
.setPassphrase("passphrase")
.enablePersistentMode(false)
.setGroupOperatingBand(WifiP2pConfig.GROUP_OWNER_BAND_5GHZ)
.build();

// create a non-persistent group on 5GHz
manager.createGroup(channel, config, null);

Để tham gia một nhóm bằng thông tin xác thực, hãy thay thế manager.createGroup() bằng nội dung sau:

Kotlin

manager.connect(channel, config, null)

Java

manager.connect(channel, config, null);

Kênh hướng đến kết nối Bluetooth LE (CoC)

Android 10 cho phép ứng dụng của bạn sử dụng kết nối CoC BLE để chuyển các luồng dữ liệu lớn hơn giữa hai thiết bị BLE. Giao diện này tóm tắt Bluetooth và cơ chế kết nối để đơn giản hoá việc triển khai.

Tính năng điện thoại

Android 10 có một số điểm cải tiến liên quan đến điện thoại.

Cải thiện chất lượng cuộc gọi

Android 10 bổ sung khả năng thu thập thông tin về chất lượng của các cuộc gọi đang diễn ra trong Hệ thống con đa phương tiện qua giao thức Internet (IMS), bao gồm cả chất lượng đến và đi từ mạng, trên các thiết bị hỗ trợ tính năng này.

Tính năng sàng lọc cuộc gọi và nhận dạng người gọi

Android 10 cung cấp cho ứng dụng của bạn một phương thức để xác định các cuộc gọi không có trong sổ địa chỉ của người dùng là cuộc gọi có khả năng là cuộc gọi rác và thay mặt người dùng từ chối thầm các cuộc gọi rác. Thông tin về các cuộc gọi bị chặn này được ghi lại dưới dạng cuộc gọi bị chặn trong nhật ký cuộc gọi để cung cấp thông tin minh bạch hơn cho người dùng khi họ bị thiếu cuộc gọi. Việc sử dụng API này giúp loại bỏ yêu cầu người dùng cấp quyền READ_CALL_LOG để cung cấp chức năng sàng lọc cuộc gọi và nhận dạng người gọi.

API dịch vụ chuyển hướng cuộc gọi

Android 10 thay đổi cách xử lý ý định gọi. Ngừng sử dụng thông báo truyền tin NEW_OUTGOING_CALL và thay thế bằng API CallRedirectionService. API CallRedirectionService cung cấp giao diện để bạn sửa đổi các cuộc gọi đi do nền tảng Android thực hiện. Ví dụ: ứng dụng bên thứ ba có thể huỷ cuộc gọi và định tuyến lại cuộc gọi qua VoIP.

Cải tiến tính năng tạo tệp trên bộ nhớ ngoài

Ngoài việc ra mắt bộ nhớ có giới hạn, Android 10 còn bổ sung các tính năng sau liên quan đến bộ nhớ ngoài:

  • Bạn có thể sử dụng cờ IS_PENDING để cấp cho ứng dụng quyền truy cập độc quyền vào tệp phương tiện khi tệp đó được ghi vào ổ đĩa.
  • Nếu biết một vị trí cụ thể nên lưu trữ các tệp, bạn có thể cung cấp cho hệ thống gợi ý về vị trí lưu trữ các tệp mới ghi.
  • Mỗi thiết bị lưu trữ bên ngoài đều có một tên ổ đĩa duy nhất.

Nội dung nghe nhìn và đồ hoạ

Android 10 ra mắt các tính năng và API đa phương tiện và đồ hoạ mới sau đây:

Chia sẻ đầu vào âm thanh

Android 10 bổ sung khả năng cho phép hai ứng dụng đồng thời chia sẻ đầu vào âm thanh. Để biết toàn bộ thông tin, hãy xem phần Chia sẻ dữ liệu đầu vào âm thanh.

Ghi lại quá trình phát âm thanh

Android 10 cho phép một ứng dụng ghi lại âm thanh phát từ các ứng dụng khác. Để biết toàn bộ thông tin, hãy xem phần Ghi lại quá trình phát.

Thanh tua lại trong thông báo MediaStyle

Kể từ Android 10, thông báo MediaStyle sẽ hiển thị một thanh tua. Thanh tua cho biết tiến trình phát từ PlaybackState.getPosition() và trong một số trường hợp, bạn có thể dùng thanh tua để tua đến một vị trí trong chương trình đang phát. Giao diện và hành vi của thanh tua lại được kiểm soát bằng các quy tắc sau:

  • Thanh tua sẽ xuất hiện nếu có MediaSession đang hoạt động và thời lượng của thanh tua (do MediaMetadata.METADATA_KEY_DURATION chỉ định) lớn hơn 0. Điều này có nghĩa là thanh này không xuất hiện đối với các luồng không xác định như sự kiện phát trực tiếp và chương trình phát thanh.
  • Nếu phiên triển khai ACTION_SEEK_TO, người dùng có thể kéo thanh tua để điều khiển vị trí phát.

API MIDI gốc

API MIDI gốc của Android (AMidi) cho phép các nhà phát triển ứng dụng gửi và nhận dữ liệu MIDI bằng mã C/C++, tích hợp chặt chẽ hơn với logic kiểm soát/âm thanh C/C++ và giảm thiểu nhu cầu sử dụng JNI.

Để biết thêm thông tin, hãy xem bài viết Android Native MIDI API.

Cải tiến MediaCodecInfo

Android 10 thêm các phương thức vào MediaCodecInfo để tiết lộ thêm thông tin về bộ mã hoá và giải mã.

Để biết thêm thông tin, hãy xem phần Bộ mã hoá và giải mã nội dung nghe nhìn.

Thermal API

Khi trở nên quá nóng, thiết bị có thể điều tiết CPU và/hoặc GPU, gây ảnh hưởng không mong muốn đến ứng dụng và trò chơi. Các ứng dụng sử dụng đồ hoạ phức tạp, tác vụ tính toán nặng hoặc hoạt động mạng được duy trì liên tục có nhiều khả năng gặp phải vấn đề hơn. Những vấn đề này có thể khác nhau giữa các thiết bị dựa trên tần số của bộ xử lý và lõi, mức độ tích hợp, cũng như gói thiết bị và hệ số hình dạng.

Trong Android 10, ứng dụng và trò chơi có thể sử dụng API nhiệt để theo dõi các thay đổi trên thiết bị và hành động để duy trì mức sử dụng điện năng thấp hơn nhằm khôi phục nhiệt độ bình thường. Ứng dụng đăng ký trình nghe trong PowerManager, thông qua đó hệ thống báo cáo trạng thái nhiệt đang diễn ra, từ nhẹ và trung bình đến nghiêm trọng, quan trọng, khẩn cấp và tắt.

Khi thiết bị báo cáo ứng suất nhiệt, các ứng dụng và trò chơi có thể giúp ích bằng cách giảm các hoạt động đang diễn ra để giảm mức sử dụng năng lượng theo nhiều cách. Ví dụ: ứng dụng phát trực tuyến có thể giảm độ phân giải/tốc độ bit hoặc lưu lượng truy cập mạng, ứng dụng máy ảnh có thể tắt đèn flash hoặc tính năng tăng cường hình ảnh chuyên sâu, trò chơi có thể giảm tốc độ khung hình hoặc lưới đa giác, ứng dụng đa phương tiện có thể giảm âm lượng loa và ứng dụng bản đồ có thể tắt GPS.

API nhiệt yêu cầu một lớp HAL thiết bị mới. Lớp này hiện được hỗ trợ trên các thiết bị Pixel chạy Android 10 và chúng tôi đang làm việc với các đối tác nhà sản xuất thiết bị để hỗ trợ rộng rãi cho hệ sinh thái nhanh nhất có thể.

Máy ảnh và hình ảnh

Android 10 ra mắt các tính năng mới liên quan đến máy ảnh và hình ảnh sau đây:

Hỗ trợ máy ảnh đơn sắc

Android 9 (API cấp 28) là phiên bản đầu tiên giới thiệu tính năng máy ảnh đơn sắc. Android 10 bổ sung một số tính năng nâng cao để hỗ trợ máy ảnh đơn sắc:

  • Hỗ trợ định dạng luồng Y8 để cải thiện hiệu quả sử dụng bộ nhớ.
  • Hỗ trợ chụp ảnh DNG thô đơn sắc.
  • Giới thiệu các phép liệt kê MONO và NIR CFA để phân biệt giữa máy ảnh đơn sắc thông thường và máy ảnh cận hồng ngoại.

Bạn có thể sử dụng tính năng này để chụp ảnh đơn sắc gốc. Thiết bị nhiều camera logic có thể sử dụng máy ảnh đơn sắc làm máy ảnh phụ thực để đạt được chất lượng hình ảnh tốt hơn trong điều kiện thiếu sáng.

Định dạng độ sâu động

Kể từ Android 10, máy ảnh có thể lưu trữ dữ liệu độ sâu cho một hình ảnh trong một tệp riêng biệt, bằng cách sử dụng giản đồ mới có tên là Định dạng độ sâu động (DDF). Ứng dụng có thể yêu cầu cả hình ảnh JPG và siêu dữ liệu độ sâu của hình ảnh đó, sử dụng thông tin đó để áp dụng bất kỳ độ mờ nào mà ứng dụng muốn trong quá trình xử lý hậu kỳ mà không sửa đổi dữ liệu hình ảnh ban đầu.

Để đọc thông số kỹ thuật của định dạng này, hãy xem phần Định dạng độ sâu động.

Định dạng tệp hình ảnh hiệu quả cao

Định dạng tệp hình ảnh hiệu quả cao (HEIF) là một định dạng hình ảnh và video tiêu chuẩn, mang đến khả năng mã hoá chất lượng cao hơn và kích thước tệp nhỏ hơn so với các định dạng tệp khác.

Để biết thêm thông tin về định dạng tệp, hãy xem phần HEIC.

Cải tiến về nhiều máy ảnh

Android 10 cải thiện khả năng kết hợp nhiều máy ảnh thành một máy ảnh logic duy nhất, một tính năng được giới thiệu trong Android 9 (API cấp 28). Các tính năng sau đã được thêm vào API Camera2:

  • isSessionConfigurationSupported(SessionConfiguration sessionConfig) – cho phép bạn truy vấn xem có thể sử dụng cấu hình phiên đã truyền để tạo phiên chụp ảnh bằng máy ảnh hay không.

  • LOGICAL_MULTI_CAMERA_ACTIVE_PHYSICAL_ID – cho phép bạn xác định mã nhận dạng của máy ảnh thực đang hoạt động hỗ trợ thiết bị máy ảnh logic. Bạn có thể sử dụng mã nhận dạng được trả về để yêu cầu luồng logic và luồng máy ảnh phụ thực để đạt được hiệu suất pin tốt hơn.

API dịch vụ hỗ trợ tiếp cận

Android 10 ra mắt các tính năng và API mới sau đây của dịch vụ hỗ trợ tiếp cận:

Cờ khoá mục nhập AccessibilityNodeInfo

Kể từ Android 10, bạn có thể gọi isTextEntryKey() để xác định xem một AccessibilityNodeInfo nhất định có đại diện cho một phím nhập văn bản thuộc bàn phím hay bàn phím số hay không.

Phản hồi bằng giọng nói trong hộp thoại Hỗ trợ tiếp cận

Trong trường hợp người dùng cần thực hiện lối tắt hỗ trợ tiếp cận để bắt đầu một dịch vụ hỗ trợ tiếp cận, Android 10 cho phép hộp thoại đi kèm với lời nhắc chuyển văn bản sang lời nói nếu dịch vụ yêu cầu.

Lối tắt hỗ trợ tiếp cận khi bật tính năng điều hướng bằng cử chỉ

Khi tính năng cử chỉ điều hướng được bật trong Android 10, nút hỗ trợ tiếp cận sẽ không hiển thị hoặc không thể chọn. Để truy cập vào trình đơn dịch vụ hỗ trợ tiếp cận, người dùng phải thực hiện một trong các cử chỉ sau:

  • Vuốt lên bằng 2 ngón tay.
  • Vuốt lên và giữ bằng 2 ngón tay.

Lối tắt hỗ trợ tiếp cận cho bàn phím thực

Trong Android 10, người dùng có thể kích hoạt phím tắt hỗ trợ tiếp cận trên bàn phím thực bằng cách nhấn tổ hợp phím Ctrl+Alt+Z.

Cải tiến tay điều khiển bàn phím mềm

Trong Android 10, các dịch vụ hỗ trợ tiếp cận có thể yêu cầu hiển thị bàn phím mềm ngay cả khi thiết bị phát hiện thấy bàn phím cứng được gắn vào. Người dùng có thể ghi đè hành vi này.

Thời gian chờ hỗ trợ tiếp cận do người dùng xác định

Android 10 giới thiệu API getRecommendedTimeoutMillis(). Phương thức này hỗ trợ thời gian chờ do người dùng xác định cho các thành phần giao diện người dùng tương tác và không tương tác. Giá trị trả về chịu ảnh hưởng của cả các lựa chọn ưu tiên của người dùng và API dịch vụ hỗ trợ tiếp cận.

Cải tiến tính năng Tự động điền

Android 10 có các điểm cải tiến sau đây đối với dịch vụ tự động điền.

Yêu cầu tự động điền liên quan đến khả năng tương thích

Bạn có thể sử dụng cờ FillRequest.FLAG_COMPATIBILITY_MODE_REQUEST để xác định xem hệ thống đã tạo yêu cầu tự động điền hay chưa thông qua chế độ tương thích.

Lưu tên người dùng và mật khẩu cùng lúc

Bạn có thể hỗ trợ các trường hợp ứng dụng sử dụng nhiều hoạt động để hiển thị tên người dùng, mật khẩu và các trường khác bằng cách sử dụng cờ SaveInfo.FLAG_DELAY_SAVE.

Người dùng tương tác với giao diện người dùng Lưu

Bạn có thể hiển thị và ẩn trường mật khẩu trong hộp thoại lưu bằng cách đặt trình nghe thao tác trên hộp thoại và thay đổi chế độ hiển thị của chế độ xem từ xa tương ứng của mật khẩu.

Hỗ trợ cập nhật tập dữ liệu

Tính năng tự động điền có thể cập nhật mật khẩu hiện có. Ví dụ: nếu người dùng đã lưu một mật khẩu và họ lưu một mật khẩu mới, thì tính năng Tự động điền sẽ nhắc người dùng cập nhật mật khẩu hiện có thay vì lưu mật khẩu mới.

Cải tiến tính năng Phân loại trường

Android 10 có các điểm cải tiến sau đây đối với API Phân loại trường.

Hàm khởi tạo UserData.Builder

Hàm khởi tạo UserData.Builder đã thay đổi để phù hợp hơn với mẫu Builder.

Cho phép liên kết một Giá trị với nhiều loại Mã danh mục

Khi sử dụng UserData.Builder trong Android 10, giờ đây, bạn có thể liên kết một giá trị với nhiều loại mã nhận dạng danh mục. Trong các bản phát hành trước, một ngoại lệ sẽ được gửi nếu một giá trị được thêm nhiều lần.

Cải thiện khả năng hỗ trợ số thẻ tín dụng

Tính năng phân loại trường hiện có thể phát hiện các số có bốn chữ số là bốn chữ số cuối của số thẻ tín dụng.

Hỗ trợ phân loại trường dành riêng cho ứng dụng

Android 10 bổ sung FillResponse.setUserData(), cho phép bạn đặt dữ liệu người dùng dành riêng cho ứng dụng trong suốt phiên hoạt động. Điều này giúp dịch vụ tự động điền phát hiện các loại cho các trường có nội dung dành riêng cho ứng dụng.

Giao diện người dùng và các chế độ điều khiển hệ thống

Android 10 cung cấp các điểm cải tiến sau đây về giao diện người dùng:

Hỗ trợ giới hạn PopFrame JVMTI

Android 10 bổ sung tính năng hỗ trợ cho chức năng can_pop_frames trong quá trình triển khai JVMTI Android. Khi gỡ lỗi, tính năng này cho phép bạn chạy lại các hàm sau khi tạm dừng tại một điểm ngắt và điều chỉnh các hàm cục bộ, toàn cục hoặc cách triển khai một hàm. Để biết thêm thông tin, hãy xem trang tham khảo về Khung bật lên của Oracle.

API điều khiển giao diện

Android 10 cung cấp API SurfaceControl để truy cập cấp thấp vào trình tổng hợp hệ thống (SurfaceFlinger). Đối với hầu hết người dùng, SurfaceView là cách chính xác để tận dụng trình tổng hợp. API SurfaceControl có thể hữu ích trong một số trường hợp, ví dụ:

  • Đồng bộ hoá nhiều nền tảng
  • Nhúng giao diện trên nhiều quy trình
  • Quản lý thời gian hoạt động ở cấp thấp hơn

API SurfaceControl có trong cả liên kết SDK và NDK. Quá trình triển khai NDK bao gồm một API để trao đổi vùng đệm theo cách thủ công với trình kết hợp. Đây là một giải pháp thay thế cho những người dùng đã gặp phải các giới hạn của BufferQueue.

Phát hiện trình kết xuất bị treo WebView

Android 10 giới thiệu lớp trừu tượng WebViewRenderProcessClient mà các ứng dụng có thể sử dụng để phát hiện xem WebView có phản hồi hay không. Cách sử dụng lớp này:

  1. Xác định lớp con của riêng bạn và triển khai các phương thức onRenderProcessResponsive()onRenderProcessUnresponsive().
  2. Đính kèm một thực thể của WebViewRenderProcessClient vào một hoặc nhiều đối tượng WebView.
  3. Nếu WebView không phản hồi, hệ thống sẽ gọi phương thức onRenderProcessUnresponsive() của ứng dụng, truyền WebViewWebViewRenderProcess. (Nếu WebView là quy trình đơn, tham số WebViewRenderProcess sẽ rỗng.) Ứng dụng của bạn có thể thực hiện hành động thích hợp, chẳng hạn như hiển thị hộp thoại cho người dùng hỏi xem họ có muốn tạm dừng quá trình kết xuất hay không.

Nếu WebView vẫn không phản hồi, hệ thống sẽ gọi onRenderProcessUnresponsive() định kỳ (không quá một lần mỗi 5 giây) nhưng không thực hiện hành động nào khác. Nếu WebView trở lại trạng thái thích ứng, hệ thống sẽ chỉ gọi onRenderProcessResponsive() một lần.

Bảng cài đặt

Android 10 ra mắt Settings Panels (Bảng cài đặt), một API cho phép ứng dụng hiển thị chế độ cài đặt cho người dùng trong ngữ cảnh của ứng dụng. Điều này giúp người dùng không cần phải chuyển đến phần Cài đặt để thay đổi các chế độ như NFC hoặc Dữ liệu di động để sử dụng ứng dụng.

Hình 1. Người dùng cố gắng mở một trang web trong khi thiết bị không kết nối với mạng. Chrome sẽ bật bảng cài đặt Internet Connectivity (Kết nối Internet)...

Hình 2. Người dùng có thể bật Wi-Fi và chọn một mạng mà không cần rời khỏi ứng dụng Chrome.

Ví dụ: giả sử người dùng mở trình duyệt web trong khi thiết bị của họ đang ở chế độ trên máy bay. Trước Android 10, ứng dụng chỉ có thể hiển thị một thông báo chung yêu cầu người dùng mở phần Cài đặt để khôi phục kết nối. Với Android 10, ứng dụng trình duyệt có thể hiển thị một bảng điều khiển nội tuyến cho thấy các chế độ cài đặt kết nối chính như chế độ trên máy bay, Wi-Fi (bao gồm cả mạng lân cận) và dữ liệu di động. Với bảng điều khiển này, người dùng có thể khôi phục kết nối mà không cần thoát khỏi ứng dụng.

Để hiển thị bảng cài đặt, hãy kích hoạt một ý định bằng một trong các thao tác Settings.Panel sau:

Kotlin

val panelIntent = Intent(Settings.Panel.settings_panel_type)
startActivityForResult(panelIntent)

Java

Intent panelIntent = new Intent(Settings.Panel.settings_panel_type);
startActivityForResult(panelIntent);

settings_panel_type có thể là một trong những giá trị sau:

ACTION_INTERNET_CONNECTIVITY
Hiển thị các chế độ cài đặt liên quan đến kết nối Internet, chẳng hạn như Chế độ trên máy bay, Wi-Fi và Dữ liệu di động.
ACTION_WIFI
Hiển thị chế độ cài đặt Wi-Fi nhưng không hiển thị các chế độ cài đặt kết nối khác. Điều này rất hữu ích cho các ứng dụng cần kết nối Wi-Fi để tải lên hoặc tải xuống các tệp có kích thước lớn.
ACTION_NFC
Hiển thị tất cả chế độ cài đặt liên quan đến giao tiếp phạm vi gần (NFC).
ACTION_VOLUME
Hiển thị chế độ cài đặt âm lượng cho tất cả luồng âm thanh.

Cải tiến tính năng chia sẻ

Android 10 cung cấp một số điểm cải tiến về tính năng chia sẻ:

API Lối tắt chia sẻ

Sharing Shortcuts API (API lối tắt chia sẻ) thay thế Direct Share API (API chia sẻ trực tiếp).

Thay vì truy xuất kết quả theo yêu cầu, API Lối tắt chia sẻ cho phép ứng dụng xuất bản trước các mục tiêu chia sẻ trực tiếp. Đây là cách hoạt động của ShortcutManager. Vì hai API này tương tự nhau, nên chúng tôi đã mở rộng ShortcutInfo API để giúp việc sử dụng cả hai tính năng trở nên dễ dàng hơn. Với API Lối tắt chia sẻ, bạn có thể trực tiếp chỉ định các danh mục hoặc người dùng cho một mục tiêu chia sẻ. Các mục tiêu chia sẻ sẽ tồn tại trong hệ thống cho đến khi ứng dụng đó cập nhật các mục tiêu đó hoặc ứng dụng bị gỡ cài đặt.

Cơ chế Chia sẻ trực tiếp cũ vẫn hoạt động, nhưng các ứng dụng sử dụng cơ chế này có mức độ ưu tiên thấp hơn so với các ứng dụng sử dụng API Lối tắt chia sẻ.

ShortcutInfo.Builder thêm và cải thiện các phương thức để cung cấp thêm thông tin về mục tiêu chia sẻ.

Mục tiêu chia sẻ trực tiếp

Bạn có thể xuất bản lối tắt động dưới dạng Mục tiêu chia sẻ trực tiếp. Xem bài viết Xuất bản mục tiêu chia sẻ trực tiếp.

ShortcutManagerCompat là một API AndroidX mới cung cấp khả năng tương thích ngược với API DirectShare cũ. Đây là cách ưu tiên để phát hành mục tiêu chia sẻ.

Xem trước văn bản

Khi chia sẻ nội dung văn bản, ứng dụng có thể hiển thị bản xem trước không bắt buộc của nội dung đó trong giao diện người dùng của Trang chia sẻ.

Xem phần Thêm bản xem trước văn bản đa dạng thức

Tìm hiểu thêm

Để biết thêm thông tin về cách ứng dụng có thể chia sẻ dữ liệu, hãy xem bài viết Gửi dữ liệu đơn giản đến các ứng dụng khácNhận dữ liệu đơn giản từ các ứng dụng khác

Giao diện tối

Android 10 cung cấp Giao diện tối áp dụng cho cả giao diện người dùng của hệ thống Android và các ứng dụng chạy trên thiết bị. Để biết toàn bộ thông tin, hãy xem phần Giao diện tối.

Loại dịch vụ trên nền trước

Android 10 giới thiệu thuộc tính tệp kê khai XML foregroundServiceType. Bạn sẽ đưa thuộc tính này vào định nghĩa của một số dịch vụ cụ thể. Bạn có thể chỉ định nhiều loại dịch vụ trên nền trước cho một dịch vụ cụ thể, mặc dù điều này hiếm khi phù hợp.

Bảng sau đây cho thấy các loại dịch vụ trên nền trước và những dịch vụ thích hợp để khai báo một loại cụ thể:

Loại dịch vụ trên nền trước Ví dụ về trường hợp sử dụng dịch vụ cần khai báo loại này
connectedDevice Theo dõi vòng đeo tay theo dõi sức khoẻ
dataSync Tải tệp xuống từ mạng
location Tiếp tục một hành động do người dùng bắt đầu
mediaPlayback Phát sách nói, podcast hoặc nhạc
mediaProjection Quay video màn hình thiết bị trong một khoảng thời gian ngắn
phoneCall Xử lý cuộc gọi điện thoại đang diễn ra

Kotlin

Android 10 có các bản cập nhật sau đây để phát triển Kotlin.

Chú giải về tính chất rỗng cho các API libcore

Android 10 cải thiện phạm vi của chú thích tính chất rỗng trong SDK cho các API libcore. Các chú thích này cho phép nhà phát triển ứng dụng đang sử dụng tính năng phân tích tính chất rỗng của Kotlin hoặc Java trong Android Studio để nhận thông tin về tính chất rỗng khi tương tác với các API này.

Thông thường, việc vi phạm hợp đồng về tính chất rỗng trong Kotlin sẽ dẫn đến lỗi biên dịch. Để đảm bảo khả năng tương thích với mã hiện có, bạn chỉ cần thêm chú thích @RecentlyNullable@RecentlyNonNull. Điều này có nghĩa là các lỗi vi phạm tính chất rỗng sẽ dẫn đến cảnh báo thay vì lỗi.

Ngoài ra, mọi chú thích @RecentlyNullable hoặc @RecentlyNonNull đã được thêm vào Android 9 sẽ lần lượt thay đổi thành @Nullable@NonNull. Điều này có nghĩa là trong Android 10 trở lên, các lỗi vi phạm tính chất rỗng sẽ dẫn đến lỗi thay vì cảnh báo.

Để biết thêm thông tin về các thay đổi đối với chú thích, hãy xem bài viết SDK Android Pie hiện thân thiện hơn với Kotlin trên Blog dành cho nhà phát triển Android.

NDK

Android 10 có các thay đổi sau đây đối với NDK.

Cải thiện tính năng gỡ lỗi quyền sở hữu chỉ số mô tả tệp

Android 10 thêm fdsan, giúp bạn dễ dàng tìm và khắc phục các vấn đề về quyền sở hữu chỉ số mô tả tệp.

Các lỗi liên quan đến việc xử lý sai quyền sở hữu chỉ số mô tả tệp (thường biểu thị dưới dạng lỗi sử dụng sau khi đóngđóng hai lần) tương tự như lỗi phân bổ bộ nhớ sử dụng sau khi giải phónggiải phóng hai lần, nhưng thường khó chẩn đoán và khắc phục hơn nhiều. fdsan cố gắng phát hiện và/hoặc ngăn chặn việc xử lý sai chỉ số mô tả tệp bằng cách thực thi quyền sở hữu chỉ số mô tả tệp.

Để biết thêm thông tin về các sự cố liên quan đến những vấn đề này, hãy xem phần Lỗi do fdsan phát hiện. Để biết thêm thông tin về fdsan, hãy xem trang Googlesource về fdsan.

ELF TLS

Các ứng dụng được tạo bằng NDK có cấp độ API tối thiểu là 29 có thể sử dụng ELF TLS thay vì emutls. Chúng tôi đã thêm tính năng hỗ trợ trình liên kết động và tĩnh để hỗ trợ phương thức xử lý biến cục bộ của luồng này.

Đối với các ứng dụng được tạo cho API cấp 28 trở xuống, chúng tôi đã triển khai các điểm cải tiến cho libgcc/compiler-rt để giải quyết một số vấn đề về emutls.

Để biết thêm thông tin, hãy xem bài viết Những thay đổi đối với Android dành cho nhà phát triển NDK.

Thời gian chạy

Android 10 có thay đổi về thời gian chạy như sau.

Kích hoạt thu gom rác dựa trên Mallinfo

Khi các đối tượng Java trên nền tảng nhỏ tham chiếu đến các đối tượng khổng lồ trong vùng nhớ khối xếp C++, các đối tượng C++ thường chỉ có thể được thu hồi khi đối tượng Java được thu thập và hoàn tất. Trong các bản phát hành trước, nền tảng này đã ước tính kích thước của nhiều đối tượng C++ liên kết với các đối tượng Java. Mức ước tính này không phải lúc nào cũng chính xác và đôi khi dẫn đến mức sử dụng bộ nhớ tăng lên đáng kể, vì nền tảng không thu thập rác khi cần.

Trong Android 10, trình thu gom rác (GC) theo dõi tổng kích thước của vùng nhớ khối xếp do malloc() của hệ thống phân bổ, đảm bảo rằng các lượt phân bổ malloc() lớn luôn được đưa vào các phép tính kích hoạt GC. Các ứng dụng xen kẽ số lượng lớn lượt phân bổ C++ với quá trình thực thi Java có thể tăng tần suất thu gom rác. Các ứng dụng khác có thể giảm một chút.

Kiểm thử và gỡ lỗi

Android 10 có các điểm cải tiến sau đây để kiểm thử và gỡ lỗi.

Các điểm cải tiến đối với tính năng theo dõi hệ thống trên thiết bị

Kể từ Android 10, bạn có thể chỉ định giới hạn cho kích thước và thời lượng của một dấu vết khi thực hiện dấu vết hệ thống trên thiết bị. Khi bạn chỉ định một trong hai giá trị này, hệ thống sẽ thực hiện một dấu vết dài, định kỳ sao chép bộ đệm dấu vết vào tệp đích trong khi dấu vết được ghi lại. Dấu vết sẽ hoàn tất khi đạt đến giới hạn kích thước hoặc thời lượng mà bạn chỉ định.

Sử dụng các tham số bổ sung này để kiểm thử các trường hợp sử dụng khác với trường hợp bạn kiểm thử bằng dấu vết chuẩn. Ví dụ: bạn có thể đang chẩn đoán một lỗi về hiệu suất chỉ xảy ra sau khi ứng dụng chạy trong một khoảng thời gian dài. Trong trường hợp này, bạn có thể ghi lại một dấu vết dài trong cả ngày, sau đó phân tích bộ lập lịch CPU, hoạt động của ổ đĩa, luồng ứng dụng và dữ liệu khác trong báo cáo để xác định nguyên nhân gây ra lỗi.

Trong Android 10 trở lên, các tệp theo dõi được lưu ở định dạng có thể mở bằng Perfetto, một dự án nguồn mở để đo lường và theo dõi hiệu suất. Bạn có thể chuyển đổi tệp theo dõi Perfetto sang định dạng Systrace.

Các điểm cải tiến của TextClassifier

Android 10 cung cấp thêm chức năng phân loại văn bản trong giao diện TextClassifier.

Phát hiện ngôn ngữ

Phương thức detectLanguage() hoạt động tương tự như các phương thức phân loại hiện có. Phương thức này nhận một đối tượng TextLanguage.Request và trả về một đối tượng TextLanguage.

Đối tượng TextLanguage bao gồm một danh sách các cặp có thứ tự. Mỗi cặp chứa một ngôn ngữ và một điểm số tin cậy tương ứng cho hoạt động phân loại.

Hành động được đề xuất trong cuộc trò chuyện

Phương thức suggestConversationActions() hoạt động tương tự như các phương thức phân loại hiện có. Phương thức này nhận một đối tượng ConversationActions.Request và trả về một đối tượng ConversationActions.

Các đối tượng ConversationActions bao gồm một danh sách các đối tượng ConversationAction. Mỗi đối tượng ConversationAction bao gồm một hành động được đề xuất tiềm năng và điểm số về độ tin cậy của hành động đó.

Câu trả lời/hành động thông minh trong thông báo

Android 9 đã ra mắt tính năng hiển thị câu trả lời được đề xuất trong thông báo. Android 10 mở rộng tính năng này bằng khả năng đưa vào các hành động dựa trên ý định được đề xuất. Hơn nữa, nền tảng này có thể tự động tạo các đề xuất này. Ứng dụng vẫn có thể cung cấp các đề xuất của riêng mình hoặc chọn không sử dụng các đề xuất do hệ thống tạo.

API dùng để tạo các phản hồi này là một phần của TextClassifier và cũng được hiển thị trực tiếp cho nhà phát triển trong Android 10. Vui lòng đọc phần về các điểm cải tiến của TextClassifier để biết thêm thông tin.

Nếu ứng dụng của bạn cung cấp các đề xuất riêng, thì nền tảng sẽ không tạo bất kỳ đề xuất tự động nào. Nếu không muốn thông báo của ứng dụng hiển thị bất kỳ câu trả lời hoặc hành động được đề xuất nào, bạn có thể chọn không sử dụng câu trả lời và hành động do hệ thống tạo bằng cách sử dụng setAllowGeneratedReplies()setAllowSystemGeneratedContextualActions().