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 |   58 +++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 53 insertions(+), 5 deletions(-)

diff --git a/app/src/main/java/com/auto/lyric/MainActivity.java b/app/src/main/java/com/auto/lyric/MainActivity.java
index 8bed626..182d0b5 100644
--- a/app/src/main/java/com/auto/lyric/MainActivity.java
+++ b/app/src/main/java/com/auto/lyric/MainActivity.java
@@ -1,12 +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.widget.Toast;
+
+import androidx.activity.result.ActivityResultLauncher;
+import androidx.activity.result.contract.ActivityResultContracts;
 
 import com.auto.lyric.base.activities.BaseActivity;
 import com.auto.lyric.data.ActiveResult;
@@ -21,6 +26,7 @@
 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;
@@ -29,16 +35,49 @@
 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 = new Gson().fromJson(key,UserInfo.class);
+        /*userInfo = new Gson().fromJson(key,UserInfo.class);
         try {
             if(TextUtils.isEmpty(key) || TextUtils.isEmpty(userInfo.keyDateValid)||
-                    new Date().getTime() > dateFormat.parse(userInfo.keyDateValid).getTime()){
+                    new Date().getTime() > dateTimeFormat.parse(userInfo.keyDateValid).getTime()){
                 activeDialog();
             }else{
 
@@ -60,8 +99,8 @@
             }
         } catch (ParseException e) {
             e.printStackTrace();
-        }
-
+        }*/
+        //确认
         binding.button.setOnClickListener(v -> {
 
             if(binding.edit.getText().toString().trim().length() == 0){
@@ -107,12 +146,21 @@
                     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)));
     }
 

--
Gitblit v1.9.1