5

目标:
需要获取今天的使用统计信息(今天使用设备的总时间),即。上午 12 点至当前时间。

问题: 1.
我得到今天的时间 + 一些其他不可解释的时间2.不可解释
的时间戳(由 getTimestamp 方法检索的使用统计的开始和结束)
时间段不相关。我将开始时间定为上午 12 点,将结束时间定为当前时间,但是对于使用统计,我得到完全不相关的“.firstTimeStamp”和“.lastTimeStamp”(据说返回使用统计数据的开始和结束)。

*已经完成了权限授予部分,这是我用来获取总时间(以分钟为单位)的功能。

fun showtime(){

    val time=Calendar.getInstance()
    time.set(Calendar.HOUR_OF_DAY,0)
    time.set(Calendar.MINUTE,0)

    val start=time.timeInMillis
    val end= System.currentTimeMillis()

    val usageStatsManager = getSystemService(Context.USAGE_STATS_SERVICE) as UsageStatsManager
    var stats = usageStatsManager.queryAndAggregateUsageStats(start,end)

    var x:Long=0
    var ft:Long=0
    var v:Long=0
    var l:Long=0

    for ((key,value) in stats) {
        ft=value.totalTimeInForeground/60000
          textField1.append("$key = $ft mins")
            textField1.append("\n")
            x=x+ft
        v=value.firstTimeStamp
        l=value.lastTimeStamp
    }

    textView.setText("YOU SPENT $x mins.")
    textView2.setText("${Date(v)} to \n${Date(l)}")
}

例如,当上述代码在 12 月 12 日星期三上午 12 点 40 分运行时,结果是:(
在 textView 中):
您花了 90 分钟
(在 textView2 中):
Tue 11 Dec 16:23:19 GMT +05:30 2018 to
Tue 12 月 11 日 19:38:45 GMT +05:30 2018

如何在短短 40 分钟内使用手机 90 分钟?
那些明显不相关的时间戳是什么意思?
我做错了什么来实现我的目标吗?

4

2 回答 2

2

我实际上遇到了类似的问题:

根据我对文档的理解,firstTimeStamp应该lastTimeStamp给出“这个 UsageStats 代表的时间范围的开始(结束)”。

然而,它们与我在queryAndAggregateUsageStatsasbeginTime和中作为论点给出的不同endTime

同样,结果似乎宁愿返回由/totalTimeInForeground给出的时间跨度的结果,而不是请求的结果。firstTimeStamplastTimeStamp

为此,我用谷歌填写了一个错误,请查看https://issuetracker.google.com/issues/118564471

于 2018-12-17T12:49:27.880 回答
1

我注意到你的方法有几个问题。

  • 你失踪了time.set(Calendar.SECOND,0)并且time.set(Calendar.MILLISECOND,0)
  • 精度在分区中丢失ft=value.totalTimeInForeground/60000

我会推荐Java Time (ThreeTenBP)来更准确地处理DateTimeDuration 。我创建了一个新函数进行比较,结果确实不同。

fun showtime2(){
    val start = LocalDate.now().atStartOfDay(ZoneId.systemDefault()).toInstant().toEpochMilli()
    val end = ZonedDateTime.now().toInstant().toEpochMilli()

    val usageStatsManager = getSystemService(Context.USAGE_STATS_SERVICE) as UsageStatsManager
    val stats = usageStatsManager.queryAndAggregateUsageStats(start, end)

    val total = Duration.ofMillis(stats.values.map { it.totalTimeInForeground }.sum())
    println("YOU SPENT ${total.toMinutes()} mins.")
}

你的输出

你花了 577 分钟。

我的输出

你花了 582 分钟。

于 2018-12-11T22:14:09.057 回答