From e407dd1f335aa9c716b89b3152bf363b898d28fa Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Sun, 29 May 2022 11:29:56 +0000
Subject: [PATCH] 接口请求框架 注册接口
---
app/src/main/java/com/auto/lyric/MainActivity.java | 171 +++++++++++++++++++++++++++++++++++++++++++++++++++++++--
1 files changed, 165 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..fa1f3cf 100644
--- a/app/src/main/java/com/auto/lyric/MainActivity.java
+++ b/app/src/main/java/com/auto/lyric/MainActivity.java
@@ -1,14 +1,173 @@
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.view.ViewGroup;
+import android.widget.EditText;
+import android.widget.LinearLayout;
+import android.widget.Toast;
-import android.os.Bundle;
+import androidx.appcompat.app.AlertDialog;
-public class MainActivity extends AppCompatActivity {
+import com.auto.lyric.base.activities.BaseActivity;
+import com.auto.lyric.data.ActiveResult;
+import com.auto.lyric.data.LyricServer;
+import com.auto.lyric.data.TextBean;
+import com.auto.lyric.databinding.ActivityMainBinding;
+import com.auto.lyric.retrofit.observable.LoadingHttpObserver;
+import com.auto.lyric.service.AutoInputService;
+import com.auto.lyric.service.FloatingWindowService;
+import com.auto.lyric.util.DeviceUtil;
+import com.auto.lyric.vm.MainViewModel;
+import com.google.gson.Gson;
+
+import java.text.ParseException;
+import java.text.SimpleDateFormat;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Date;
+import java.util.regex.Pattern;
+
+public class MainActivity extends BaseActivity<ActivityMainBinding, MainViewModel> {
+ SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
@Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
+ public void initViews() {
+ Intent floatService = new Intent(getApplicationContext(), FloatingWindowService.class);
+ String key = getStringProjectPrefrence("activeKey");
+ ActiveResult result = new Gson().fromJson(key,ActiveResult.class);
+ try {
+ if(TextUtils.isEmpty(key) || TextUtils.isEmpty(result.validDate)||
+ new Date().getTime() > dateFormat.parse(result.validDate).getTime()){
+ AlertDialog.Builder builder = new AlertDialog.Builder(this);
+ builder.setTitle("软件尚未激活或已过期");
+ EditText editText = new EditText(this);
+ editText.setHint("请输入激活码");
+ ViewGroup.MarginLayoutParams params = new ViewGroup.MarginLayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
+ params.setMargins(DeviceUtil.convertDpToPixel(30,this),DeviceUtil.convertDpToPixel(20,this),DeviceUtil.convertDpToPixel(30,this),0);
+ editText.setLayoutParams(params);
+ LinearLayout lin = new LinearLayout(this);
+ lin.addView(editText);
+ builder.setView(lin);
+ builder.setCancelable(false);
+ AlertDialog dialg = builder.create();
+ dialg.setButton(AlertDialog.BUTTON_NEGATIVE,"激活", (dialog, which) -> {
+ viewModel.checkActive(editText.getText().toString().trim(),new LoadingHttpObserver<ActiveResult>(this) {
+
+ @Override
+ public void onError(ActiveResult error) {
+ super.onError(error);
+ dialg.show();
+ }
+
+ @Override
+ public void onComplete(ActiveResult result) {
+
+ }
+ });
+ });
+ dialg.setButton(AlertDialog.BUTTON_POSITIVE,"退出程序",(dialog,which) ->{
+ System.exit(0);
+ });
+ dialg.show();
+ }
+ } catch (ParseException e) {
+ e.printStackTrace();
+ }
+
+ 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);
+ startService(new Intent(this,AutoInputService.class));
+ }
+ //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