From 27f180efca808046df3f3e917ee5f98d2d54849b Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Wed, 04 May 2022 13:57:34 +0000
Subject: [PATCH] 滑动歌词 计算时间
---
app/src/main/java/com/auto/lyric/MainActivity.java | 120 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++---
1 files changed, 114 insertions(+), 6 deletions(-)
diff --git a/app/src/main/java/com/auto/lyric/MainActivity.java b/app/src/main/java/com/auto/lyric/MainActivity.java
index ec4e9ce..121b6f9 100644
--- a/app/src/main/java/com/auto/lyric/MainActivity.java
+++ b/app/src/main/java/com/auto/lyric/MainActivity.java
@@ -1,14 +1,122 @@
package com.auto.lyric;
-import androidx.appcompat.app.AppCompatActivity;
+import android.content.Intent;
+import android.net.Uri;
+import android.os.Build;
+import android.provider.Settings;
+import android.text.TextUtils;
+import android.util.Log;
+import android.widget.Toast;
-import android.os.Bundle;
+import com.auto.lyric.base.activities.BaseActivity;
+import com.auto.lyric.data.LyricServer;
+import com.auto.lyric.data.TextBean;
+import com.auto.lyric.databinding.ActivityMainBinding;
+import com.auto.lyric.service.AutoInputService;
+import com.auto.lyric.service.FloatingWindowService;
+import com.auto.lyric.vm.MainViewModel;
-public class MainActivity extends AppCompatActivity {
+import java.text.ParseException;
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.regex.Pattern;
+
+public class MainActivity extends BaseActivity<ActivityMainBinding, MainViewModel> {
@Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
+ public void initViews() {
+
+ Intent inputService = new Intent(getApplicationContext(), AutoInputService.class);
+
+ Intent floatService = new Intent(getApplicationContext(), FloatingWindowService.class);
+ binding.button.setOnClickListener(v -> {
+
+ if(binding.edit.getText().toString().trim().length() == 0){
+ Toast.makeText(this,"请输入文本", Toast.LENGTH_SHORT).show();
+ return;
+ }
+ ArrayList<TextBean> arrayList = new ArrayList<>();//解析的文本数据
+ SimpleDateFormat msFormat = new SimpleDateFormat("mm:ss.SSS");
+ String[] strings = binding.edit.getText().toString().split("\n");
+ for(String text : strings){
+ int index = text.indexOf("]");
+ if(index < 8 ){
+ continue;
+ }
+ String regex = "(?<=\\])";
+ Pattern compile = Pattern.compile(regex);
+ String[] split = compile.split(text,2);
+ long wait = 0;
+ try {
+ wait = 28800000 + msFormat.parse(split[0].replace("[","").replace("]","")).getTime();
+ } catch (ParseException e) {
+ e.printStackTrace();
+ }
+ arrayList.add(new TextBean(wait,split[1]));
+ }
+ if(arrayList.size() == 0){
+ return;
+ }
+
+ LyricServer.read(Arrays.asList(strings));
+ //申请权限
+ if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
+ //开启悬浮窗
+ if(!Settings.canDrawOverlays(getApplicationContext())) {
+ //启动Activity让用户授权
+ Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION);
+ intent.setData(Uri.parse("package:" + getPackageName()));
+ intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK );
+ startActivity(intent);
+ }else if(!isAccessibilitySettingsOn()){//辅助权限
+ Intent intent = new Intent(Settings.ACTION_ACCESSIBILITY_SETTINGS);
+ intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK );
+ startActivity(intent);
+ }else{//开启监听服务
+ startService(floatService);
+ }
+ }
+ });
}
+
+ public boolean isAccessibilitySettingsOn() {
+ int accessibilityEnabled = 0;
+ final String service = getPackageName() + "/" + AutoInputService.class.getCanonicalName();
+ try {
+ accessibilityEnabled = Settings.Secure.getInt(
+ this.getApplicationContext().getContentResolver(),
+ android.provider.Settings.Secure.ACCESSIBILITY_ENABLED);
+ Log.v(TAG, "accessibilityEnabled = " + accessibilityEnabled);
+ } catch (Settings.SettingNotFoundException e) {
+ Log.e(TAG, "Error finding setting, default accessibility to not found: "
+ + e.getMessage());
+ }
+ TextUtils.SimpleStringSplitter mStringColonSplitter = new TextUtils.SimpleStringSplitter(':');
+
+ if (accessibilityEnabled == 1) {
+ Log.v(TAG, "***ACCESSIBILITY IS ENABLED*** -----------------");
+ String settingValue = Settings.Secure.getString(
+ getApplicationContext().getContentResolver(),
+ Settings.Secure.ENABLED_ACCESSIBILITY_SERVICES);
+ if (settingValue != null) {
+ mStringColonSplitter.setString(settingValue);
+ while (mStringColonSplitter.hasNext()) {
+ String accessibilityService = mStringColonSplitter.next();
+
+ Log.v(TAG, "-------------- > accessibilityService :: " + accessibilityService + " " + service);
+ if (accessibilityService.equalsIgnoreCase(service)) {
+ Log.v(TAG, "We've found the correct setting - accessibility is switched on!");
+ return true;
+ }
+ }
+ }
+ } else {
+ Log.v(TAG, "***ACCESSIBILITY IS DISABLED***");
+ }
+
+ return false;
+ }
+
+
}
\ No newline at end of file
--
Gitblit v1.9.1