From 4d2d0b42973e82a88bee26b8c6fa2d7f8a647aa1 Mon Sep 17 00:00:00 2001 From: asuraliu Date: Fri, 19 Jul 2024 14:51:29 +0800 Subject: [PATCH 1/2] 1. Update targetAPI to 34 and adapt to Android 14; 2. Fix Notification bugs. --- app/build.gradle | 16 ++-- app/src/main/AndroidManifest.xml | 4 +- .../model/NotificationMonitor.java | 33 ++++--- .../service/MonitoringService.java | 30 ++++--- .../ratul/topactivity/ui/MainActivity.java | 88 +++++++++++++++---- .../ratul/topactivity/utils/WindowUtil.java | 4 +- build.gradle | 2 +- gradle.properties | 3 + gradle/wrapper/gradle-wrapper.properties | 2 +- 9 files changed, 121 insertions(+), 61 deletions(-) diff --git a/app/build.gradle b/app/build.gradle index 6afec5a..6ce7b31 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -1,11 +1,13 @@ apply plugin: 'com.android.application' android { - compileSdkVersion 32 + namespace 'io.github.ratul.topactivity' + compileSdkVersion 34 + buildToolsVersion '34.0.0' defaultConfig { applicationId "io.github.ratul.topactivity" minSdkVersion 24 - targetSdkVersion 33 + targetSdkVersion 34 versionCode 18 versionName "1.5.8" } @@ -27,9 +29,9 @@ android { } dependencies { - implementation 'androidx.appcompat:appcompat:1.4.1' - implementation 'com.google.android.material:material:1.6.1' - implementation 'androidx.constraintlayout:constraintlayout:2.1.0' - implementation 'androidx.preference:preference:1.2.0' - implementation 'androidx.core:core:1.7.0' + implementation 'androidx.appcompat:appcompat:1.7.0' + implementation 'com.google.android.material:material:1.12.0' + implementation 'androidx.constraintlayout:constraintlayout:2.1.4' + implementation 'androidx.preference:preference:1.2.1' + implementation 'androidx.core:core:1.13.1' } diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml index f6a09fe..113c201 100644 --- a/app/src/main/AndroidManifest.xml +++ b/app/src/main/AndroidManifest.xml @@ -1,12 +1,12 @@ - + + diff --git a/app/src/main/java/io/github/ratul/topactivity/model/NotificationMonitor.java b/app/src/main/java/io/github/ratul/topactivity/model/NotificationMonitor.java index 65ee793..97b1c7e 100644 --- a/app/src/main/java/io/github/ratul/topactivity/model/NotificationMonitor.java +++ b/app/src/main/java/io/github/ratul/topactivity/model/NotificationMonitor.java @@ -16,27 +16,21 @@ */ package io.github.ratul.topactivity.model; -import android.app.ActivityManager; +import android.app.Notification; +import android.app.NotificationChannel; import android.app.NotificationManager; import android.app.PendingIntent; -import android.app.NotificationChannel; import android.app.TaskStackBuilder; -import android.app.Notification; -import android.graphics.Color; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.os.Build; -import android.widget.Toast; - -import java.util.List; -import java.lang.reflect.AnnotatedElement; -import io.github.ratul.topactivity.utils.DatabaseUtil; import io.github.ratul.topactivity.R; +import io.github.ratul.topactivity.service.QuickSettingsTileService; import io.github.ratul.topactivity.ui.MainActivity; +import io.github.ratul.topactivity.utils.DatabaseUtil; import io.github.ratul.topactivity.utils.WindowUtil; -import io.github.ratul.topactivity.service.QuickSettingsTileService; /** * Created by Ratul on 04/05/2022. @@ -58,13 +52,19 @@ public static void showNotification(Context context, boolean isPaused) { TaskStackBuilder stackBuilder = TaskStackBuilder.create(context); stackBuilder.addParentStack(MainActivity.class); stackBuilder.addNextIntent(intent); - PendingIntent pIntent = stackBuilder.getPendingIntent(0, PendingIntent.FLAG_UPDATE_CURRENT); + int flag; + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.S) { + flag = PendingIntent.FLAG_IMMUTABLE; + } else { + flag = PendingIntent.FLAG_UPDATE_CURRENT; + } + PendingIntent pIntent = stackBuilder.getPendingIntent(0, flag); if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { String CHANNEL_ID = context.getPackageName() + "_channel_007"; CharSequence name = "Activity Info"; - NotificationChannel mChannel = new NotificationChannel(CHANNEL_ID, name, NotificationManager.IMPORTANCE_MAX); + NotificationChannel mChannel = new NotificationChannel(CHANNEL_ID, name, NotificationManager.IMPORTANCE_DEFAULT); mChannel.setDescription("Shows current activity info"); mChannel.enableLights(false); mChannel.enableVibration(false); @@ -72,8 +72,7 @@ public static void showNotification(Context context, boolean isPaused) { notifManager.createNotificationChannel(mChannel); builder = new Notification.Builder(context, CHANNEL_ID); - } - else { + } else { builder = new Notification.Builder(context); } @@ -86,8 +85,8 @@ public static void showNotification(Context context, boolean isPaused) { .setAutoCancel(true) .setContentIntent(pIntent); - builder.addAction(R.drawable.ic_launcher_foreground, context.getString(R.string.noti_action_stop), - getPendingIntent(context, ACTION_STOP)).setContentIntent(pIntent); +// builder.addAction(R.drawable.ic_launcher_foreground, context.getString(R.string.noti_action_stop), +// getPendingIntent(context, ACTION_STOP)).setContentIntent(pIntent); notifManager.notify(NOTIFICATION_ID, builder.build()); } @@ -95,7 +94,7 @@ public static void showNotification(Context context, boolean isPaused) { public static PendingIntent getPendingIntent(Context context, int command) { Intent intent = new Intent("io.github.ratul.topactivity.ACTION_NOTIFICATION_RECEIVER"); intent.putExtra(EXTRA_NOTIFICATION_ACTION, command); - return PendingIntent.getBroadcast(context, 0, intent, 0); + return PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_IMMUTABLE); } public static void cancelNotification(Context context) { diff --git a/app/src/main/java/io/github/ratul/topactivity/service/MonitoringService.java b/app/src/main/java/io/github/ratul/topactivity/service/MonitoringService.java index 69e7585..c55a382 100644 --- a/app/src/main/java/io/github/ratul/topactivity/service/MonitoringService.java +++ b/app/src/main/java/io/github/ratul/topactivity/service/MonitoringService.java @@ -16,17 +16,17 @@ */ package io.github.ratul.topactivity.service; -import android.annotation.*; -import android.app.*; -import android.app.ActivityManager.*; -import android.content.*; -import android.content.pm.*; -import android.os.*; -import android.util.*; +import android.app.AlarmManager; +import android.app.PendingIntent; +import android.app.Service; +import android.app.usage.UsageEvents; +import android.app.usage.UsageStatsManager; +import android.content.Context; +import android.content.Intent; +import android.os.Handler; +import android.os.IBinder; +import android.os.SystemClock; -import java.util.*; -import android.app.usage.*; -import android.widget.Toast; import io.github.ratul.topactivity.utils.DatabaseUtil; import io.github.ratul.topactivity.utils.WindowUtil; @@ -94,9 +94,16 @@ public void run() { MonitoringService.INSTANCE.stopSelf(); } + String preText = MonitoringService.INSTANCE.text; + String preText1 = MonitoringService.INSTANCE.text1; getActivityInfo(); if (MonitoringService.INSTANCE.text == null) return; + if (preText != null && preText.equals(MonitoringService.INSTANCE.text) + && preText1 != null && preText1.equals(MonitoringService.INSTANCE.text1)) { + // not change, return + return; + } MonitoringService.INSTANCE.firstRun = false; if (DatabaseUtil.isShowWindow()) { @@ -113,14 +120,13 @@ public void run() { return super.onStartCommand(intent, flags, startId); } - @TargetApi(Build.VERSION_CODES.ICE_CREAM_SANDWICH) @Override public void onTaskRemoved(Intent rootIntent) { Intent restartServiceIntent = new Intent(getApplicationContext(), this.getClass()); restartServiceIntent.setPackage(getPackageName()); PendingIntent restartServicePendingIntent = PendingIntent.getService(getApplicationContext(), 1, - restartServiceIntent, PendingIntent.FLAG_ONE_SHOT); + restartServiceIntent, PendingIntent.FLAG_ONE_SHOT | PendingIntent.FLAG_IMMUTABLE); AlarmManager alarmService = (AlarmManager) getApplicationContext().getSystemService(Context.ALARM_SERVICE); alarmService.set(AlarmManager.ELAPSED_REALTIME, SystemClock.elapsedRealtime() + 500, restartServicePendingIntent); diff --git a/app/src/main/java/io/github/ratul/topactivity/ui/MainActivity.java b/app/src/main/java/io/github/ratul/topactivity/ui/MainActivity.java index f300737..1b2b612 100644 --- a/app/src/main/java/io/github/ratul/topactivity/ui/MainActivity.java +++ b/app/src/main/java/io/github/ratul/topactivity/ui/MainActivity.java @@ -16,37 +16,60 @@ */ package io.github.ratul.topactivity.ui; -import android.app.*; -import android.content.*; +import android.Manifest; +import android.app.Activity; +import android.app.AppOpsManager; +import android.content.BroadcastReceiver; +import android.content.Context; +import android.content.DialogInterface; +import android.content.Intent; +import android.content.IntentFilter; +import android.content.pm.PackageManager; +import android.graphics.Insets; import android.net.Uri; -import android.os.*; -import android.provider.*; -import android.view.*; -import android.widget.*; +import android.os.Build; +import android.os.Bundle; +import android.provider.Settings; +import android.text.Spannable; +import android.text.SpannableString; +import android.util.DisplayMetrics; +import android.view.Menu; +import android.view.MenuItem; +import android.view.View; +import android.view.WindowInsets; +import android.view.WindowMetrics; +import android.widget.CompoundButton; import android.widget.CompoundButton.OnCheckedChangeListener; -import android.app.*; +import android.widget.Toast; + +import androidx.annotation.NonNull; import androidx.appcompat.app.ActionBar; -import android.content.pm.*; -import android.graphics.drawable.*; -import android.graphics.*; -import android.text.*; import androidx.appcompat.app.AppCompatActivity; +import androidx.core.content.ContextCompat; + import com.google.android.material.dialog.MaterialAlertDialogBuilder; import com.google.android.material.switchmaterial.SwitchMaterial; -import java.util.List; -import io.github.ratul.topactivity.*; -import io.github.ratul.topactivity.utils.*; + +import java.io.BufferedReader; +import java.io.File; +import java.io.FileOutputStream; +import java.io.FileReader; + +import io.github.ratul.topactivity.App; +import io.github.ratul.topactivity.R; import io.github.ratul.topactivity.model.NotificationMonitor; -import io.github.ratul.topactivity.service.*; import io.github.ratul.topactivity.model.TypefaceSpan; -import java.io.*; -import android.util.DisplayMetrics; +import io.github.ratul.topactivity.service.AccessibilityMonitoringService; +import io.github.ratul.topactivity.service.MonitoringService; +import io.github.ratul.topactivity.utils.DatabaseUtil; +import io.github.ratul.topactivity.utils.WindowUtil; /** * Created by Wen on 16/02/2017. * Refactored by Ratul on 04/05/2022. */ public class MainActivity extends AppCompatActivity { + public static final int REQUEST_CODE_NOTIFICATION = 100; public static final String EXTRA_FROM_QS_TILE = "from_qs_tile"; public static final String ACTION_STATE_CHANGED = "io.github.ratul.topactivity.ACTION_STATE_CHANGED"; private SwitchMaterial mWindowSwitch, mNotificationSwitch, mAccessibilitySwitch; @@ -86,7 +109,7 @@ public void onClick(DialogInterface di, int btn) { } mReceiver = new UpdateSwitchReceiver(); - registerReceiver(mReceiver, new IntentFilter(ACTION_STATE_CHANGED)); + ContextCompat.registerReceiver(this, mReceiver, new IntentFilter(ACTION_STATE_CHANGED), ContextCompat.RECEIVER_NOT_EXPORTED); mNotificationSwitch.setOnCheckedChangeListener(new SwitchMaterial.OnCheckedChangeListener() { @Override @@ -105,7 +128,7 @@ public void onCheckedChanged(CompoundButton button, boolean isChecked) { mWindowSwitch.setOnCheckedChangeListener(new SwitchMaterial.OnCheckedChangeListener() { @Override public void onCheckedChanged(CompoundButton button, boolean isChecked) { - if (Build.VERSION.SDK_INT >= 23 && !Settings.canDrawOverlays(MainActivity.this)) { + if (!Settings.canDrawOverlays(MainActivity.this)) { fancy.setTitle("Overlay Permission") .setMessage("Please enable overlay permission to show window over other apps") .setPositiveButton("Settings", new DialogInterface.OnClickListener() { @@ -181,6 +204,33 @@ protected void onNewIntent(Intent intent) { } } + @Override + protected void onStart() { + super.onStart(); + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU && !mNotificationSwitch.isChecked()) { + if (checkSelfPermission(Manifest.permission.POST_NOTIFICATIONS) != PackageManager.PERMISSION_GRANTED) { + requestPermissions(new String[]{Manifest.permission.POST_NOTIFICATIONS}, REQUEST_CODE_NOTIFICATION); + } + } + } + + @Override + public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { + super.onRequestPermissionsResult(requestCode, permissions, grantResults); + if (requestCode == REQUEST_CODE_NOTIFICATION) { + if (grantResults[0] == PackageManager.PERMISSION_DENIED) { + if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU + && shouldShowRequestPermissionRationale(Manifest.permission.POST_NOTIFICATIONS)) { + requestPermissions(new String[]{Manifest.permission.POST_NOTIFICATIONS}, REQUEST_CODE_NOTIFICATION); + } else { + showToast("POST_NOTIFICATIONS Permission Denied", Toast.LENGTH_SHORT); + } + } else { + showToast("POST_NOTIFICATIONS Permission Granted", Toast.LENGTH_SHORT); + } + } + } + @Override protected void onResume() { super.onResume(); diff --git a/app/src/main/java/io/github/ratul/topactivity/utils/WindowUtil.java b/app/src/main/java/io/github/ratul/topactivity/utils/WindowUtil.java index 80bfb32..e797c92 100644 --- a/app/src/main/java/io/github/ratul/topactivity/utils/WindowUtil.java +++ b/app/src/main/java/io/github/ratul/topactivity/utils/WindowUtil.java @@ -177,8 +177,8 @@ public static void show(Context context, String pkg, String clas) { } if (NotificationMonitor.builder != null) { - NotificationMonitor.builder.setContentTitle(text); - NotificationMonitor.builder.setContentText(text1); + NotificationMonitor.builder.setContentTitle(pkg); + NotificationMonitor.builder.setContentText(clas); NotificationMonitor.notifManager.notify(NotificationMonitor.NOTIFICATION_ID, NotificationMonitor.builder.build()); } diff --git a/build.gradle b/build.gradle index 9c32f2d..95baea5 100644 --- a/build.gradle +++ b/build.gradle @@ -5,7 +5,7 @@ buildscript { mavenCentral() } dependencies { - classpath 'com.android.tools.build:gradle:7.2.1' + classpath 'com.android.tools.build:gradle:8.4.2' } } diff --git a/gradle.properties b/gradle.properties index 079df3f..17bec0b 100644 --- a/gradle.properties +++ b/gradle.properties @@ -18,3 +18,6 @@ org.gradle.jvmargs=-Xmx1536m android.useAndroidX=true android.R8=true android.enableJetifier=true +android.defaults.buildfeatures.buildconfig=true +android.nonTransitiveRClass=false +android.nonFinalResIds=false diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties index 174aad7..750ebbe 100644 --- a/gradle/wrapper/gradle-wrapper.properties +++ b/gradle/wrapper/gradle-wrapper.properties @@ -1,6 +1,6 @@ #Mon Aug 30 15:20:07 CST 2021 distributionBase=GRADLE_USER_HOME -distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.2-bin.zip +distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-bin.zip distributionPath=wrapper/dists zipStorePath=wrapper/dists zipStoreBase=GRADLE_USER_HOME From 3a36983639979684a0520f0ad83a2e3a2cb710e6 Mon Sep 17 00:00:00 2001 From: asuraliu Date: Fri, 19 Jul 2024 14:58:12 +0800 Subject: [PATCH 2/2] Upgrade Version to 1.5.9:Supported Android 14+ and fix bugs --- README.md | 4 ++-- app/build.gradle | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index dd15b75..b82c460 100644 --- a/README.md +++ b/README.md @@ -9,8 +9,8 @@ An useful tool for Android Developers & Reversers, which shows the package n


-[![App](https://img.shields.io/badge/Current%20Activity-1.5.8-blue?logo=)](https://github.com/RatulHasan8/Current-Activity/releases/tag/app-n-source) -[![SDK](https://img.shields.io/badge/Android-5.0%20and%20up-brightgreen?logo=android&logoColor=white)](https://github.com/RatulHasan8/Current-Activity/releases/tag/app-n-source) +[![App](https://img.shields.io/badge/Current%20Activity-1.5.9-blue?logo=)](https://github.com/RatulHasan8/Current-Activity/releases/tag/app-n-source) +[![SDK](https://img.shields.io/badge/Android-7.0%20to%2014up-brightgreen?logo=android&logoColor=white)](https://github.com/RatulHasan8/Current-Activity/releases/tag/app-n-source) [![License](https://img.shields.io/badge/License-GPL-red?logo=gnu&logoColor=white)](./LICENSE) [![Maintenance](https://img.shields.io/badge/Maintained-Yes-green?logo=)](https://github.com/ratsan/Current-Activity/graphs/commit-activity) [![Contributions](https://img.shields.io/badge/Contributions-Open-yellow?logo=)](https://github.com/ratsan/Current-Activity/pulls) diff --git a/app/build.gradle b/app/build.gradle index 6ce7b31..2679dfc 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -8,8 +8,8 @@ android { applicationId "io.github.ratul.topactivity" minSdkVersion 24 targetSdkVersion 34 - versionCode 18 - versionName "1.5.8" + versionCode 19 + versionName "1.5.9" } buildTypes {