Khi người dùng để thiết bị chạy Android ở trạng thái rảnh, thiết bị sẽ nhanh chóng chuyển sang trạng thái tạm ngưng để tránh tiêu hao pin. Tuy nhiên, có những lúc ứng dụng cần ngăn CPU chuyển sang trạng thái tạm ngưng. Trong một số trường hợp, ứng dụng có thể cần phải giữ màn hình bật trong khi hoạt động. Trong các trường hợp khác, ứng dụng không cần bật màn hình nhưng vẫn cần CPU hoạt động.
Phương pháp bạn sử dụng phụ thuộc vào nhu cầu của ứng dụng. Tuy nhiên, quy tắc chung là bạn nên sử dụng phương pháp nhẹ nhất có thể để giảm thiểu tác động của ứng dụng đối với tài nguyên hệ thống. Tài liệu này giúp bạn chọn đúng công nghệ Android cho trường hợp của mình.
Chọn công nghệ phù hợp
Lựa chọn tốt nhất để giữ cho thiết bị của bạn luôn thức phụ thuộc vào nhu cầu của ứng dụng. Phần này giúp bạn chọn phương pháp phù hợp.
- Ứng dụng của bạn có cần giữ màn hình bật không?
- Nếu Có, hãy xem phần Bật màn hình. Có thể có một API có mục đích đặc biệt thực hiện những gì bạn cần; ví dụ: nếu đang triển khai giao diện người dùng cuộc gọi điện thoại, bạn có thể sử dụng khung viễn thông Android để giữ màn hình bật khi cần. Nếu không có API có mục đích đặc biệt cho trường hợp của bạn, bạn có thể sử dụng API
keepScreenOn
.
- Nếu Có, hãy xem phần Bật màn hình. Có thể có một API có mục đích đặc biệt thực hiện những gì bạn cần; ví dụ: nếu đang triển khai giao diện người dùng cuộc gọi điện thoại, bạn có thể sử dụng khung viễn thông Android để giữ màn hình bật khi cần. Nếu không có API có mục đích đặc biệt cho trường hợp của bạn, bạn có thể sử dụng API
- Ứng dụng của bạn có đang chạy một dịch vụ trên nền trước và bạn có cần giữ cho thiết bị ở trạng thái thức khi màn hình tắt trong khi dịch vụ đang chạy không?
- Nếu Không, bạn không cần giữ thiết bị ở chế độ bật. Nếu người dùng đang tích cực tương tác với ứng dụng, thiết bị sẽ luôn ở trạng thái thức. Nếu người dùng không tương tác với ứng dụng của bạn và bạn không chạy dịch vụ trên nền trước, thì bạn nên để thiết bị chuyển sang chế độ tạm ngưng khi cần. Nếu bạn chỉ cần đảm bảo một số công việc được thực hiện trong khi người dùng không sử dụng ứng dụng, hãy xem tài liệu về tác vụ trong nền để tìm lựa chọn tốt nhất.
- Nếu Có, trước tiên, hãy xác nhận rằng bạn thực sự cần sử dụng dịch vụ trên nền trước. Tuỳ thuộc vào trường hợp của bạn, có thể bạn có thể sử dụng một số API có mục đích đặc biệt để hoàn thành nhu cầu của mình thay vì dịch vụ trên nền trước.
Bạn có thể tìm thấy thông tin về các dịch vụ này trong tài liệu về Dịch vụ trên nền trước. Ví dụ: nếu cần theo dõi vị trí của người dùng, bạn có thể sử dụng API khoanh vùng địa lý thay vì dịch vụ trên nền trước
location
.
- Việc thiết bị tạm ngưng trong khi dịch vụ trên nền trước đang chạy và màn hình thiết bị tắt có gây bất lợi cho trải nghiệm người dùng không? (Ví dụ: nếu bạn đang sử dụng dịch vụ trên nền trước để cập nhật thông báo, thì người dùng sẽ không gặp phải trải nghiệm tệ nếu thiết bị bị tạm ngưng.)
- Nếu Không, đừng sử dụng khoá chế độ thức. Hành động sẽ tự động tiếp tục sau khi người dùng tương tác với thiết bị, giúp thiết bị thoát khỏi trạng thái tạm ngưng.
- Nếu Có, bạn có thể cần sử dụng khoá chế độ thức. Tuy nhiên, bạn vẫn nên kiểm tra xem bạn có đang sử dụng API hoặc thực hiện hành động thay mặt bạn khai báo khoá chế độ thức hay không, như đã thảo luận trong phần Các hành động giúp thiết bị luôn thức.
Các thao tác khiến thiết bị luôn bật
Nếu ứng dụng của bạn đang thực hiện bất kỳ thao tác nào sau đây, thì bạn không cần tự đặt khoá chế độ thức. Các thao tác và API sau đây đều giúp thiết bị luôn thức.
- Nếu bạn đang phát âm thanh, hệ thống âm thanh sẽ thiết lập và quản lý khoá chế độ thức cho bạn; bạn không cần phải tự làm việc này.
- Nếu bạn đang sử dụng các API hoặc thư viện lên lịch tác vụ như WorkManager,
JobScheduler
hoặcDownloadManager
, thì hệ thống hoặc thư viện sẽ thay mặt bạn mua khoá chế độ thức. - Nếu đang sử dụng Media3 ExoPlayer, bạn có thể sử dụng
ExoPlayer.setWakeMode()
để yêu cầu trình phát đặt khoá chế độ thức cho bạn. - Một số cảm biến thiết bị là cảm biến đánh thức; bạn có thể sử dụng
SensorManager
để các cảm biến đó đánh thức thiết bị khi có dữ liệu để báo cáo. Để kiểm tra xem một cảm biến có phải là cảm biến đánh thức hay không, hãy gọiSensor.isWakeUpSensor
.