Fix lyrics loading

This commit is contained in:
h4h13 2019-12-20 00:56:06 +05:30
parent 598364b8e0
commit 1e2be0a69f
4 changed files with 56 additions and 94 deletions

View file

@ -144,37 +144,31 @@ class LyricsActivity : AbsMusicServiceActivity(), View.OnClickListener, ViewPage
private fun showSyncedLyrics() { private fun showSyncedLyrics() {
var content = "" var content = ""
try {
content = LyricUtil.getStringFromFile(song.data, song.artistName)
} catch (e: Exception) {
try { try {
content = LyricUtil.getStringFromFile(song.title, song.artistName) content = LyricUtil.getStringFromFile(song.title, song.artistName)
} catch (e2: Exception) { } catch (e: Exception) {
}
e.printStackTrace() e.printStackTrace()
} }
val materialDialog = MaterialDialog( val materialDialog = MaterialDialog(this, BottomSheet(LayoutMode.WRAP_CONTENT))
this, BottomSheet(LayoutMode.WRAP_CONTENT) .show {
).show { cornerRadius(PreferenceUtil.getInstance(this@LyricsActivity).dialogCorner)
title(R.string.add_time_framed_lryics) title(R.string.add_time_framed_lryics)
negativeButton(R.string.action_search) { negativeButton(R.string.action_search) {
RetroUtil.openUrl( RetroUtil.openUrl(this@LyricsActivity, googleSearchLrcUrl)
this@LyricsActivity, googleSearchLrcUrl
)
} }
input( input(
hint = getString(R.string.paste_lyrics_here), hint = getString(R.string.paste_lyrics_here),
prefill = content, prefill = content,
inputType = InputType.TYPE_CLASS_TEXT or InputType.TYPE_TEXT_FLAG_MULTI_LINE inputType = InputType.TYPE_CLASS_TEXT or InputType.TYPE_TEXT_FLAG_MULTI_LINE
) { _, input -> ) { _, input ->
LyricUtil.writeLrcToLoc(song.data, song.artistName, input.toString()) LyricUtil.writeLrcToLoc(song.title, song.artistName, input.toString())
} }
positiveButton(android.R.string.ok) { positiveButton(android.R.string.ok) {
updateSong() updateSong()
} }
} }
MaterialUtil.setTint(materialDialog.getInputLayout(), false) MaterialUtil.setTint(materialDialog.getInputLayout(), false)
} }
@ -195,11 +189,10 @@ class LyricsActivity : AbsMusicServiceActivity(), View.OnClickListener, ViewPage
val materialDialog = MaterialDialog( val materialDialog = MaterialDialog(
this, BottomSheet(LayoutMode.WRAP_CONTENT) this, BottomSheet(LayoutMode.WRAP_CONTENT)
).show { ).show {
cornerRadius(PreferenceUtil.getInstance(this@LyricsActivity).dialogCorner)
title(R.string.add_lyrics) title(R.string.add_lyrics)
negativeButton(R.string.action_search) { negativeButton(R.string.action_search) {
RetroUtil.openUrl( RetroUtil.openUrl(this@LyricsActivity, getGoogleSearchUrl())
this@LyricsActivity, getGoogleSearchUrl()
)
} }
input( input(
hint = getString(R.string.paste_lyrics_here), hint = getString(R.string.paste_lyrics_here),
@ -396,14 +389,10 @@ class LyricsActivity : AbsMusicServiceActivity(), View.OnClickListener, ViewPage
private fun loadLRCLyrics() { private fun loadLRCLyrics() {
val song = MusicPlayerRemote.currentSong val song = MusicPlayerRemote.currentSong
if (LyricUtil.isLrcFile2Exist(song.data, song.artistName)) {
showLyricsLocal(LyricUtil.getLocalLyricFile(song.data, song.artistName))
} else {
if (LyricUtil.isLrcFileExist(song.title, song.artistName)) { if (LyricUtil.isLrcFileExist(song.title, song.artistName)) {
showLyricsLocal(LyricUtil.getLocalLyricFile(song.title, song.artistName)) showLyricsLocal(LyricUtil.getLocalLyricFile(song.title, song.artistName))
} }
} }
}
private fun showLyricsLocal(file: File?) { private fun showLyricsLocal(file: File?) {
if (file != null) { if (file != null) {

View file

@ -213,7 +213,7 @@ abstract class AbsPlayerFragment : AbsMusicServiceFragment(),
override fun doInBackground(vararg params: Song): Lyrics? { override fun doInBackground(vararg params: Song): Lyrics? {
try { try {
var data: String? = LyricUtil.getStringFromFile(params[0].data, params[0].artistName) var data: String? = LyricUtil.getStringFromFile(params[0].title, params[0].artistName)
return if (TextUtils.isEmpty(data)) { return if (TextUtils.isEmpty(data)) {
data = MusicUtil.getLyrics(params[0]) data = MusicUtil.getLyrics(params[0])
return if (TextUtils.isEmpty(data)) { return if (TextUtils.isEmpty(data)) {

View file

@ -14,10 +14,10 @@
package code.name.monkey.retromusic.util; package code.name.monkey.retromusic.util;
import android.text.TextUtils;
import android.util.Base64; import android.util.Base64;
import androidx.annotation.NonNull; import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.File; import java.io.File;
@ -36,16 +36,17 @@ public class LyricUtil {
private static final String lrcRootPath = android.os.Environment private static final String lrcRootPath = android.os.Environment
.getExternalStorageDirectory().toString() + "/RetroMusic/lyrics/"; .getExternalStorageDirectory().toString() + "/RetroMusic/lyrics/";
private static final String TAG = "LyricUtil";
@NonNull @Nullable
public static File writeLrcToLoc(@NonNull String title, @NonNull String artist, @NonNull String lrcContext) { public static File writeLrcToLoc(@NonNull String title, @NonNull String artist, @NonNull String lrcContext) {
FileWriter writer = null; FileWriter writer = null;
try { try {
File file = new File(getLrcPath2(title, artist)); File file = new File(getLrcPath(title, artist));
if (!file.exists()) { if (!file.getParentFile().exists()) {
file.mkdirs(); file.getParentFile().mkdirs();
} }
writer = new FileWriter(getLrcPath2(title, artist)); writer = new FileWriter(getLrcPath(title, artist));
writer.write(lrcContext); writer.write(lrcContext);
return file; return file;
} catch (IOException e) { } catch (IOException e) {
@ -71,48 +72,17 @@ public class LyricUtil {
return file.exists(); return file.exists();
} }
public static boolean isLrcFile2Exist(@NonNull String title, @NonNull String artist) { @Nullable
File file = new File(getLrcPath2(title, artist));
return file.exists();
}
@NonNull
public static File getLocalLyricFile(@NonNull String title, @NonNull String artist) { public static File getLocalLyricFile(@NonNull String title, @NonNull String artist) {
try {
File file = new File(getLrcPath(title, artist)); File file = new File(getLrcPath(title, artist));
File file2 = new File(getLrcPath2(title, artist));
if (file.exists()) { if (file.exists()) {
return file; return file;
} else if (file2.exists()) {
return file2;
} else { } else {
return null;
return new File("lyric file not exist");
}
} catch (Exception dfs) {
dfs.printStackTrace();
return new File("lyric file not exist");
} }
} }
public static String getLrcPath2(String title, String artist) { private static String getLrcPath(String title, String artist) {
if (!TextUtils.isEmpty(title)) {
String x2;
if (title.endsWith(".flac") || title.endsWith(".mogg") || title.endsWith(".alac") || title.endsWith(".aiff") || title.endsWith(".webv")) {
x2 = title.substring(0, title.length() - 5) + ".lrc";
} else {
x2 = title.substring(0, title.length() - 4) + ".lrc";
}
return x2;
}
return "";
}
public static String getLrcPath(String title, String artist) {
return lrcRootPath + title + " - " + artist + ".lrc"; return lrcRootPath + title + " - " + artist + ".lrc";
} }
@ -135,18 +105,10 @@ public class LyricUtil {
@NonNull @NonNull
public static String getStringFromFile(@NonNull String title, @NonNull String artist) throws Exception { public static String getStringFromFile(@NonNull String title, @NonNull String artist) throws Exception {
File file; File file = new File(getLrcPath(title, artist));
File file2 = new File(getLrcPath(title, artist));
File file3 = new File(getLrcPath2(title, artist));
if (file2.exists()) {
file = file2;
} else {
file = file3;
}
FileInputStream fin = new FileInputStream(file); FileInputStream fin = new FileInputStream(file);
String ret = convertStreamToString(fin); String ret = convertStreamToString(fin);
fin.close(); fin.close();
// Log.d("damn2",ret);
return ret; return ret;
} }

View file

@ -1,12 +1,9 @@
package code.name.monkey.appthemehelper.util package code.name.monkey.appthemehelper.util
import android.content.res.ColorStateList import android.content.res.ColorStateList
import android.graphics.PorterDuff import androidx.appcompat.widget.AppCompatButton
import android.widget.EditText
import android.widget.TextView
import androidx.annotation.ColorInt
import androidx.core.content.ContextCompat
import code.name.monkey.appthemehelper.ThemeStore import code.name.monkey.appthemehelper.ThemeStore
import com.afollestad.materialdialogs.internal.button.DialogActionButton
import com.google.android.material.button.MaterialButton import com.google.android.material.button.MaterialButton
import com.google.android.material.textfield.TextInputLayout import com.google.android.material.textfield.TextInputLayout
@ -49,4 +46,18 @@ object MaterialUtil {
} }
} }
fun setTint(button: DialogActionButton, color: Int = ThemeStore.accentColor(button.context), background: Boolean = true) {
val temp = button as AppCompatButton
val context = temp.context
val colorState = ColorStateList.valueOf(color)
val textColor = ColorStateList.valueOf(MaterialValueHelper.getPrimaryTextColor(context, ColorUtil.isColorLight(color)))
if (background) {
temp.backgroundTintList = colorState
temp.setTextColor(textColor)
} else {
temp.setTextColor(colorState)
}
}
} }