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