From c7530f1a595883f815b9689dbd3a8159e8d6bd30 Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Sat, 31 Dec 2022 01:14:21 +0000
Subject: [PATCH] UI线程阻塞问题修复

---
 app/src/main/java/com/auto/lyric/service/AutoInputService.java |   34 +++++++++++++++++++---------------
 1 files changed, 19 insertions(+), 15 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 9e90755..ca83317 100644
--- a/app/src/main/java/com/auto/lyric/service/AutoInputService.java
+++ b/app/src/main/java/com/auto/lyric/service/AutoInputService.java
@@ -23,7 +23,8 @@
 public class AutoInputService extends AccessibilityService {
     final String TAG = "AutoInputService";
     public static final int ACTION_SEND = 1001,//发送
-            ACTION_PASTE = 1002;//粘贴
+            ACTION_PASTE = 1002,//粘贴
+            ACTION_START = 1000;//开始
 
     BroadcastReceiver receiver = new BroadcastReceiver() {
         @Override
@@ -57,9 +58,12 @@
                             Toast.makeText(getBaseContext(),"未找到控件",Toast.LENGTH_SHORT).show();
                         }
                     }catch (Exception e){
-                        e.printStackTrace();
+                        //e.printStackTrace();
                     }
 
+                    break;
+                case ACTION_START:
+                    clickEdit();
                     break;
             }
         }
@@ -70,25 +74,25 @@
     @Override
     public void onAccessibilityEvent(AccessibilityEvent event) {
         int eventType = event.getEventType();
-        Log.d(TAG," text:" + event.getText()+" class:"+event.getClassName() +" action:" + event.getAction() +" windowId:"+ event.getWindowId());
-        Log.d(TAG,"event:"+event );
-        Log.d(TAG,"ParcelableData:"+event.getParcelableData()  );
+        //Log.d(TAG," text:" + event.getText()+" class:"+event.getClassName() +" action:" + event.getAction() +" windowId:"+ event.getWindowId());
+        //Log.d(TAG,"event:"+event );
+        //Log.d(TAG,"ParcelableData:"+event.getParcelableData()  );
         AccessibilityNodeInfo nodeInfo = getRootInActiveWindow();
         AccessibilityNodeInfo source = event.getSource();//当前界面的可访问节点信息
         if(source != null){
             //printView(source,"source == ");
         }
-        Log.d(TAG,"source:"+(source == null? null : source.getClassName())  );
-        Log.d(TAG,"nodeInfo:"+ (nodeInfo == null? null : nodeInfo.getClassName()) );
+        //Log.d(TAG,"source:"+(source == null? null : source.getClassName())  );
+        //Log.d(TAG,"nodeInfo:"+ (nodeInfo == null? null : nodeInfo.getClassName()) );
         switch (eventType) {
             case AccessibilityEvent.TYPE_WINDOW_CONTENT_CHANGED://界面变化事件
-                Log.e(TAG, "TYPE_WINDOW_CONTENT_CHANGED " );
+                //Log.e(TAG, "TYPE_WINDOW_CONTENT_CHANGED " );
                 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 " );
+                //Log.e(TAG, "TYPE_WINDOW_STATE_CHANGED " );
                 if(source != null && event.getClassName().toString().equals("com.ss.android.ugc.aweme.live.LivePlayActivity") && flag){
                     clickEdit();
                 }
@@ -100,17 +104,17 @@
                 }
                 break;
             case AccessibilityEvent.TYPE_VIEW_FOCUSED://焦点变更
-                Log.e(TAG, "TYPE_VIEW_FOCUSED ResourceName:" +( source == null ? null : source.getParent()));
+                //Log.e(TAG, "TYPE_VIEW_FOCUSED ResourceName:" +( source == null ? null : source.getParent()));
                 if(event.getClassName().equals("android.widget.EditText") && source != null){
                     //source.performAction(AccessibilityNodeInfo.ACTION_LONG_CLICK);
                     //source.performAction(AccessibilityNodeInfo.ACTION_PASTE);//粘贴
                 }
                 break;
             case AccessibilityEvent.TYPE_VIEW_LONG_CLICKED:
-                Log.e(TAG, "TYPE_VIEW_LONG_CLICKED ResourceName:" +( source == null ? null : source.getParent()));
+                //Log.e(TAG, "TYPE_VIEW_LONG_CLICKED ResourceName:" +( source == null ? null : source.getParent()));
                 break;
             case AccessibilityEvent.TYPE_VIEW_CLICKED:
-                Log.e(TAG, "TYPE_VIEW_CLICKED " );
+                //Log.e(TAG, "TYPE_VIEW_CLICKED " );
                 if(nodeInfo != null) {
                     Log.e(TAG, "TYPE_VIEW_CLICKED source:" + nodeInfo.getText() + " " + nodeInfo.getClass());
                 }
@@ -119,7 +123,7 @@
                 break;
             case AccessibilityEvent.TYPE_VIEW_TEXT_CHANGED:
                 //界面文字改动
-                Log.e(TAG, "TYPE_VIEW_TEXT_CHANGED " );
+                //Log.e(TAG, "TYPE_VIEW_TEXT_CHANGED " );
                 break;
         }
 
@@ -148,7 +152,7 @@
 
     @SuppressLint("NewApi")
     private void printView(AccessibilityNodeInfo node, String space){
-        Log.e(TAG,space +node+" id:"+node.getViewIdResourceName() +" class:"+node.getClassName()+" text:"+node.getText()+" "+node.getPaneTitle());
+        //Log.e(TAG,space +node+" id:"+node.getViewIdResourceName() +" class:"+node.getClassName()+" text:"+node.getText()+" "+node.getPaneTitle());
         if(node.getChildCount() > 0){
             for(int i = 0 ; i < node.getChildCount() ; i ++){
                 if(node.getChild(i) != null) {
@@ -159,7 +163,7 @@
     }
     @SuppressLint("NewApi")
     private AccessibilityNodeInfo getView(AccessibilityNodeInfo node, String className){
-        Log.e(TAG,className +" id:"+node.getViewIdResourceName() +" class:"+node.getClassName()+" text:"+node.getText()+" "+node.getPaneTitle());
+        //Log.e(TAG,className +" id:"+node.getViewIdResourceName() +" class:"+node.getClassName()+" text:"+node.getText()+" "+node.getPaneTitle());
         if(node.getChildCount() > 0){
             for(int i = 0 ; i < node.getChildCount() ; i ++){
                 if(node.getChild(i) != null) {

--
Gitblit v1.9.1