From 75360a9fa2fcead8b516467d982c5cdf82c63263 Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Sun, 15 May 2022 06:44:38 +0000
Subject: [PATCH] 歌词解析 修复及优化 handler 阻塞问题优化

---
 app/src/main/java/com/auto/lyric/data/LyricServer.java              |   32 +++++-----
 app/src/main/java/com/auto/lyric/service/FloatingWindowService.java |   73 ++++++++++++++++++------
 app/src/main/java/com/auto/lyric/service/AutoInputService.java      |   32 ++++++----
 3 files changed, 87 insertions(+), 50 deletions(-)

diff --git a/app/src/main/java/com/auto/lyric/data/LyricServer.java b/app/src/main/java/com/auto/lyric/data/LyricServer.java
index 2741d2c..7b47db2 100644
--- a/app/src/main/java/com/auto/lyric/data/LyricServer.java
+++ b/app/src/main/java/com/auto/lyric/data/LyricServer.java
@@ -6,7 +6,6 @@
 import java.io.FileNotFoundException;
 import java.io.IOException;
 import java.io.InputStreamReader;
-import java.util.Iterator;
 import java.util.List;
 import java.util.TreeMap;
 import java.util.regex.Matcher;
@@ -69,18 +68,22 @@
         // System.out.println("++++++++++++>>"+data);
         /*text = text.replace("[","");//将前面的替换成后面的
         text = text.replace("]","@");
-        String splitdata[] = text.split("@");//分隔*/
+        String splitdata[] = text.split("@");//分隔
         String regex = "(?<=\\])";
         Pattern compile = Pattern.compile(regex);
