Android 10 (API cấp 29) trở lên đặt ra các quy định hạn chế về thời điểm ứng dụng có thể bắt đầu hoạt động khi ứng dụng chạy ở chế độ nền. Các hạn chế này giúp giảm thiểu tình trạng gián đoạn cho người dùng và giúp người dùng kiểm soát tốt hơn nội dung hiện trên màn hình.
Hướng dẫn này trình bày thông báo như một giải pháp thay thế để bắt đầu các hoạt động từ chế độ nền. Trang này cũng liệt kê các trường hợp cụ thể không áp dụng quy định hạn chế này.
Thay vào đó, hãy hiển thị thông báo
Trong hầu hết trường hợp, các ứng dụng ở chế độ nền phải hiển thị thông báo có giới hạn về thời gian để cung cấp thông tin khẩn cấp cho người dùng thay vì trực tiếp bắt đầu một hoạt động. Các thông báo đó bao gồm xử lý cuộc gọi điện thoại đến hoặc một đồng hồ báo thức đang hoạt động.
Hệ thống cảnh báo và nhắc nhở dựa trên thông báo này mang lại một số lợi ích cho người dùng:
- Khi sử dụng thiết bị, người dùng sẽ thấy một thông báo quan trọng cho phép họ phản hồi. Người dùng duy trì ngữ cảnh hiện tại và có quyền kiểm soát nội dung mà họ nhìn thấy trên màn hình.
- Thông báo có giới hạn thời gian tuân thủ quy tắc Không làm phiền của người dùng. Ví dụ: người dùng có thể chỉ cho phép cuộc gọi của một số người liên hệ cụ thể hoặc của những người gọi lại khi chế độ Không làm phiền đang bật.
- Khi màn hình thiết bị tắt, ý định toàn màn hình sẽ khởi chạy ngay lập tức.
- Trên màn hình Cài đặt của thiết bị, người dùng có thể xem những ứng dụng nào đã gửi thông báo gần đây, bao gồm cả các kênh thông báo cụ thể. Trên màn hình này, người dùng có thể kiểm soát lựa chọn ưu tiên về thông báo.
Thời điểm ứng dụng có thể bắt đầu hoạt động
Các ứng dụng chạy trên Android 10 trở lên có thể bắt đầu hoạt động khi đáp ứng một hoặc nhiều điều kiện sau:
- Ứng dụng có một cửa sổ hiển thị, chẳng hạn như một hoạt động ở nền trước.
- Ứng dụng có một hoạt động trong ngăn xếp lui của tác vụ trên nền trước.
Ứng dụng có một hoạt động trong ngăn xếp lui của một tác vụ hiện có trên màn hình Gần đây.
Ứng dụng có một hoạt động bắt đầu gần đây.
Ứng dụng có tên
finish()
trên một hoạt động gần đây. Điều này chỉ áp dụng khi ứng dụng có một hoạt động ở nền trước hoặc một hoạt động trong ngăn xếp lui của tác vụ ở nền trước tại thời điểmfinish()
được gọi.Ứng dụng có một trong các dịch vụ sau đây chịu sự ràng buộc của hệ thống. Các dịch vụ này có thể cần khởi chạy giao diện người dùng.
AccessibilityService
AutofillService
CallRedirectionService
HostApduService
InCallService
TileService
(Không áp dụng trong Android 14 (API cấp 34) trở lên)VoiceInteractionService
VrListenerService
.
Ứng dụng có một dịch vụ bị ràng buộc bởi một ứng dụng hiển thị khác. Ứng dụng liên kết với dịch vụ phải luôn hiển thị với ứng dụng ở chế độ nền để bắt đầu thành công các hoạt động.
Ứng dụng nhận được thông báo
PendingIntent
từ hệ thống. Trong trường hợp ý định đang chờ xử lý cho dịch vụ và broadcast receiver, ứng dụng có thể bắt đầu các hoạt động trong vài giây sau khi ý định đang chờ xử lý được gửi.Ứng dụng nhận được
PendingIntent
được gửi từ một ứng dụng khác, hiển thị.Ứng dụng nhận được thông báo của hệ thống, trong đó ứng dụng dự kiến sẽ khởi chạy giao diện người dùng. Ví dụ:
ACTION_NEW_OUTGOING_CALL
vàSECRET_CODE_ACTION
. Ứng dụng có thể bắt đầu các hoạt động trong vài giây sau khi thông báo được gửi đi.Ứng dụng được liên kết với một thiết bị phần cứng đồng hành thông qua API
CompanionDeviceManager
. API này cho phép ứng dụng bắt đầu các hoạt động để phản hồi các thao tác mà người dùng thực hiện trên thiết bị đã ghép nối.Ứng dụng này là một trình kiểm soát chính sách thiết bị chạy ở chế độ chủ sở hữu thiết bị. Ví dụ về các trường hợp sử dụng bao gồm thiết bị doanh nghiệp được quản lý đầy đủ cũng như thiết bị chuyên dụng như biển hiệu kỹ thuật số và ki-ốt.
Người dùng cấp cho ứng dụng quyền
SYSTEM_ALERT_WINDOW
.
Bắt buộc phải chọn sử dụng khi bắt đầu các hoạt động từ PendingIntents
Để tránh cho phép vô tình bắt đầu Hoạt động dựa trên các điều kiện được liệt kê, bắt đầu từ Android 14, có các API rõ ràng cho phép bạn chọn sử dụng hoặc không sử dụng quyền cấp cho ứng dụng để bắt đầu Hoạt động.
Theo mặc định, các ứng dụng nhắm đến Android 15 trở lên sẽ không còn cấp ngầm quyền khởi chạy hoạt động ở chế độ nền (BAL) cho PendingIntents
mà chúng tạo ra. Bạn phải chọn sử dụng rõ ràng. Để làm như vậy, đây là những lựa chọn tuỳ thuộc vào việc ứng dụng đang gửi hay tạo PendingIntents
.
Do Trình gửi PendingIntent
Những ứng dụng nhắm đến Android 14 trở lên muốn bắt đầu một PendingIntent
phải
- đáp ứng các điều kiện được liệt kê và
- chọn cho phép khởi chạy hoạt động trong nền dựa trên các trường hợp ngoại lệ đó
Việc chọn sử dụng này chỉ xảy ra nếu nhà phát triển ứng dụng biết rằng ứng dụng sẽ khởi động một Hoạt động.
Để chọn sử dụng, ứng dụng phải truyền gói ActivityOptions
có setPendingIntentBackgroundActivityStartMode(ActivityOptions.MODE_BACKGROUND_ACTIVITY_START_ALLOWED)
đến PendingIntent.send()
hoặc các phương thức tương tự.
Do Trình tạo PendingIntent
Giờ đây, các ứng dụng nhắm đến Android 15 trở lên và tạo PendingIntent
phải chọn sử dụng tính năng này một cách rõ ràng để cho phép khởi chạy hoạt động ở chế độ nền nếu muốn khởi động các PendingIntents
đó theo các điều kiện được liệt kê.
Trong hầu hết các trường hợp, ứng dụng khởi động PendingIntent
sẽ là ứng dụng chọn sử dụng.
Tuy nhiên, nếu ứng dụng tạo cần cấp các đặc quyền này:
- Bạn có thể bắt đầu
PendingIntent
bất cứ lúc nào ứng dụng đang tạo xuất hiện. - Bạn có thể bắt đầu
PendingIntent
bất cứ lúc nào nếu ứng dụng tạo có các đặc quyền đặc biệt.
Để chọn sử dụng, ứng dụng phải truyền gói ActivityOptions
có setPendingIntentCreatorBackgroundActivityStartMode
(ActivityOptions.MODE_BACKGROUND_ACTIVITY_START_ALLOWED)
đến PendingIntent.getActivity()
hoặc các phương thức tương tự.
Hãy đọc tài liệu tham khảo liên quan để biết thêm thông tin chi tiết:
ActivityOptions.setPendingIntentBackgroundActivityStartMode
ActivityOptions.setPendingIntentCreatorBackgroundActivityStartMode