diff --git a/app/src/apkFlavor/AndroidManifest.xml b/app/src/apkFlavor/AndroidManifest.xml
index 6f843ef0..41dd23ad 100644
--- a/app/src/apkFlavor/AndroidManifest.xml
+++ b/app/src/apkFlavor/AndroidManifest.xml
@@ -266,6 +266,10 @@
+
+
diff --git a/app/src/fdroidFlavor/AndroidManifest.xml b/app/src/fdroidFlavor/AndroidManifest.xml
index af39e626..e02e0287 100644
--- a/app/src/fdroidFlavor/AndroidManifest.xml
+++ b/app/src/fdroidFlavor/AndroidManifest.xml
@@ -251,6 +251,10 @@
+
+
diff --git a/app/src/googlePlayFlavor/AndroidManifest.xml b/app/src/googlePlayFlavor/AndroidManifest.xml
index 1c67849b..cbc088a4 100644
--- a/app/src/googlePlayFlavor/AndroidManifest.xml
+++ b/app/src/googlePlayFlavor/AndroidManifest.xml
@@ -250,6 +250,10 @@
+
+
diff --git a/app/src/main/java/com/jens/automation2/Action.java b/app/src/main/java/com/jens/automation2/Action.java
index 2c3c3598..da605244 100644
--- a/app/src/main/java/com/jens/automation2/Action.java
+++ b/app/src/main/java/com/jens/automation2/Action.java
@@ -640,6 +640,9 @@ public class Action
case copyToClipboard:
Actions.copyToClipboard(context, Miscellaneous.replaceVariablesInText(this.getParameter2(), context));
break;
+ case takeScreenshot:
+ Actions.takeScreenshot();
+ break;
default:
Miscellaneous.logEvent("w", "Action", context.getResources().getString(R.string.unknownActionSpecified), 3);
break;
diff --git a/app/src/main/java/com/jens/automation2/ActivityManageRule.java b/app/src/main/java/com/jens/automation2/ActivityManageRule.java
index b012e1a0..b5c62051 100644
--- a/app/src/main/java/com/jens/automation2/ActivityManageRule.java
+++ b/app/src/main/java/com/jens/automation2/ActivityManageRule.java
@@ -2127,7 +2127,7 @@ public class ActivityManageRule extends Activity
else if(types[i].toString().equals(Action_Enum.copyToClipboard.toString()))
items.add(new Item(typesLong[i].toString(), R.drawable.clipboard));
else if(types[i].toString().equals(Action_Enum.takeScreenshot.toString()))
- items.add(new Item(typesLong[i].toString(), R.drawable.clipboard));
+ items.add(new Item(typesLong[i].toString(), R.drawable.copier));
else
items.add(new Item(typesLong[i].toString(), R.drawable.placeholder));
}
diff --git a/app/src/main/java/com/jens/automation2/ActivityPermissions.java b/app/src/main/java/com/jens/automation2/ActivityPermissions.java
index 43a9c2d4..87b47166 100644
--- a/app/src/main/java/com/jens/automation2/ActivityPermissions.java
+++ b/app/src/main/java/com/jens/automation2/ActivityPermissions.java
@@ -333,31 +333,33 @@ public class ActivityPermissions extends Activity
{
int accessibilityEnabled = 0;
- final String service = mContext.getPackageName() + "/com.mytest.accessibility.MyAccessibilityService";
+ final String service = mContext.getPackageName() + "/" + BuildConfig.APPLICATION_ID + ".MyAccessibilityService";
boolean accessibilityFound = false;
try
{
accessibilityEnabled = Settings.Secure.getInt(mContext.getApplicationContext().getContentResolver(), Settings.Secure.ACCESSIBILITY_ENABLED);
- Log.v(TAG, "accessibilityEnabled = " + accessibilityEnabled);
+// Log.v(TAG, "accessibilityEnabled = " + accessibilityEnabled);
}
catch (Settings.SettingNotFoundException e)
{
- Log.e(TAG, "Error finding setting, default accessibility to not found: " + e.getMessage());
+// Log.e(TAG, "Error finding setting, default accessibility to not found: " + e.getMessage());
}
TextUtils.SimpleStringSplitter mStringColonSplitter = new TextUtils.SimpleStringSplitter(':');
- if (accessibilityEnabled == 1) {
- String settingValue = Settings.Secure.getString(mContext
- .getApplicationContext().getContentResolver(),
- Settings.Secure.ENABLED_ACCESSIBILITY_SERVICES);
- if (settingValue != null) {
+ if (accessibilityEnabled == 1)
+ {
+ String settingValue = Settings.Secure.getString(mContext.getApplicationContext().getContentResolver(), Settings.Secure.ENABLED_ACCESSIBILITY_SERVICES);
+ if (settingValue != null)
+ {
TextUtils.SimpleStringSplitter splitter = mStringColonSplitter;
splitter.setString(settingValue);
- while (splitter.hasNext()) {
- String accessabilityService = splitter.next();
+ while (splitter.hasNext())
+ {
+ String accessibilityService = splitter.next();
- if (accessabilityService.equalsIgnoreCase(service)) {
+ if (accessibilityService.equalsIgnoreCase(service))
+ {
return true;
}
}
@@ -1026,7 +1028,9 @@ public class ActivityPermissions extends Activity
usingElements.add(getResources().getString(R.string.queryAllPackages));
break;
case Manifest.permission.BIND_ACCESSIBILITY_SERVICE:
- usingElements.add(getResources().getString(R.string.bindAccessibilityService));
+ for(String ruleName : getRulesUsing(Action.Action_Enum.takeScreenshot))
+ usingElements.add(String.format(getResources().getString(R.string.ruleXrequiresThis), ruleName));
+ break;
}
return usingElements;
@@ -1035,6 +1039,15 @@ public class ActivityPermissions extends Activity
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
+ /*
+ All of the following permissions need to be "manually" activated by the user in some
+ buried system menu.
+ In my opinion by mistake the function will be called when the user has just landed
+ on one of those screens, not when he exits it again. To compensate for that onResume()
+ is overridden. This enables the permission screen to automatically close after all
+ required permissions have been granted.
+ */
+
super.onActivityResult(requestCode, resultCode, data);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M)
@@ -1665,4 +1678,19 @@ public class ActivityPermissions extends Activity
return false;
}
}
+
+ @Override
+ protected void onResume()
+ {
+ super.onResume();
+
+ for(String p : getRequiredPermissions(false))
+ {
+ if(!havePermission(p, this))
+ return;
+ }
+
+ // have all
+ setHaveAllPermissions();
+ }
}
\ No newline at end of file
diff --git a/app/src/main/java/com/jens/automation2/MyAccessibilityService.java b/app/src/main/java/com/jens/automation2/MyAccessibilityService.java
index 922c91f9..79edbd13 100644
--- a/app/src/main/java/com/jens/automation2/MyAccessibilityService.java
+++ b/app/src/main/java/com/jens/automation2/MyAccessibilityService.java
@@ -1,8 +1,14 @@
package com.jens.automation2;
import android.accessibilityservice.AccessibilityService;
+import android.os.Build;
+import android.util.Log;
+import android.view.Display;
import android.view.accessibility.AccessibilityEvent;
+import androidx.annotation.NonNull;
+import androidx.annotation.RequiresApi;
+
public class MyAccessibilityService extends AccessibilityService
{
static MyAccessibilityService instance;
@@ -10,7 +16,9 @@ public class MyAccessibilityService extends AccessibilityService
public static MyAccessibilityService getInstance()
{
if(instance == null)
+ {
instance = new MyAccessibilityService();
+ }
return instance;
}
@@ -26,4 +34,18 @@ public class MyAccessibilityService extends AccessibilityService
{
}
+
+ @Override
+ public void onCreate()
+ {
+ super.onCreate();
+ instance = this;
+ }
+
+ @Override
+ protected void onServiceConnected()
+ {
+ super.onServiceConnected();
+ Miscellaneous.logEvent("i", "Accessibility service", "Service started.", 4);
+ }
}
\ No newline at end of file
diff --git a/app/src/main/res/drawable-hdpi/copier.png b/app/src/main/res/drawable-hdpi/copier.png
new file mode 100644
index 00000000..81257cb0
Binary files /dev/null and b/app/src/main/res/drawable-hdpi/copier.png differ
diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml
index bfaa942c..7651fe98 100644
--- a/app/src/main/res/values/strings.xml
+++ b/app/src/main/res/values/strings.xml
@@ -893,6 +893,8 @@
GET
POST
Take screenshot
+ Bind to accessibility service
Bind to accessibility service
After clicking OK you\'ll be sent to a system dialog. Please select Automation there and allow "Allow accessibility API".
+ Required for certains actions.
\ No newline at end of file
diff --git a/app/src/main/res/xml/config_accessibility_service.xml b/app/src/main/res/xml/config_accessibility_service.xml
new file mode 100644
index 00000000..b1f0a7e9
--- /dev/null
+++ b/app/src/main/res/xml/config_accessibility_service.xml
@@ -0,0 +1,12 @@
+
+
\ No newline at end of file
diff --git a/fastlane/metadata/android/en-US/changelogs/138.txt b/fastlane/metadata/android/en-US/changelogs/138.txt
index 7c8e11a0..1ccda421 100644
--- a/fastlane/metadata/android/en-US/changelogs/138.txt
+++ b/fastlane/metadata/android/en-US/changelogs/138.txt
@@ -1,3 +1,4 @@
* Fixed: Overlay permission for start other program action only required if startByActivity() is selected
* Fixed: Broadcast receiver trigger would not trigger anything, but crash
-* Added: One can now choose between GET and POST when using triggerURL action
\ No newline at end of file
+* Added: One can now choose between GET and POST when using triggerURL action
+* Added: new action -> take screenshot
\ No newline at end of file