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 về 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 29 và tấ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 tăng cường bảo mật
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 một phương thức sinh trắc học ngầm ẩn. Ví dụ: bạn có thể thông báo cho hệ thống rằng không cần xác nhận thêm sau khi người dùng đã xác thực bằng tính năng 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 sẽ 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 mạng và khả năng 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 có được khoá đang 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 Easy Connect 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 WifiP2pConfig
và WifiP2pManager
có bản cập nhật trong Android 10 để hỗ trợ khả năng thiết lập kết nối nhanh với Wi-Fi Direct bằng thông tin 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 cách sử dụ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 các 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àm phiền, cũng như để người dùng im lặng từ chối các cuộc gọi làm phiền. 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. Thông báo truyền tin NEW_OUTGOING_CALL
không được dùng nữa và được 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.
Những cải tiến về 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ơi lưu trữ tệp, bạn có thể cung cấp cho hệ thống một 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 cung cấp cho ứng dụng khả năng ghi lại âm thanh phát từ các ứng dụng khác. Để biết đầy đủ thông tin, hãy xem phần Chụp ảnh khi 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ị 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 tìm kiếm xuất hiện nếu có
MediaSession
đang hoạt động và thời lượng của thanh tua (doMediaMetadata.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
, thì 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 phần API MIDI gốc của Android.
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.
API Nhiệt
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ể.
Camera 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). Các ứng dụng có thể yêu cầu cả hình ảnh JPG và siêu dữ liệu về chiều sâu của hình ảnh, sử dụng thông tin đó để áp dụng độ mờ mà ứng dụng muốn trong quá trình xử lý hậu kỳ mà không cần sửa đổi dữ liệu hình ảnh gốc.
Để đọc thông số kỹ thuật của định dạng này, hãy xem phần Định dạng chiều 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ể 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ợ một 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á của mục nhập AccessibilityNodeInfo
Kể từ Android 10, bạn có thể gọi hàm 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 hoặc bàn phím 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.
Phím 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ả 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
.
Tương tác của người dùng 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
Giờ đây, khi sử dụng
UserData.Builder
trong
Android 10, bạn có thể ánh xạ một giá trị với nhiều loại mã 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 dịch vụ hỗ trợ cho số thẻ tín dụng
Việc phân loại trường hiện có thể phát hiện các số gồm 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 thêm 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 hỗ trợ thêm 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 ở 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 Pop Frame của Oracle.
API điều khiển bề mặt
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ó sẵn 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 tổng 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 ra mắt 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:
- Xác định lớp con của riêng bạn và triển khai các phương thức
onRenderProcessResponsive()
vàonRenderProcessUnresponsive()
. - Đính kèm một thực thể của
WebViewRenderProcessClient
vào một hoặc nhiều đối tượngWebView
. - Nếu
WebView
không phản hồi, hệ thống sẽ gọi phương thứconRenderProcessUnresponsive()
của ứng dụng, truyềnWebView
vàWebViewRenderProcess
. (NếuWebView
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á 5 giây một lần), 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 bối cảnh ứng dụng của họ. Đ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.
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 khả năng 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 trạng thái 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 đối với 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 Chia sẻ lối tắt
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ẻ vẫn tồn tại trong hệ thống cho đến khi cùng một ứng dụng cập nhật chúng 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 Share Shortcuts API (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 bài viết 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ác và Nhậ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
| Giám sát thiết bị theo dõi hoạt động thể dục có thể đeo |
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 của 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 tính chất rỗng cho 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
và @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
và @NonNull
.
Điều này có nghĩa là trong Android 10 trở lên, 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 và đóng hai lần) tương tự như lỗi phân bổ bộ nhớ sử dụng sau khi giải phóng và giả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ề sự cố liên quan đến những vấn đề này, hãy xem bài viết Lỗi do fdsan phát hiện. Để biết thêm thông tin về fdsan, hãy xem trang Googlesource trên fdsan.
TLS ELF (Bảo mật tầng truyền tải)
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 Các thay đổi về 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 tính năng 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.
Hãy 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 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à các 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 mà bạn 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 các tệp theo dõi Perfetto thành đị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
.
Các đối tượng TextLanguage
bao gồm một danh sách các cặp được sắp. 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. Các ứng dụng vẫn có thể cung cấp đề xuất của riêng mình hoặc chọn không nhận đề 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 mục 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()
và setAllowSystemGeneratedContextualActions()
.