Я использовал API getRunningTask в одном из своих приложений, чтобы найти приложение Foreground. Этот API был устаревшим с Lollipop. После этого устаревания я предпочел API getRunningAppProcess вместе с Importance_Foreground. Я также исключил REASON_SERVICE и REASON_PROVIDER из этого списка. Я отфильтровал системные приложения на основе логики, которая отлично работала. Проблема в том, что если приложение A находится на переднем плане, я получаю Application B как всплеск. Таким образом, этот подход в настоящее время вызывает сомнения. Есть ли другая альтернатива API getRunningTask? Или мне не хватает простейшей вещи в текущем подходе. Помогите ребятам.
Есть ли альтернатива для API getRunningTask
Ответ 1
На основе ответа на этот вопрос
String getTopPackage(){
long ts = System.currentTimeMillis();
UsageStatsManager mUsageStatsManager = (UsageStatsManager)getSystemService("usagestats");
List<UsageStats> 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<UsageStats> {
@Override
public int compare(UsageStats lhs, UsageStats rhs) {
return (lhs.getLastTimeUsed() > rhs.getLastTimeUsed()) ? -1 : (lhs.getLastTimeUsed() == rhs.getLastTimeUsed()) ? 0 : 1;
}
}
Это разрешение необходимо:
<uses-permission xmlns:tools="http://schemas.android.com/tools"
android:name="android.permission.PACKAGE_USAGE_STATS"
tools:ignore="ProtectedPermissions" />
И вам потребуется авторизация пользователя для запроса статистики, используйте это, чтобы направить пользователя на страницу настроек:
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;
}
}
Ответ 2
Получить список RunningAppProcessInfo
на ActivityManager.getRunningAppProcesses()
.
Выберите RuningAppProcessInfo
с importance
== RunningAppProcessInfo.IMPORTANCE_FOREGROUND
и processState
== ActivityManager.START_TASK_TO_FRONT
.
(Первое легко, последнее затруднено, потому что требуется отражение)
См. мой ответ на этот вопрос getRunningTasks не работает в Android L