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