From 549a487148522fa4a459967cd6546e22a315ae52 Mon Sep 17 00:00:00 2001 From: Runt <qingingrunt2010@qq.com> Date: Mon, 26 Dec 2022 15:17:52 +0000 Subject: [PATCH] 上传歌词 --- app/src/main/java/com/auto/lyric/MainActivity.java | 103 +++++++++++++++++++++++++++++++++------------------ 1 files changed, 67 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..ece5151 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,47 +22,75 @@ 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; 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"); - + 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 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() > dateFormat.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){ @@ -113,6 +141,17 @@ //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 +192,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