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/MainActivity.java | 2
app/src/main/java/com/auto/lyric/service/FloatingWindowService.java | 103 ++++++++++++++++-----------------
app/src/main/java/com/auto/lyric/service/AutoInputService.java | 34 ++++++-----
3 files changed, 70 insertions(+), 69 deletions(-)
diff --git a/app/src/main/java/com/auto/lyric/MainActivity.java b/app/src/main/java/com/auto/lyric/MainActivity.java
index ece5151..90e69f3 100644
--- a/app/src/main/java/com/auto/lyric/MainActivity.java
+++ b/app/src/main/java/com/auto/lyric/MainActivity.java
@@ -136,7 +136,7 @@
startActivity(intent);
}else{//开启监听服务
startService(floatService);
- startService(new Intent(this,AutoInputService.class));
+ //startService(new Intent(this,AutoInputService.class));
}
//startService(floatService);
}
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) {
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 f6056fd..865ebe0 100644
--- a/app/src/main/java/com/auto/lyric/service/FloatingWindowService.java
+++ b/app/src/main/java/com/auto/lyric/service/FloatingWindowService.java
@@ -7,9 +7,9 @@
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.Looper;
import android.os.Message;
import android.util.Log;
import android.view.Gravity;
@@ -27,6 +27,7 @@
import com.auto.lyric.databinding.FloatViewBinding;
import com.auto.lyric.util.DeviceUtil;
+import java.lang.ref.WeakReference;
import java.text.SimpleDateFormat;
import java.util.Timer;
import java.util.TimerTask;
@@ -41,23 +42,21 @@
private WindowManager.LayoutParams params;
FloatViewBinding binding;
final String TAG = "FloatingWindowService";
- final int THREAD_STOP = 0, KEYBOARD_SEND = 100;
+ final int THREAD_STOP = 99, KEYBOARD_SEND = 100;
SimpleDateFormat msFormat = new SimpleDateFormat("mm:ss.SSS");
boolean pause;//是否暂停
int progress;//时间进度
LyricObject lyricObject;//当前发送过的歌词
- Handler handler;
+ MyHandler handler ;
//计时器
- Timer timer;
- CountDownTimer countDownTimer;
- ServiceTask task;//计时器执行任务
+ Timer timer = new Timer();
+ //计时器执行任务
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.sendMessage(new Message());
if(lyricObject == null || lyricObject != LyricServer.getLrc_map().get(index)){
lyricObject = LyricServer.getLrc_map().get(index);
Message message = new Message();
@@ -138,6 +137,7 @@
stop();
}
});
+ handler = new MyHandler(Looper.getMainLooper(),this);
}
@Nullable
@@ -146,28 +146,6 @@
return null;
}
- private void initHandler(){
- handler = new Handler(){
- @Override
- public void handleMessage(@NonNull Message msg) {
- super.handleMessage(msg);
- if(msg.what == THREAD_STOP){//停止
- stop();
- }else if(msg.what == KEYBOARD_SEND){//发送文本
- copy(msg.obj.toString());
- Intent intent = new Intent();
- intent.setAction(AutoInputService.class.getName());
- intent.putExtra("action",AutoInputService.ACTION_PASTE);
- sendBroadcast(intent);
- intent.putExtra("action",AutoInputService.ACTION_SEND);
- sendBroadcast(intent);
- }else if(msg.what == -1){//显示在输入框中
-
- //Toast.makeText(getBaseContext(),"上一句--"+msg.obj,Toast.LENGTH_SHORT).show();
- }
- }
- };
- }
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
@@ -176,7 +154,6 @@
manager.addView(binding.getRoot(), params);
}
binding.lyric.setTextSize();
- initHandler();
stop();
progress = LyricServer.getLrc_map().get(0).begintime;
binding.timer.setText(msFormat.format(progress));
@@ -194,18 +171,18 @@
case MotionEvent.ACTION_MOVE:
touchY=tt-touchY;
binding.lyric.setOffsetY(binding.lyric.getOffsetY()+touchY);
- Log.e("LyricView","offsety:"+binding.lyric.getOffsetY());
+ //Log.e("LyricView","offsety:"+binding.lyric.getOffsetY());
binding.lyric.invalidate();
break;
case MotionEvent.ACTION_UP:
if(binding.btnStart.getText().equals("开启") || pause) {
int index = binding.lyric.getIndexFromOffsetY(binding.lyric.getOffsetY());
LyricObject lyricObject = LyricServer.getLrc_map().get(index);
- Log.e("LyricView", "index:"+index+" object:" + lyricObject);
+ //Log.e("LyricView", "index:"+index+" object:" + lyricObject);
if(lyricObject != null) {
binding.lyric.setIndex(index);
binding.lyric.setOffsetY(220 - index * (binding.lyric.getSIZEWORD() + 44));
- Log.e("LyricView", "object:" + lyricObject);
+ //Log.e("LyricView", "object:" + lyricObject);
progress = lyricObject.begintime;
binding.timer.setText(msFormat.format(progress));
}
@@ -226,9 +203,9 @@
Log.e(TAG,"onDestroy ");
try {
timer.cancel();
- countDownTimer.cancel();
}catch (Exception e){}
AutoInputService.flag = false;
+ pause = true;
manager.removeView(binding.getRoot());
}
@@ -237,37 +214,25 @@
*/
private void start(){
AutoInputService.flag = true;
+ pause = false;
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);
+ timer.schedule(new ServiceTask(),0,10);
binding.btnStart.setText("停止");
binding.btnPause.setText("暂停");
binding.btnBack.setEnabled(true);
binding.btnFast.setEnabled(true);
binding.btnPause.setEnabled(true);
- pause = false;
+ Intent intent = new Intent();
+ intent.setAction(AutoInputService.class.getName());
+ intent.putExtra("action",AutoInputService.ACTION_START);
+ sendBroadcast(intent);
}
private void pause(){
try {
timer.cancel();
- countDownTimer.cancel();
}catch (Exception e){}
pause = true;
AutoInputService.flag = false;
@@ -294,5 +259,37 @@
clipboard.setPrimaryClip(clipData);
}
+ class MyHandler extends Handler{
+
+ private final WeakReference<FloatingWindowService> weakReference;
+
+ MyHandler(Looper looper,FloatingWindowService service) {
+ super(looper);
+ this.weakReference = new WeakReference<>(service);
+ }
+
+ @Override
+ public void handleMessage(@NonNull Message msg) {
+ super.handleMessage(msg);
+ if(msg.what == THREAD_STOP){//停止
+ stop();
+ }else if(msg.what == KEYBOARD_SEND){//发送文本
+ copy(msg.obj.toString());
+ Intent intent = new Intent();
+ intent.setAction(AutoInputService.class.getName());
+ intent.putExtra("action",AutoInputService.ACTION_PASTE);
+ sendBroadcast(intent);
+ intent.putExtra("action",AutoInputService.ACTION_SEND);
+ sendBroadcast(intent);
+ }else if(msg.what == -1){//显示在输入框中
+
+ //Toast.makeText(getBaseContext(),"上一句--"+msg.obj,Toast.LENGTH_SHORT).show();
+ }
+ int index = binding.lyric.getIndex(progress);
+ binding.lyric.setOffsetY(220 - index * (binding.lyric.getSIZEWORD() + 44));
+ binding.lyric.invalidate();
+ weakReference.get().binding.timer.setText(msFormat.format(progress));
+ }
+ }
}
--
Gitblit v1.9.1