Android 6.0 Marshmallow では、次のコードでフォアグラウンド アプリをクエリしますが、通知を送信するアプリにフォアグラウンド アプリを表示するため、着信通知に問題がありました。この問題は Marshmallow にのみ存在します (5.X は正常に動作します)。
// API 21 and above
@TargetApi(Build.VERSION_CODES.LOLLIPOP)
public static String getProcessNew(UsageStatsManager mUsageStatsManager, Context c) throws Exception {
String st = null;
try {
long endTime = System.currentTimeMillis();
long beginTime = endTime - 1000 * 10;
// We get usage stats for the last minute
List<UsageStats> stats = mUsageStatsManager.queryUsageStats(UsageStatsManager.INTERVAL_DAILY, beginTime,
endTime);
// Sort the stats by the last time used
if (stats != null) {
SortedMap<Long, UsageStats> mySortedMap = new TreeMap<Long, UsageStats>();
for (UsageStats usageStats : stats) {
mySortedMap.put(usageStats.getLastTimeUsed(), usageStats);
}
if (mySortedMap != null && !mySortedMap.isEmpty()) {
st = mySortedMap.get(mySortedMap.lastKey()).getPackageName();
}
}
} catch (Exception e) {
Log.d("main", "Wxxxxexx " + e);
}
return st;
}
そして、通知の問題は、この回答UsageEvents のソリューションを使用して解決されます。
答えの解決策として、フォアグラウンドアプリを取得するためのコードとその動作を入れましたが、3秒遅れました。私のサービスはフォアグラウンドアプリをチェックしており、500ミリ秒ごとに繰り返していますが、whatsappパッケージはwhatsappを開始してから3秒後に検出します。これは、上記のソリューションから使用する UsageEvents のコードです。
if (BuildV >= 23) {
long endTime = System.currentTimeMillis();
long beginTime = endTime - 1000 * 10;
UsageEvents usageEvents = mUsageStatsManager.queryEvents(beginTime, endTime);
UsageEvents.Event event = new UsageEvents.Event();
while (usageEvents.hasNextEvent()) {
usageEvents.getNextEvent(event);
}
if (st.equals(event.getPackageName())
&& event.getEventType() == UsageEvents.Event.MOVE_TO_FOREGROUND) {
pack = st;
}
}