Kể từ Android 14 (API cấp 34), bạn phải khai báo một loại dịch vụ phù hợp cho từng dịch vụ trên nền trước. Điều đó có nghĩa là bạn phải khai báo loại dịch vụ trong tệp kê khai ứng dụng và cũng phải yêu cầu quyền sử dụng dịch vụ trên nền trước phù hợp cho loại dịch vụ đó (ngoài việc yêu cầu quyền FOREGROUND_SERVICE
). Hơn nữa, tuỳ thuộc vào loại dịch vụ trên nền trước, bạn có thể phải yêu cầu quyền khi bắt đầu chạy trước khi khởi chạy dịch vụ.
Camera
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
camera
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_CAMERA
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_CAMERA
- Điều kiện tiên quyết về thời gian chạy
Yêu cầu và được cấp quyền khi bắt đầu chạy
CAMERA
- Mô tả
Tiếp tục truy cập vào máy ảnh từ chế độ nền, chẳng hạn như các ứng dụng trò chuyện video cho phép thực hiện đa nhiệm.
Thiết bị đã kết nối
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
connectedDevice
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_CONNECTED_DEVICE
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE
- Điều kiện tiên quyết về thời gian chạy
Ít nhất một trong các điều kiện sau phải đúng:
Khai báo ít nhất một trong các quyền sau đây trong tệp kê khai:
Yêu cầu và được cấp ít nhất một trong các quyền sau đây khi bắt đầu chạy:
- Nội dung mô tả
Các hoạt động tương tác với thiết bị bên ngoài cần có kết nối Bluetooth, NFC, IR, USB hoặc kết nối mạng.
- Phương án thay thế
Nếu ứng dụng của bạn cần chuyển dữ liệu liên tục sang một thiết bị bên ngoài, hãy cân nhắc sử dụng trình quản lý thiết bị đồng hành. Sử dụng API hiện diện thiết bị đồng hành để giúp ứng dụng của bạn luôn chạy trong khi thiết bị đồng hành nằm trong phạm vi.
Nếu ứng dụng của bạn cần quét tìm thiết bị Bluetooth, hãy cân nhắc sử dụng API quét Bluetooth.
Đồng bộ hoá dữ liệu
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
dataSync
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_DATA_SYNC
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_DATA_SYNC
- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Các hoạt động chuyển dữ liệu, chẳng hạn như:
- Tải dữ liệu lên hoặc tải dữ liệu xuống
- Hoạt động sao lưu và khôi phục
- Hoạt động nhập hoặc xuất dữ liệu
- Tìm nạp dữ liệu
- Xử lý tệp cục bộ
- Chuyển dữ liệu giữa thiết bị và đám mây qua mạng
- Lựa chọn thay thế
Hãy xem phần Các giải pháp thay thế cho dịch vụ đồng bộ hoá dữ liệu trên nền trước để biết thông tin chi tiết.
Sức khoẻ
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceType
health
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_HEALTH
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_HEALTH
- Điều kiện tiên quyết về thời gian chạy
Ít nhất một trong các điều kiện sau phải đúng:
Khai báo quyền
HIGH_SAMPLING_RATE_SENSORS
trong tệp kê khai.Yêu cầu và được cấp ít nhất một trong các quyền khi bắt đầu chạy sau đây:
- Mô tả
Trường hợp sử dụng lâu dài bất kỳ để hỗ trợ các ứng dụng trong danh mục thể dục (ví dụ: trình theo dõi bài tập thể dục).
Vị trí
- Foreground service type to declare in manifest under
android:foregroundServiceType
location
- Permission to declare in your manifest
FOREGROUND_SERVICE_LOCATION
- Constant to pass to
startForeground()
FOREGROUND_SERVICE_TYPE_LOCATION
- Runtime prerequisites
The user must have enabled location services and the app must be granted at least one of the following runtime permissions:
- Description
Long-running use cases that require location access, such as navigation and location sharing.
- Alternatives
If your app needs to be triggered when the user reaches specific locations, consider using the geofence API instead.
Nội dung nghe nhìn
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
mediaPlayback
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_MEDIA_PLAYBACK
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Tiếp tục phát âm thanh hoặc video ở chế độ nền. Hỗ trợ chức năng Quay video kỹ thuật số (DVR) trên Android TV.
- Lựa chọn thay thế
Nếu bạn đang hiển thị video ở chế độ hình trong hình, hãy sử dụng chế độ Hình trong hình.
Xử lý phương tiện
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
mediaProcessing
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_MEDIA_PROCESSING
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_MEDIA_PROCESSING
- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Dịch vụ thực hiện các thao tác tốn nhiều thời gian đối với các thành phần nội dung nghe nhìn, chẳng hạn như chuyển đổi nội dung nghe nhìn sang các định dạng khác nhau. Hệ thống cho phép dịch vụ này chạy trong một khoảng thời gian giới hạn. Trong trường hợp thông thường, giới hạn thời gian này là 6 giờ trên mỗi 24 giờ. (Giới hạn này dùng chung cho tất cả
mediaProcessing
dịch vụ trên nền trước của ứng dụng.)Ứng dụng của bạn nên dừng dịch vụ xử lý nội dung nghe nhìn theo cách thủ công trong các trường hợp sau:
- Khi quá trình chuyển mã kết thúc hoặc đến trạng thái lỗi, hãy yêu cầu lệnh gọi dịch vụ
Service.stopForeground()
vàService.stopSelf()
để dừng hoàn toàn dịch vụ.
- Khi quá trình chuyển mã kết thúc hoặc đến trạng thái lỗi, hãy yêu cầu lệnh gọi dịch vụ
Nếu đạt đến khoảng thời gian chờ, hệ thống sẽ gọi phương thức
Service.onTimeout(int, int)
của dịch vụ. Tại thời điểm này, dịch vụ có vài giây để gọiService.stopSelf()
. Nếu dịch vụ không gọiService.stopSelf()
, một lỗi ANR sẽ xuất hiện với thông báo lỗi sau: "Dịch vụ trên nền trước của <fgs_type> không dừng trong thời gian chờ: <component_name>".Lưu ý:
Service.onTimeout(int, int)
không có trên Android 14 trở xuống. Trên các thiết bị chạy các phiên bản đó, nếu một dịch vụ xử lý nội dung đa phương tiện đạt đến khoảng thời gian chờ, thì hệ thống sẽ ngay lập tức lưu ứng dụng vào bộ nhớ đệm. Vì lý do này, ứng dụng của bạn không nên nhận thông báo hết thời gian chờ. Thay vào đó, ứng dụng sẽ chấm dứt dịch vụ trên nền trước hoặc thay đổi sang dịch vụ nền ngay khi thích hợp.
Chiếu nội dung nghe nhìn
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
mediaProjection
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_MEDIA_PROJECTION
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION
- Điều kiện tiên quyết về thời gian chạy
Gọi phương thức
createScreenCaptureIntent()
trước khi bắt đầu dịch vụ trên nền trước. Thao tác này sẽ hiển thị thông báo cấp quyền cho người dùng; người dùng phải cấp quyền thì bạn mới có thể tạo dịch vụ.Sau khi tạo dịch vụ trên nền trước, bạn có thể gọi
MediaProjectionManager.getMediaProjection()
.- Mô tả
Chiếu nội dung tới màn hình phụ hoặc thiết bị bên ngoài bằng các API
MediaProjection
. Nội dung này không nhất thiết chỉ là nội dung đa phương tiện.- Lựa chọn thay thế
Để truyền trực tuyến nội dung nghe nhìn sang một thiết bị khác, hãy sử dụng SDK Google Cast.
Micrô
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
microphone
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_MICROPHONE
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_MICROPHONE
- Điều kiện tiên quyết về thời gian chạy
Yêu cầu và được cấp quyền khi bắt đầu chạy
RECORD_AUDIO
.- Mô tả
Tiếp tục ghi âm qua micrô ở chế độ nền, chẳng hạn như trình ghi âm giọng nói hoặc ứng dụng giao tiếp.
Cuộc gọi điện thoại
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai theo
android:foregroundServiceType
phoneCall
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_PHONE_CALL
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_PHONE_CALL
- Điều kiện tiên quyết về thời gian chạy
Ít nhất một trong các điều kiện sau phải đúng:
- Ứng dụng đã khai báo quyền
MANAGE_OWN_CALLS
trong tệp kê khai.
- Ứng dụng đã khai báo quyền
- Ứng dụng là ứng dụng quay số mặc định thông qua vai trò
ROLE_DIALER
.
- Ứng dụng là ứng dụng quay số mặc định thông qua vai trò
- Mô tả
Tiếp tục cuộc gọi đang diễn ra bằng các API
ConnectionService
.- Lựa chọn thay thế
Nếu bạn cần thực hiện cuộc gọi điện thoại, video hoặc VoIP, hãy cân nhắc sử dụng thư viện
android.telecom
.Cân nhắc sử dụng
CallScreeningService
để sàng lọc cuộc gọi.
Nhắn tin từ xa
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
remoteMessaging
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_REMOTE_MESSAGING
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
- Chuyển tin nhắn văn bản từ thiết bị này sang thiết bị khác. Hỗ trợ người dùng nhắn tin liên tục khi họ chuyển đổi thiết bị.
Dịch vụ ngắn
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
shortService
- Quyền khai báo trong tệp kê khai
- Không có
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_SHORT_SERVICE
- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Nhanh chóng hoàn tất công việc quan trọng mà không bị gián đoạn hoặc trì hoãn.
Kiểu này có một số đặc điểm riêng biệt:
- Chỉ chạy được trong một khoảng thời gian ngắn (khoảng 3 phút).
- Không hỗ trợ các dịch vụ cố định trên nền trước.
- Không thể bắt đầu các dịch vụ trên nền trước khác.
- Không yêu cầu quyền dành riêng cho từng kiểu, tuy vẫn đòi hỏi quyền
FOREGROUND_SERVICE
. shortService
chỉ có thể thay đổi sang một loại dịch vụ khác nếu ứng dụng hiện đủ điều kiện để bắt đầu một dịch vụ mới trên nền trước.- Dịch vụ trên nền trước có thể thay đổi kiểu của dịch vụ này thành
shortService
bất cứ lúc nào. Lúc đó, khoảng thời gian chờ sẽ bắt đầu.
Thời gian chờ đối với shortService bắt đầu từ thời điểm gọi
Service.startForeground()
. Ứng dụng dự kiến sẽ gọiService.stopSelf()
hoặcService.stopForeground()
trước khi hết thời gian chờ. Nếu không,Service.onTimeout()
mới sẽ được gọi, mang đến cho ứng dụng một khoảng thời gian ngắn để gọistopSelf()
hoặcstopForeground()
nhằm dừng dịch vụ.Một thời gian ngắn sau khi
Service.onTimeout()
được gọi, ứng dụng sẽ chuyển sang một trạng thái lưu trong bộ nhớ đệm và không còn được xem là chạy ở nền trước, trừ trường hợp người dùng chủ động tương tác với ứng dụng. Một thời gian ngắn sau khi ứng dụng được lưu vào bộ nhớ đệm và dịch vụ vẫn chưa bị dừng, ứng dụng sẽ nhận được một lỗi ANR. Thông báo lỗi ANR đó nhắc đếnFOREGROUND_SERVICE_TYPE_SHORT_SERVICE
. Vì những lý do này, cách tốt nhất là triển khai lệnh gọi lạiService.onTimeout()
.Lệnh gọi lại
Service.onTimeout()
không tồn tại trên Android 13 trở xuống. Nếu cùng một dịch vụ chạy trên các thiết bị như vậy, thì dịch vụ đó sẽ không bị hết thời gian chờ cũng như không gặp lỗi ANR. Hãy đảm bảo dịch vụ của bạn dừng ngay sau khi hoàn tất tác vụ xử lý, kể cả khi chưa nhận được lệnh gọi lạiService.onTimeout()
.Điều quan trọng bạn cần lưu ý là nếu không hết thời gian chờ của
shortService
, ứng dụng sẽ gặp lỗi ANR ngay cả khi có các dịch vụ trên nền trước hợp lệ khác hoặc các quy trình khác trong vòng đời của ứng dụng.Nếu người dùng nhìn thấy ứng dụng hoặc ứng dụng đáp ứng một trong các quy tắc miễn trừ cho phép bắt đầu chạy các dịch vụ trên nền trước từ chế độ nền, hãy gọi
Service.StartForeground()
một lần nữa bằng tham sốFOREGROUND_SERVICE_TYPE_SHORT_SERVICE
(kéo dài thời gian chờ thêm 3 phút nữa). Nếu người dùng không nhìn thấy ứng dụng và ứng dụng không đáp ứng một trong các quy tắc miễn trừ, thì mọi cố gắng bắt đầu một dịch vụ trên nền trước khác, bất kể kiểu nào, cũng sẽ gây raForegroundServiceStartNotAllowedException
Nếu người dùng tắt tính năng tối ưu hoá pin cho ứng dụng, thì ứng dụng vẫn bị ảnh hưởng bởi thời gian chờ của dịch vụ shortService trên nền trước.
Nếu bạn bắt đầu một dịch vụ trên nền trước bao gồm kiểu
shortService
và một kiểu dịch vụ trên nền trước khác, hệ thống sẽ bỏ qua phần khai báo cho kiểushortService
. Tuy nhiên, dịch vụ vẫn phải tuân thủ điều kiện tiên quyết của các kiểu khác đã khai báo. Để biết thêm thông tin, hãy xem Tài liệu về Dịch vụ trên nền trước.
Cách sử dụng đặc biệt
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
specialUse
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_SPECIAL_USE
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Bao gồm mọi trường hợp sử dụng dịch vụ trên nền trước hợp lệ không thuộc các loại dịch vụ trên nền trước khác.
Ngoài việc khai báo loại dịch vụ trên nền trước
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
, nhà phát triển nên khai báo các trường hợp sử dụng trong tệp kê khai. Để làm vậy, họ cần chỉ định phần tử<property>
trong phần tử<service>
. Các giá trị này và trường hợp sử dụng tương ứng sẽ được xem xét khi bạn gửi ứng dụng trong Google Play Console. Việc sử dụng yêu cầu của bạn là theo mẫu tuỳ ý và bạn cần đảm bảo cung cấp đủ để cho nhân viên đánh giá biết lý do bạn cần sử dụngspecialUse
loại.<service android:name="fooService" android:foregroundServiceType="specialUse"> <property android:name="android.app.PROPERTY_SPECIAL_USE_FGS_SUBTYPE" android:value="explanation_for_special_use"/> </service>
Được miễn trừ hệ thống
- Loại dịch vụ trên nền trước cần khai báo trong tệp kê khai trong
android:foregroundServiceType
systemExempted
- Quyền khai báo trong tệp kê khai
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
- Hằng số để truyền đến
startForeground()
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
- Điều kiện tiên quyết về thời gian chạy
- Không có
- Nội dung mô tả
Dành riêng cho các ứng dụng hệ thống, cũng như chế độ tích hợp hệ thống cụ thể để tiếp tục sử dụng các dịch vụ trên nền trước.
Để sử dụng loại này, ứng dụng phải đáp ứng ít nhất một trong các tiêu chí sau:
- Thiết bị đang ở trạng thái chế độ minh hoạ
- Ứng dụng là Chủ sở hữu thiết bị
- Ứng dụng là Chủ sở hữu trình phân tích tài nguyên
- Ứng dụng An toàn có vai trò
ROLE_EMERGENCY
- Ứng dụng Quản trị thiết bị
- Ứng dụng có quyền
SCHEDULE_EXACT_ALARM
hoặcUSE_EXACT_ALARM
Ứng dụng VPN (được định cấu hình bằng cách sử dụng Cài đặt > Mạng và Internet > VPN)
Nếu không, việc khai báo loại này sẽ khiến hệ thống gửi ra một
ForegroundServiceTypeNotAllowedException
.
Phương thức thực thi chính sách của Google Play đối với việc sử dụng các loại dịch vụ trên nền trước
Nếu ứng dụng nhắm đến Android 14 trở lên, bạn cần khai báo các loại dịch vụ trên nền trước của ứng dụng trên trang nội dung ứng dụng của Play Console (Chính sách > Nội dung ứng dụng). Để biết thêm thông tin về cách khai báo các loại dịch vụ trên nền trước trong Play Console, hãy xem bài viết Tìm hiểu các yêu cầu về ý định truy cập chế độ toàn màn hình và dịch vụ trên nền trước.