mirror of
https://github.com/gedoor/legado.git
synced 2025-08-10 00:52:30 +00:00
fix:搜索封面,详情封面,封面换源的缺省headers的优先级:书源>全局
This commit is contained in:
@@ -7,6 +7,7 @@ import android.net.Uri
|
||||
import androidx.annotation.DrawableRes
|
||||
import com.bumptech.glide.RequestBuilder
|
||||
import io.legado.app.constant.AppPattern.dataUriRegex
|
||||
import io.legado.app.data.appDb
|
||||
import io.legado.app.model.analyzeRule.AnalyzeUrl
|
||||
import io.legado.app.utils.isAbsUrl
|
||||
import io.legado.app.utils.isContentScheme
|
||||
@@ -18,7 +19,7 @@ object ImageLoader {
|
||||
/**
|
||||
* 自动判断path类型
|
||||
*/
|
||||
fun load(context: Context, path: String?): RequestBuilder<Drawable> {
|
||||
fun load(context: Context, path: String?, sourceOrigin: String? = null): RequestBuilder<Drawable> {
|
||||
return when {
|
||||
path.isNullOrEmpty() -> GlideApp.with(context).load(path)
|
||||
dataUriRegex.find(path) != null -> {
|
||||
@@ -27,7 +28,8 @@ object ImageLoader {
|
||||
}
|
||||
path.isAbsUrl() -> {
|
||||
kotlin.runCatching {
|
||||
val url = AnalyzeUrl(path).getGlideUrl()
|
||||
val source = sourceOrigin?.let { appDb.bookSourceDao.getBookSource(it) }
|
||||
val url = AnalyzeUrl(path, source = source).getGlideUrl()
|
||||
GlideApp.with(context).load(url)
|
||||
}.getOrDefault(
|
||||
GlideApp.with(context).load(path)
|
||||
|
||||
@@ -35,7 +35,7 @@ class CoverAdapter(context: Context, val callBack: CallBack) :
|
||||
item: SearchBook,
|
||||
payloads: MutableList<Any>
|
||||
) = binding.run {
|
||||
ivCover.load(item.coverUrl, item.name, item.author)
|
||||
ivCover.load(item.coverUrl, item.name, item.author, false, item.origin)
|
||||
tvSource.text = item.originName
|
||||
}
|
||||
|
||||
|
||||
@@ -220,7 +220,7 @@ class BookInfoActivity :
|
||||
}
|
||||
|
||||
private fun showCover(book: Book) {
|
||||
binding.ivCover.load(book.getDisplayCover(), book.name, book.author)
|
||||
binding.ivCover.load(book.getDisplayCover(), book.name, book.author, false, book.origin)
|
||||
BookCover.loadBlur(this, book.getDisplayCover())
|
||||
.into(binding.bgBook)
|
||||
}
|
||||
|
||||
@@ -86,7 +86,8 @@ class SearchAdapter(context: Context, val callBack: CallBack) :
|
||||
searchBook.coverUrl,
|
||||
searchBook.name,
|
||||
searchBook.author,
|
||||
AppConfig.loadOnlyWifi
|
||||
AppConfig.loadOnlyWifi,
|
||||
searchBook.origin
|
||||
)
|
||||
}
|
||||
}
|
||||
@@ -99,7 +100,7 @@ class SearchAdapter(context: Context, val callBack: CallBack) :
|
||||
"last" -> upLasted(binding, searchBook.latestChapterTitle)
|
||||
"intro" -> tvIntroduce.text = searchBook.trimIntro(context)
|
||||
"kind" -> upKind(binding, searchBook.getKindList())
|
||||
"cover" -> ivCover.load(searchBook.coverUrl, searchBook.name, searchBook.author)
|
||||
"cover" -> ivCover.load(searchBook.coverUrl, searchBook.name, searchBook.author, false, searchBook.origin)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -175,7 +175,8 @@ class CoverImageView @JvmOverloads constructor(
|
||||
path: String? = null,
|
||||
name: String? = null,
|
||||
author: String? = null,
|
||||
loadOnlyWifi: Boolean = false
|
||||
loadOnlyWifi: Boolean = false,
|
||||
sourceOrigin: String? = null
|
||||
) {
|
||||
this.bitmapPath = path
|
||||
this.name = name?.replace(AppPattern.bdRegex, "")?.trim()
|
||||
@@ -186,7 +187,7 @@ class CoverImageView @JvmOverloads constructor(
|
||||
.centerCrop()
|
||||
.into(this)
|
||||
} else {
|
||||
ImageLoader.load(context, path)//Glide自动识别http://,content://和file://
|
||||
ImageLoader.load(context, path, sourceOrigin)//Glide自动识别http://,content://和file://
|
||||
.apply(RequestOptions().set(OkHttpModelLoader.loadOnlyWifiOption, loadOnlyWifi))
|
||||
.placeholder(BookCover.defaultDrawable)
|
||||
.error(BookCover.defaultDrawable)
|
||||
|
||||
Reference in New Issue
Block a user