質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Q&A

1回答

4610閲覧

AndroidStudioのUsageStatsManagerでアプリの使用履歴の取得

okaru0317

総合スコア10

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

0グッド

0クリップ

投稿2017/01/08 09:49

編集2017/01/08 11:48

###前提・実現したいこと
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を使用して開発しています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yona

2017/01/08 11:17

msYesterdayの計算している箇所を追記してください。
guest

回答1

0

ミリ秒で確認してもわからないので、SimpleDateFormatを使って日付文字列にフォーマットして確認してください。

・Calendar.getInstance()は現在時刻を返すのでDateを別途設定する必要はありません。
・GMTとの時差を考慮する必要は無いと思います。

追記
開始時間の作成処理をリファクタリングしました。

Java

1Calendar objNow = Calendar.getInstance(); 2objNow.add(Calendar.DAY_OF_MONTH, -1); 3objNow.set(Calendar.HOUR_OF_DAY,0); 4objNow.set(Calendar.MINUTE,0); 5objNow.set(Calendar.SECOND,0); 6objNow.set(Calendar.MILLISECOND,0); 7long msYesterday = objNow.getTimeInMillis();

投稿2017/01/08 12:03

編集2017/01/08 13:34
yona

総合スコア18155

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

okaru0317

2017/01/08 12:54

回答ありがとうございます。 上記のmsYesterdayを ------------------------------------- Date toDate = new Date(msYesterday); Log.d("yesterday", toDate + ""); ------------------------------------- と記述して先ほど実行して、ログを見てみたところ ------------------------------------- D/yesterday: Sat Jan 07 00:00:00 GMT+00:00 2017 ------------------------------------- と書いてありました。 なのでmsYesterdayのミリ秒は昨日の0時になっているのではないかと思います。
yona

2017/01/08 13:53

2017/01/07 00:00:00〜2017/01/08 00:00:00になっているとして、UsageStats内の各メソッドはどのような値を返していますか?
okaru0317

2017/01/08 14:55 編集

追記ありがとうございます。参考にさせていただきます。 UsageStats内のメソッドは 上記の使用履歴取得のためのソースコードの続きに ------------------------------------------------------------------------------------------ for (Map.Entry<Long, UsageStats> entry : map.entrySet()) {  マップ完成 UsageStats usageStats = entry.getValue(); times[i] = usageStats.getTotalTimeInForeground(); packagename[i] = usageStats.getPackageName(); ------------------------------------------------------------------------------------------ 以上のように記述してあり、timesの中に入っていると思われます。 今回はエミュレーターで実行していて、ログでtimesとpackagenameをそれぞれ見てみると ------------------------------------------------------------------------------------------ D/packagename: com.android.providers.contacts D/times: 0 D/packagename: com.google.android.googlequicksearchbox D/times: 43253 D/packagename: jp.ac.test.test3 D/times: 364208 ------------------------------------------------------------------------------------------ と書かれていました。 これは昨日の使用履歴とは異なっていると思われます。
yona

2017/01/08 15:52

getLastTimeStampを日付文字列に変換してください。
okaru0317

2017/01/08 16:06

回答ありがとうございます。 申し訳ありません。 getLastTimeStampを日付文字列に変換してください。とは getLastTimeStampを新たに加えてから日付文字列に変換するということでしょうか?
yona

2017/01/08 16:13

UsageStats#getLastTimeStampを日付文字列に変換してください。
okaru0317

2017/01/09 13:44

回答ありがとうございます。 返事が後れてしまい申し訳ありません。 -------------------------------------------------- timestamp[i] = usageStats.getLastTimeStamp() Date day = new Date(timestamp[i]); Log.d("timestamp", day + ""); -------------------------------------------------- と記述して先ほど実行して、ログを確認したところ、 -------------------------------------------------- D/timestamp: Mon Jan 09 13:37:21 GMT+00:00 2017 D/packagename: com.android.providers.contacts D/times: 0 D/timestamp: Mon Jan 09 13:37:29 GMT+00:00 2017 D/packagename: com.google.android.googlequicksearchbox D/times: 18116 D/timestamp: Mon Jan 09 13:36:22 GMT+00:00 2017 D/packagename: com.android.settings D/times: 32261 D/timestamp: Mon Jan 09 13:37:29 GMT+00:00 2017 D/packagename: jp.ac.kanagawa_it.s1323013.test3 D/times: 64941 --------------------------------------------------- と書かれていました。 これは今日の使用履歴になっていると思われます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問