From ea6ce17bf3272259295adccbad85583079b5bac0 Mon Sep 17 00:00:00 2001
From: Runt <qingingrunt2010@qq.com>
Date: Wed, 22 Feb 2023 14:14:41 +0000
Subject: [PATCH] api调用
---
app/src/main/java/com/auto/lyric/MainActivity.java | 113 ++++++++++++++++++++++++++++++++++++++------------------
1 files changed, 77 insertions(+), 36 deletions(-)
diff --git a/app/src/main/java/com/auto/lyric/MainActivity.java b/app/src/main/java/com/auto/lyric/MainActivity.java
index 2bee5ac..182d0b5 100644
--- a/app/src/main/java/com/auto/lyric/MainActivity.java
+++ b/app/src/main/java/com/auto/lyric/MainActivity.java
@@ -1,17 +1,17 @@
package com.auto.lyric;
+import android.Manifest;
import android.content.Intent;
import android.net.Uri;
import android.os.Build;
+import android.os.Environment;
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 androidx.appcompat.app.AlertDialog;
+import androidx.activity.result.ActivityResultLauncher;
+import androidx.activity.result.contract.ActivityResultContracts;
import com.auto.lyric.base.activities.BaseActivity;
import com.auto.lyric.data.ActiveResult;
@@ -22,10 +22,11 @@
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.ui.collect.CollectActivity;
import com.auto.lyric.vm.MainViewModel;
import com.google.gson.Gson;
+import java.io.File;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
@@ -34,35 +35,72 @@
import java.util.regex.Pattern;
public class MainActivity extends BaseActivity<ActivityMainBinding, MainViewModel> {
+ SimpleDateFormat dateTimeFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
-
+ UserInfo userInfo;
@Override
public void initViews() {
+ //选择文件
+ ActivityResultLauncher fileLauncher = registerForActivityResult(new ActivityResultContracts.OpenDocument(), result -> {
+ Log.e(TAG,"result:"+result+" "+(result == null?"":result.getPath()));
+ if(result != null && result.getPath().indexOf(".lrc") == result.getPath().length()-4) {
+ Log.e(TAG,"getRootDirectory:"+" "+Environment.getExternalStorageDirectory());
+ String path = Environment.getExternalStorageDirectory()+"/"+result.getPath().split(":")[1];
+
+ viewModel.uploadFile(userInfo.userId,userInfo.activeKey,new File(path));
+ }else{
+ showDialog("文件格式错误", "请选择标准的歌词文件", (dialog, which) -> {
+ dialog.dismiss();
+ });
+ }
+ });
+ //单个权限申请
+ ActivityResultLauncher singlePermission = registerForActivityResult(new ActivityResultContracts.RequestPermission(), result -> {
+ if(result){
+ fileLauncher.launch(new String[]{"*/*"});
+ }else{
+ showDialog("权限申请", "没有文件读取权限", (dialog, which) -> {
+ dialog.dismiss();
+ });
+ }
+ });
Intent floatService = new Intent(getApplicationContext(), FloatingWindowService.class);
+ String deviceInfoStr = getStringProjectPrefrence("deviceInfo");
+ if(TextUtils.isEmpty(deviceInfoStr)){
+ viewModel.registerDevice();
+ }
+ long date = getLongProjectPrefrence("launchDate");
+ if(date == 0 || !dateFormat.format(new Date()).equals(dateFormat.format(new Date(date))) ){
+ viewModel.launchApp();
+ }
String key = getStringProjectPrefrence("activeKey");
- UserInfo result = new Gson().fromJson(key,UserInfo.class);
+ /*userInfo = new Gson().fromJson(key,UserInfo.class);
try {
- if(TextUtils.isEmpty(key) || TextUtils.isEmpty(result.keyDateValid)||
- new Date().getTime() > dateFormat.parse(result.keyDateValid).getTime()){
+ if(TextUtils.isEmpty(key) || TextUtils.isEmpty(userInfo.keyDateValid)||
+ new Date().getTime() > dateTimeFormat.parse(userInfo.keyDateValid).getTime()){
activeDialog();
}else{
- viewModel.checkActive(result.userId,result.activeKey,new LoadingHttpObserver<ActiveResult>(this) {
+ viewModel.checkActive(userInfo.userId,userInfo.activeKey,new LoadingHttpObserver<ActiveResult>(this) {
@Override
public void onError(ActiveResult error) {
super.onError(error);
+ if(error.result.equals("108")){
+ activeDialog();
+ }
}
@Override
public void onComplete(ActiveResult result) {
+ userInfo = result.userInfo;
}
});
}
} catch (ParseException e) {
e.printStackTrace();
- }
-
+ }*/
+ //确认
binding.button.setOnClickListener(v -> {
if(binding.edit.getText().toString().trim().length() == 0){
@@ -108,11 +146,22 @@
startActivity(intent);
}else{//开启监听服务
startService(floatService);
- startService(new Intent(this,AutoInputService.class));
+ //startService(new Intent(this,AutoInputService.class));
}
//startService(floatService);
}
});
+ //收藏
+ binding.collect.setOnClickListener(v -> addCollectDailog(userInfo.userId,userInfo.activeKey,binding.edit.getText().toString()));
+ //清空
+ binding.clear.setOnClickListener(v -> binding.edit.setText(""));
+ //保存本地
+ binding.save.setOnClickListener(v -> {});
+ binding.txtLocal.setOnClickListener(v -> {
+ singlePermission.launch(Manifest.permission.READ_EXTERNAL_STORAGE);//读取文件权限
+ });
+ //收藏夹
+ binding.txtFavorite.setOnClickListener(v -> startActivity(new Intent(mContext, CollectActivity.class)));
}
public boolean isAccessibilitySettingsOn() {
@@ -153,39 +202,31 @@
return false;
}
+ private void addCollectDailog(String userId,String activeKey,String lrc ){
+
+ showInputDialog("收藏歌词","填写歌词名称","收藏","取消",(dialog1,editText, which) -> {
+ viewModel.addToCollect(userId, activeKey, editText.getText().toString(), lrc, new LoadingHttpObserver<ActiveResult>(this) {
+ @Override
+ public void onComplete(ActiveResult error) {
+
+ }
+ });
+ },(dialog1,editText, which) -> {});
+ }
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) -> {
+ showInputDialog("软件尚未激活或已过期", "请输入激活码", "激活", "退出程序", (dialog1,editText, 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) {
+ dialog1.dismiss();
+ userInfo = result.userInfo;
putStringProjectPrefrence("activeKey",new Gson().toJson(result.userInfo));
}
});
- });
- dialg.setButton(AlertDialog.BUTTON_POSITIVE,"退出程序",(dialog,which) ->{
+ }, (dialog1,editText, which) -> {
System.exit(0);
});
- dialg.show();
}
}
\ No newline at end of file
--
Gitblit v1.9.1