From 55a5784c2d3f2f8a69c670294a64e65debaf4c53 Mon Sep 17 00:00:00 2001 From: Runt <qingingrunt2010@qq.com> Date: Fri, 03 Jun 2022 14:38:14 +0000 Subject: [PATCH] 注册 --- app/src/main/java/com/auto/lyric/MainActivity.java | 189 +++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 183 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..2bee5ac 100644 --- a/app/src/main/java/com/auto/lyric/MainActivity.java +++ b/app/src/main/java/com/auto/lyric/MainActivity.java @@ -1,14 +1,191 @@ 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.data.UserInfo; +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"); + UserInfo result = new Gson().fromJson(key,UserInfo.class); + try { + if(TextUtils.isEmpty(key) || TextUtils.isEmpty(result.keyDateValid)|| + new Date().getTime() > dateFormat.parse(result.keyDateValid).getTime()){ + activeDialog(); + }else{ + + viewModel.checkActive(result.userId,result.activeKey,new LoadingHttpObserver<ActiveResult>(this) { + + @Override + public void onError(ActiveResult error) { + super.onError(error); + } + + @Override + public void onComplete(ActiveResult result) { + } + }); + } + } 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; + } + + + private void activeDialog(){ + 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.register(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) { + putStringProjectPrefrence("activeKey",new Gson().toJson(result.userInfo)); + } + }); + }); + dialg.setButton(AlertDialog.BUTTON_POSITIVE,"退出程序",(dialog,which) ->{ + System.exit(0); + }); + dialg.show(); + } + } \ No newline at end of file -- Gitblit v1.9.1