Есть ли альтернатива для API getRunningTask

Я использовал API getRunningTask в одном из своих приложений, чтобы найти приложение Foreground. Этот API был устаревшим с Lollipop. После этого устаревания я предпочел API getRunningAppProcess вместе с Importance_Foreground. Я также исключил REASON_SERVICE и REASON_PROVIDER из этого списка. Я отфильтровал системные приложения на основе логики, которая отлично работала. Проблема в том, что если приложение A находится на переднем плане, я получаю Application B как всплеск. Таким образом, этот подход в настоящее время вызывает сомнения. Есть ли другая альтернатива API getRunningTask? Или мне не хватает простейшей вещи в текущем подходе. Пожалуйста, помогите парням.

Основываясь на ответе на этот вопрос

String getTopPackage(){ long ts = System.currentTimeMillis(); UsageStatsManager mUsageStatsManager = (UsageStatsManager)getSystemService("usagestats"); List usageStats = mUsageStatsManager.queryUsageStats(UsageStatsManager.INTERVAL_BEST, ts-1000, ts); if (usageStats == null || usageStats.size() == 0) { return NONE_PKG; } Collections.sort(usageStats, mRecentComp); return usageStats.get(0).getPackageName(); } 

Это mRecentComp :

 static class RecentUseComparator implements Comparator { @Override public int compare(UsageStats lhs, UsageStats rhs) { return (lhs.getLastTimeUsed() > rhs.getLastTimeUsed()) ? -1 : (lhs.getLastTimeUsed() == rhs.getLastTimeUsed()) ? 0 : 1; } } 

Это разрешение необходимо:

  

И вам потребуется авторизация пользователя для запроса статистики, используйте это, чтобы направить пользователя на страницу настроек:

 Intent intent = new Intent(Settings.ACTION_USAGE_ACCESS_SETTINGS); startActivity(intent); 

И вы можете проверить, имеете ли вы уже такое разрешение:

 public static boolean needPermissionForBlocking(Context context) { try { PackageManager packageManager = context.getPackageManager(); ApplicationInfo applicationInfo = packageManager.getApplicationInfo(context.getPackageName(), 0); AppOpsManager appOpsManager = (AppOpsManager) context.getSystemService(Context.APP_OPS_SERVICE); int mode = appOpsManager.checkOpNoThrow(AppOpsManager.OPSTR_GET_USAGE_STATS, applicationInfo.uid, applicationInfo.packageName); return (mode != AppOpsManager.MODE_ALLOWED); } catch (PackageManager.NameNotFoundException e) { return true; } } 

Получите список RunningAppProcessInfo от ActivityManager.getRunningAppProcesses() . Выберите RuningAppProcessInfo чье importance == RunningAppProcessInfo.IMPORTANCE_FOREGROUND и чей processState == ActivityManager.START_TASK_TO_FRONT . (Первое легко, последнее затруднено, потому что необходимо reflection)

См. Мой ответ на этот вопрос. GetRunningTasks не работает в Android L

  • Как узнать, включен ли экран в Android?
  • Как получить день месяца?
  • Android Volley - BasicNetwork.performRequest: Неожиданный код ответа 400
  • Android Studio - невозможно разрешить символ «firebase»
  • Как получить Bitmap от Uri?
  • Возможно ли в принципе для Android-устройства взаимодействовать с iPhone через Bluetooth / GameKit?
  • Как подключить внешний IP-адрес от Java Android
  • PorterduffXfermode: очистить раздел растрового изображения
  • Как работает сопоставление между ресурсами android ресурсов и ID ресурсов?
  • Android: как интегрировать декодер в мультимедийную инфраструктуру
  • Передача растрового изображения в другую информацию о получении сообщения на логарифме
  • Давайте будем гением компьютера.