###前提・実現したいこと
AndroidStudioで、UsageStatsManagerのqueryUsageStatsを使用して、昨日の一日のアプリの使用履歴を取得したいと思っています。
###発生している問題・エラーメッセージ
beginTimeに昨日の0時のミリ秒、endTimeにbeginTimeから一日分のミリ秒を足した値を入れて実行しているのですが、帰ってくる値が、今日の使用履歴になってしまいます。
本アプリを入れた次の日にも試してみたのですが、前日に使用して、翌日に使用していないアプリは、前日のそのままの使用時間になっており、前日使用していて、翌日も使用したアプリは使用時間が翌日からの使用時間に更新されてしまっているみたいです。
###該当のソースコード
使用履歴の取得のためのソースコード
UsageStatsManager usm = (UsageStatsManager) getSystemService(Context.USAGE_STATS_SERVICE); // 【3】 long endTime = msYesterday + 24 * 60 * 60 * 1000;//昨日のミリ秒から一日分のミリ秒を足している long beginTime = msYesterday;//msYesterdayには昨日の0時のミリ秒が入っています List<UsageStats> list = usm.queryUsageStats(UsageStatsManager.INTERVAL_BEST, beginTime, endTime); if (list != null && list.size() > 0) { //listに何か入っていたとき SortedMap<Long, UsageStats> map = new TreeMap<>(); for (UsageStats usageStats : list) { //時間順に並び替えたもの map.put(usageStats.getTotalTimeInForeground(), usageStats); }
msYesterdayの計算のソースコード
Calendar objNow = Calendar.getInstance(); Date nowdate = new Date(); objNow.setTime(nowdate); objNow.add(Calendar.DAY_OF_MONTH, -1);//現在から一日前にしている。 objNow.add(Calendar.HOUR_OF_DAY, 9);//GMTとの時差を直している Log.d("nowdate", objNow.getTime()+"");//objNowは前日の時刻を表している final long NOW_TIME_TO_MS = objNow.get(Calendar.HOUR_OF_DAY)*60*60*1000 + objNow.get(Calendar.MINUTE)*60*1000 + objNow.get(Calendar.SECOND)*1000 + objNow.get(Calendar.MILLISECOND); long msYesterday = objNow.getTimeInMillis() - NOW_TIME_TO_MS;//昨日の0時のミリ秒が入っている。
###試したこと
endTimeのミリ秒を今日の0時のミリ秒にして、beginTimeのミリ秒をendTimeから一日分のミリ秒を引いた値に変えて実行してみましたが、同じ結果になってしまいました。
###補足情報(言語/FW/ツール等のバージョンなど)
AndroidStudioを使用して開発しています。