Есть ли альтернатива для API getRunningTask
Я использовал API getRunningTask в одном из своих приложений, чтобы найти приложение Foreground. Этот API был устаревшим с Lollipop. После этого устаревания я предпочел API getRunningAppProcess вместе с Importance_Foreground. Я также исключил REASON_SERVICE и REASON_PROVIDER из этого списка. Я отфильтровал системные приложения на основе логики, которая отлично работала. Проблема в том, что если приложение A находится на переднем плане, я получаю Application B как всплеск. Таким образом, этот подход в настоящее время вызывает сомнения. Есть ли другая альтернатива API getRunningTask? Или мне не хватает простейшей вещи в текущем подходе. Пожалуйста, помогите парням.
- Создание и совместное использование файла из внутреннего хранилища
- как измерять скорость загрузки / скачивания и задержку в соединении Wi-Fi для Android
- objective ACTION_VIEW для файла с неизвестным MimeType
- Пользовательский ListView для Android не может нажимать на элементы
- android - Как я могу сделать кнопку вспышкой?
- Как запустить метод каждые X секунд
- Кэширование в веб-браузере Android
- Как я могу генерировать случайное число в определенном диапазоне в Android?
Основываясь на ответе на этот вопрос
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