-        String[] splitdata = compile.split(text,2);//分隔
-        if(text.endsWith("]") || splitdata.length == 1){
-
-            String str = text;
-            str = str.replace("[","");
-            str = str.replace("]","");
-            str = str.replace(":",".");
-            str = str.replace(".","@");
-            String timedata[] =str.split("@");
+        String[] splitdata = compile.split(text,2);//分隔*/
+        int index = text.indexOf("]");
+        String[] splitdata;
+        if(text.length()-1 == index){
+            splitdata = new String[]{text};
+        }else{
+            splitdata = new String[]{text.substring(0,index),text.substring(index+1)};
+        }
+        String tmpstr = splitdata[0].replace("[","").replace("]","");
+        if(splitdata.length == 1){
+            tmpstr = tmpstr.replace(":",".");
+            tmpstr = tmpstr.replace(".","@");
+            String timedata[] =tmpstr.split("@");
             Matcher matcher = pattern.matcher(timedata[0]);
             if(timedata.length==3 && matcher.matches()){
                 int m = Integer.parseInt(timedata[0]);  //分
@@ -94,9 +97,6 @@
             }
         } else{
             String lrcContenet = splitdata[1];
-            String tmpstr = splitdata[0];
-            tmpstr = tmpstr.replace("[","");
-            tmpstr = tmpstr.replace("]","");
             tmpstr = tmpstr.replace(":",".");
             tmpstr = tmpstr.replace(".","@");
             String timedata[] =tmpstr.split("@");
@@ -119,7 +119,6 @@
      */
     private static void initLrc(TreeMap<Integer, LyricObject> lrc_read){
         lrc_map.clear();
-        Iterator<Integer> iterator = lrc_read.keySet().iterator();
         LyricObject oldval  = null;
         int i =0;
         for(Integer key : lrc_read.keySet()){
@@ -127,8 +126,7 @@
             if (oldval == null) {
                 oldval = val;
             } else {
-                LyricObject item1= new LyricObject();
-                item1  = oldval;
+                LyricObject item1 = oldval;
                 item1.timeline = val.begintime-oldval.begintime;
                 lrc_map.put(new Integer(i), item1);
                 i++;
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 c68f2c6..9e90755 100644
--- a/app/src/main/java/com/auto/lyric/service/AutoInputService.java
+++ b/app/src/main/java/com/auto/lyric/service/AutoInputService.java
@@ -129,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")
@@ -176,8 +178,8 @@
     @SuppressLint("NewApi")
     private AccessibilityNodeInfo getViewByDesc(AccessibilityNodeInfo node, String desc){
         try{
-            Log.e(TAG,desc +" getViewByDesc id:"+node.getViewIdResourceName() +" class:"+node.getClassName()+" text:"+node.getText()+" "+node.getContentDescription());
-            Log.e(TAG,"getViewByDesc  node:"+node);
+            //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) {
@@ -209,7 +211,9 @@
 
     @Override
     public void onInterrupt() {
+        Log.e(TAG,"onInterrupt 服务停止");
         unregisterReceiver(receiver);
+        Toast.makeText(getBaseContext(),"服务停止",Toast.LENGTH_SHORT).show();
     }
     @Override
     protected void onServiceConnected() {
diff --git a/app/src/main/java/com/auto/lyric/service/FloatingWindowService.java b/app/src/main/java/com/auto/lyric/service/FloatingWindowService.java
index 122af61..b194d21 100644
--- a/app/src/main/java/com/auto/lyric/service/FloatingWindowService.java
+++ b/app/src/main/java/com/auto/lyric/service/FloatingWindowService.java
@@ -7,6 +7,7 @@
 import android.content.Intent;
 import android.graphics.PixelFormat;
 import android.os.Build;
+import android.os.CountDownTimer;
 import android.os.Handler;
 import android.os.IBinder;
 import android.os.Message;
@@ -43,7 +44,7 @@
     private WindowManager.LayoutParams params;
     FloatViewBinding binding;
     final String TAG = "FloatingWindowService";
-    final int THREAD_STOP = 0, KEYBOARD_SEND = 100,UPDATE_TIME = 200;
+    final int THREAD_STOP = 0, KEYBOARD_SEND = 100;
     SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
     SimpleDateFormat msFormat = new SimpleDateFormat("mm:ss.SSS");
     boolean pause;//是否暂停
@@ -51,24 +52,30 @@
     LyricObject lyricObject;//当前发送过的歌词
     Handler handler;
 
+    //计时器
     Timer timer;
-    ServiceTask task;
+    CountDownTimer countDownTimer;
+    ServiceTask task;//计时器执行任务
     class ServiceTask extends TimerTask{
         @Override
         public void run() {
             int index = binding.lyric.getIndex(progress+=10);
             binding.lyric.setOffsetY(220 - index * (binding.lyric.getSIZEWORD() + 44));
             binding.lyric.invalidate();
-            handler.sendEmptyMessage(UPDATE_TIME);
             if(lyricObject == null || lyricObject != LyricServer.getLrc_map().get(index)){
                 lyricObject = LyricServer.getLrc_map().get(index);
                 Message message = new Message();
                 message.what = KEYBOARD_SEND;
                 message.obj = lyricObject.lrc;
-                handler.sendMessage(message);
+                boolean flag = handler.sendMessage(message);
+                Log.e(TAG,"sendmessge "+message.obj +" 发送成功:"+flag);
             }
+            //停止
             if(index == LyricServer.getLrc_map().size()-1){
-                handler.sendEmptyMessage(THREAD_STOP);
+                Message stop = new Message();
+                stop.what = THREAD_STOP;
+                boolean flag = handler.sendMessage(stop);
+                Log.e(TAG,"sendEmptyMessage THREAD_STOP 发送成功:"+flag);
             }
         }
     };
@@ -94,11 +101,9 @@
         params.width = WindowManager.LayoutParams.MATCH_PARENT;
         params.height = DeviceUtil.convertDpToPixel(200,getBaseContext());
         binding.close.setOnClickListener(v ->{
-            stopService(new Intent(this,this.getClass()));
+            stopService(new Intent(this,FloatingWindowService.class));
             stopService(new Intent(this,AutoInputService.class));
         });
-        progress = LyricServer.getLrc_map().get(0).begintime;
-        binding.timer.setText(msFormat.format(progress));
         binding.floating.setOnTouchListener(new View.OnTouchListener() {
             int startY;
             @Override
@@ -142,12 +147,9 @@
             if(binding.btnStart.getText().equals("开启")){
                 start();
             }else{
-                pause();
-                binding.btnStart.setText("开启");
-                binding.btnPause.setEnabled(false);
+                stop();
             }
         });
-        initHandler();
     }
 
     @Nullable
@@ -157,12 +159,12 @@
     }
 
     private void initHandler(){
-        handler = new Handler(this.getMainLooper()){
+        handler = new Handler(){
             @Override
             public void handleMessage(@NonNull Message msg) {
                 super.handleMessage(msg);
                 if(msg.what == THREAD_STOP){//停止
-                    binding.btnStart.performClick();
+                    stop();
                 }else if(msg.what == KEYBOARD_SEND){//发送文本
                     copy(msg.obj.toString());
                     Intent intent = new Intent();
@@ -174,8 +176,6 @@
                 }else if(msg.what == -1){//显示在输入框中
 
                     //Toast.makeText(getBaseContext(),"上一句--"+msg.obj,Toast.LENGTH_SHORT).show();
-                }else if(msg.what == UPDATE_TIME){
-                    binding.timer.setText(msFormat.format(progress));
                 }
             }
         };
@@ -184,8 +184,17 @@
     @Override
     public int onStartCommand(Intent intent, int flags, int startId) {
         Log.e(TAG,"onStartCommand flags:"+flags+" startId:"+startId+ " intent:"+intent);
-        manager.addView(binding.getRoot(),params);
+        if(binding.getRoot().getParent() == null) {
+            manager.addView(binding.getRoot(), params);
+        }
         binding.lyric.setTextSize();
+        initHandler();
+        stop();
+        progress = LyricServer.getLrc_map().get(0).begintime;
+        binding.timer.setText(msFormat.format(progress));
+        int index = binding.lyric.getIndex(progress);
+        binding.lyric.setOffsetY(220 - index * (binding.lyric.getSIZEWORD() + 44));
+        binding.lyric.invalidate();
         binding.lyric.setOnTouchListener(new View.OnTouchListener() {
             float touchY; //当触摸歌词View时,保存为当前触点的Y轴坐标
             @Override
@@ -227,7 +236,10 @@
     public void onDestroy() {
         super.onDestroy();
         Log.e(TAG,"onDestroy ");
-        timer.cancel();
+        try {
+            timer.cancel();
+            countDownTimer.cancel();
+        }catch (Exception e){}
         AutoInputService.flag = false;
         manager.removeView(binding.getRoot());
     }
@@ -239,7 +251,20 @@
         AutoInputService.flag = true;
         try {
             timer.cancel();
+            countDownTimer.cancel();
         }catch (Exception e){}
+        countDownTimer = new CountDownTimer(LyricServer.getLrc_map().get(LyricServer.getLrc_map().keySet().size()-1).begintime,10) {
+            @Override
+            public void onTick(long millisUntilFinished) {
+                binding.timer.setText(msFormat.format(progress));
+            }
+
+            @Override
+            public void onFinish() {
+
+            }
+        };
+        countDownTimer.start();
         timer = new Timer();
         task = new ServiceTask();
         timer.schedule(task,0,10);
@@ -252,7 +277,10 @@
     }
 
     private void pause(){
-        timer.cancel();
+        try {
+            timer.cancel();
+            countDownTimer.cancel();
+        }catch (Exception e){}
         pause = true;
         AutoInputService.flag = false;
         binding.btnBack.setEnabled(false);
@@ -260,9 +288,16 @@
         binding.btnPause.setText("继续");
     }
 
+    private void stop(){
+        pause();
+        binding.btnStart.setText("开启");
+        binding.btnPause.setEnabled(false);
+    }
+
 
     //复制
     private void copy(String data) {
+        Log.e(TAG,"copy "+data);
         // 获取系统剪贴板
         ClipboardManager clipboard = (ClipboardManager) getSystemService(Context.CLIPBOARD_SERVICE);
         // 创建一个剪贴数据集,包含一个普通文本数据条目(需要复制的数据),其他的还有

--
Gitblit v1.9.1