From a046d5a804d6842796a718fba4e98c3259340a60 Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Sat, 04 Jun 2022 12:42:04 +0000
Subject: [PATCH] 接口参数问题 标题栏 添加收藏功能
---
app/src/main/java/com/auto/lyric/service/AutoInputService.java | 66 ++++++++++++++++++--------------
1 files changed, 37 insertions(+), 29 deletions(-)
diff --git a/app/src/main/java/com/auto/lyric/service/AutoInputService.java b/app/src/main/java/com/auto/lyric/service/AutoInputService.java
index e5bb979..9e90755 100644
--- a/app/src/main/java/com/auto/lyric/service/AutoInputService.java
+++ b/app/src/main/java/com/auto/lyric/service/AutoInputService.java
@@ -4,6 +4,7 @@
import android.accessibilityservice.AccessibilityServiceInfo;
import android.annotation.SuppressLint;
import android.content.BroadcastReceiver;
+import android.content.ClipboardManager;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
@@ -28,25 +29,26 @@
@Override
public void onReceive(Context context, Intent intent) {
int action = intent.getIntExtra("action", 0);
+ ClipboardManager cmb = (ClipboardManager) context .getSystemService(Context.CLIPBOARD_SERVICE);
Log.e(TAG, "onReceive action: " + action);
switch (action){
case ACTION_SEND:
//List<AccessibilityNodeInfo> nodeInfos = getRootInActiveWindow().findAccessibilityNodeInfosByViewId("com.ss.android.ugc.aweme:id/llp");
AccessibilityNodeInfo sendNode = getViewByDesc(getRootInActiveWindow(),"发送");
- Log.e(TAG, "ACTION_SEND nodeInfos: " + sendNode);
+ Log.e(TAG, "ACTION_SEND "+cmb.getText()+" nodeInfos: " + sendNode);
if(sendNode != null){
Log.e(TAG, "ACTION_SEND nodeInfos: " + sendNode.getClassName());
sendNode.performAction(AccessibilityNodeInfo.ACTION_CLICK);
}else{
- printView(getRootInActiveWindow()," ");
+ //printView(getRootInActiveWindow()," ");
Toast.makeText(getBaseContext(),"未找到控件",Toast.LENGTH_SHORT).show();
}
break;
case ACTION_PASTE:
try{
List<AccessibilityNodeInfo> list = getRootInActiveWindow().findAccessibilityNodeInfosByText("说点什么...");
- Log.e(TAG, "ACTION_PASTE nodeInfos: " + list.size());
- printView(getRootInActiveWindow()," ");
+ Log.e(TAG, "ACTION_PASTE "+cmb.getText()+" nodeInfos: " + list.size());
+ //printView(getRootInActiveWindow()," ");
AccessibilityNodeInfo editNode = getView(getRootInActiveWindow(),"android.widget.EditText");
if(editNode != null){
Log.e(TAG, "ACTION_PASTE nodeInfos: " + editNode.getClassName());
@@ -81,13 +83,13 @@
switch (eventType) {
case AccessibilityEvent.TYPE_WINDOW_CONTENT_CHANGED://界面变化事件
Log.e(TAG, "TYPE_WINDOW_CONTENT_CHANGED " );
- if(event.getClassName().toString().equals("androidx.viewpager.widget.ViewPager")){
+ if(event.getClassName().toString().equals("androidx.viewpager.widget.ViewPager") && flag){
clickEdit();
}
break;
case AccessibilityEvent.TYPE_WINDOW_STATE_CHANGED://界面变化事件
Log.e(TAG, "TYPE_WINDOW_STATE_CHANGED " );
- if(source != null && event.getClassName().toString().equals("com.ss.android.ugc.aweme.live.LivePlayActivity")){
+ if(source != null && event.getClassName().toString().equals("com.ss.android.ugc.aweme.live.LivePlayActivity") && flag){
clickEdit();
}
@@ -127,19 +129,21 @@
* 点击弹出 edit弹框
*/
private void clickEdit(){
- List<AccessibilityNodeInfo> list = getRootInActiveWindow().findAccessibilityNodeInfosByText("说点什么...");
- Log.e(TAG,"获取到控件 "+list.size());
- if (list != null && list.size() > 0 && flag) {
- //模拟第三方点击事件
- //找到你的节点以后 就直接点击他就行了
- //AccessibilityNodeInfo node = list.get(0);
- list.get(0).performAction(AccessibilityNodeInfo.ACTION_CLICK);
- if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) {
- Log.e(TAG,"执行点击 "+list.get(0).getPaneTitle());
+ try{
+ List<AccessibilityNodeInfo> list = getRootInActiveWindow().findAccessibilityNodeInfosByText("说点什么...");
+ Log.e(TAG,"获取到控件 "+list.size());
+ if (list != null && list.size() > 0 && flag) {
+ //模拟第三方点击事件
+ //找到你的节点以后 就直接点击他就行了
+ //AccessibilityNodeInfo node = list.get(0);
+ list.get(0).performAction(AccessibilityNodeInfo.ACTION_CLICK);
+ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.P) {
+ Log.e(TAG,"执行点击 "+list.get(0).getPaneTitle());
+ }
+ }else if(flag){
+ //Toast.makeText(getBaseContext(),"未找到控件",Toast.LENGTH_SHORT).show();
}
- }else if(flag){
- Toast.makeText(getBaseContext(),"未找到控件",Toast.LENGTH_SHORT).show();
- }
+ }catch ( Exception e){}
}
@SuppressLint("NewApi")
@@ -173,20 +177,22 @@
@SuppressLint("NewApi")
private AccessibilityNodeInfo getViewByDesc(AccessibilityNodeInfo node, String desc){
- Log.e(TAG,desc +" getViewByDesc id:"+node.getViewIdResourceName() +" class:"+node.getClassName()+" text:"+node.getText()+" "+node.getContentDescription());
- Log.e(TAG,"getViewByDesc node:"+node);
- if(node.getChildCount() > 0){
- for(int i = 0 ; i < node.getChildCount() ; i ++){
- if(node.getChild(i) != null) {
- AccessibilityNodeInfo nodeInfo = getViewByDesc(node.getChild(i), desc);
- if(nodeInfo != null){
- return nodeInfo;
+ try{
+ //Log.e(TAG,desc +" getViewByDesc id:"+node.getViewIdResourceName() +" class:"+node.getClassName()+" text:"+node.getText()+" "+node.getContentDescription());
+ //Log.e(TAG,"getViewByDesc node:"+node);
+ if(node.getChildCount() > 0){
+ for(int i = 0 ; i < node.getChildCount() ; i ++){
+ if(node.getChild(i) != null) {
+ AccessibilityNodeInfo nodeInfo = getViewByDesc(node.getChild(i), desc);
+ if(nodeInfo != null){
+ return nodeInfo;
+ }
}
}
+ }else if(node != null && node.getContentDescription() != null && node.getContentDescription().equals(desc)){
+ return node;
}
- }else if(node != null && node.getContentDescription() != null && node.getContentDescription().equals(desc)){
- return node;
- }
+ }catch (Exception e){}
return null;
}
private void printWindow(AccessibilityWindowInfo window, String space){
@@ -205,7 +211,9 @@
@Override
public void onInterrupt() {
+ Log.e(TAG,"onInterrupt 服务停止");
unregisterReceiver(receiver);
+ Toast.makeText(getBaseContext(),"服务停止",Toast.LENGTH_SHORT).show();
}
@Override
protected void onServiceConnected() {
--
Gitblit v1.9.1