1. 背景
请教大家:应用后台使用时长有没有什么建议或方案? UsageStats 运行时长定义为前台的时间,后台时间例如按home、back切入后台或被杀,UsageStats是不统计在内的,故得不到后台运行时长
目前使用UsageStatsManager如下:
-
UsageStatsManager.queryEventStats:一般是用来根据最近时间戳找到top进程
-
UsageStatsManager.queryAndAggregateUsageStats:获取聚合后的应用前台使用时长
-
UsageStatsManager.queryEvents:自己计算每个进程的运行时长和启动次数(包含Activity和Service ForeGround 事件)来获取前台使用时长
备注其他思路:
-
Settings:后台时长倒是有一些参考,初步看无法设置时间段内查询,只能得到总后台运行时长 BatteryStats.Uid.getProcessStateTime(Battery.UID.PROCESS_STATE_BACKGROUND)
-
是否可以利用后台占用CPU时长,作为应用后台使用时长呢?
mCurrentFocus=Window{cba4105 u0 com.huawei.systemmanager/com.huawei.systemmanager.power.ui.DetailOfSoftConsumptionActivity} <string name="cpu_time_front">CPU 占用时间 (前台)</string> <string name="cpu_bg">CPU 占用时间 (后台)</string>
2. Settings 的后台时长
BatteryUtils.getProcessTimeMs(StatusType.BACKGROUND, uid) BatteryUtils.getProcessBackgroundTimeMs(uid, which) BatteryStats.Uid.getProcessStateTime(Battery.UID.PROCESS_STATE_BACKGROUND)
2.1 摘要
时长基于进程state为:PROCESS_STATE_IMPORTANT_BACKGROUND、PROCESS_STATE_TRANSTENT_BACKGROUND、PROCESS_STATE_BACKUP、PROCESS_STATE_SERVICE、PROCESS_STATE_RECEIVER 为后台时长并累加;
2.1 Battery.UID.PROCESS_STATE_BACKGROUND
通俗的意思是非前台即为后台: ActivityManager 为 6 ~ 11 的进程
-
PROCESS_STATE_RECEIVER 11 后台进程,且正在运行receiver
-
PROCESS_STATE_SERVICE 10 后台进程,且正在运行service
-
PROCESS_STATE_BACKUP 9 备份进程
-
PROCESS_STATE_TRANSTENT_BACKGROUND 8 对于用户比较重要的后台进程
-
PROCESS_STATE_IMPORTANT_BACKGROUND 7 对用户很重要的进程,用户可感知其存在
--javascripttypescriptshellbashsqljsonhtmlcssccppjavarubypythongorustmarkdown
848 /**
849 * Time this uid has any process in an active background state, but none in the
850 * "foreground" or better state.
851 */
852 public static final int PROCESS_STATE_BACKGROUND = 3;
630 /**
631 * Maps the ActivityManager procstate into corresponding BatteryStats procstate.
632 */
633 public static int mapToInternalProcessState(int procState) {
634 if (procState == ActivityManager.PR