Fullscreen cover view activity
parent
8e9b89f6f0
commit
eea427216d
@ -0,0 +1,92 @@
|
|||||||
|
package org.koitharu.kotatsu.image.ui
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.content.Intent
|
||||||
|
import android.graphics.drawable.Drawable
|
||||||
|
import android.net.Uri
|
||||||
|
import android.os.Bundle
|
||||||
|
import androidx.appcompat.app.AppCompatDelegate
|
||||||
|
import androidx.core.graphics.Insets
|
||||||
|
import androidx.core.graphics.drawable.toBitmap
|
||||||
|
import androidx.core.view.updatePadding
|
||||||
|
import coil.ImageLoader
|
||||||
|
import coil.request.CachePolicy
|
||||||
|
import coil.request.ImageRequest
|
||||||
|
import coil.target.PoolableViewTarget
|
||||||
|
import com.davemorrissey.labs.subscaleview.ImageSource
|
||||||
|
import com.davemorrissey.labs.subscaleview.SubsamplingScaleImageView
|
||||||
|
import org.koin.android.ext.android.inject
|
||||||
|
import org.koitharu.kotatsu.base.ui.BaseActivity
|
||||||
|
import org.koitharu.kotatsu.databinding.ActivityImageBinding
|
||||||
|
import org.koitharu.kotatsu.utils.ext.enqueueWith
|
||||||
|
import org.koitharu.kotatsu.utils.ext.indicator
|
||||||
|
|
||||||
|
class ImageActivity : BaseActivity<ActivityImageBinding>() {
|
||||||
|
|
||||||
|
private val coil: ImageLoader by inject()
|
||||||
|
|
||||||
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
|
super.onCreate(savedInstanceState)
|
||||||
|
setContentView(ActivityImageBinding.inflate(layoutInflater))
|
||||||
|
supportActionBar?.run {
|
||||||
|
setDisplayHomeAsUpEnabled(true)
|
||||||
|
setDisplayShowTitleEnabled(false)
|
||||||
|
}
|
||||||
|
loadImage(intent.data)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onWindowInsetsChanged(insets: Insets) {
|
||||||
|
binding.toolbar.updatePadding(
|
||||||
|
left = insets.left,
|
||||||
|
right = insets.right,
|
||||||
|
top = insets.top,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun loadImage(url: Uri?) {
|
||||||
|
ImageRequest.Builder(this)
|
||||||
|
.data(url)
|
||||||
|
.memoryCachePolicy(CachePolicy.DISABLED)
|
||||||
|
.lifecycle(this)
|
||||||
|
.target(SsivTarget(binding.ssiv))
|
||||||
|
.indicator(binding.progressBar)
|
||||||
|
.enqueueWith(coil)
|
||||||
|
}
|
||||||
|
|
||||||
|
private class SsivTarget(
|
||||||
|
override val view: SubsamplingScaleImageView,
|
||||||
|
) : PoolableViewTarget<SubsamplingScaleImageView> {
|
||||||
|
|
||||||
|
override fun onStart(placeholder: Drawable?) = setDrawable(placeholder)
|
||||||
|
|
||||||
|
override fun onError(error: Drawable?) = setDrawable(error)
|
||||||
|
|
||||||
|
override fun onSuccess(result: Drawable) = setDrawable(result)
|
||||||
|
|
||||||
|
override fun onClear() = setDrawable(null)
|
||||||
|
|
||||||
|
override fun equals(other: Any?): Boolean {
|
||||||
|
return (this === other) || (other is SsivTarget && view == other.view)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun hashCode() = view.hashCode()
|
||||||
|
|
||||||
|
override fun toString() = "SsivTarget(view=$view)"
|
||||||
|
|
||||||
|
private fun setDrawable(drawable: Drawable?) {
|
||||||
|
if (drawable != null) {
|
||||||
|
view.setImage(ImageSource.bitmap(drawable.toBitmap()))
|
||||||
|
} else {
|
||||||
|
view.recycle()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
companion object {
|
||||||
|
|
||||||
|
fun newIntent(context: Context, url: String): Intent {
|
||||||
|
return Intent(context, ImageActivity::class.java)
|
||||||
|
.setData(Uri.parse(url))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,18 @@
|
|||||||
|
package org.koitharu.kotatsu.utils.progress
|
||||||
|
|
||||||
|
import coil.request.ImageRequest
|
||||||
|
import coil.request.ImageResult
|
||||||
|
import com.google.android.material.progressindicator.BaseProgressIndicator
|
||||||
|
|
||||||
|
class ImageRequestIndicatorListener(
|
||||||
|
private val indicator: BaseProgressIndicator<*>,
|
||||||
|
) : ImageRequest.Listener {
|
||||||
|
|
||||||
|
override fun onCancel(request: ImageRequest) = indicator.hide()
|
||||||
|
|
||||||
|
override fun onError(request: ImageRequest, throwable: Throwable) = indicator.hide()
|
||||||
|
|
||||||
|
override fun onStart(request: ImageRequest) = indicator.show()
|
||||||
|
|
||||||
|
override fun onSuccess(request: ImageRequest, metadata: ImageResult.Metadata) = indicator.hide()
|
||||||
|
}
|
||||||
@ -0,0 +1,26 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<FrameLayout
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<com.davemorrissey.labs.subscaleview.SubsamplingScaleImageView
|
||||||
|
android:id="@+id/ssiv"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:transitionName="cover" />
|
||||||
|
|
||||||
|
<com.google.android.material.appbar.MaterialToolbar
|
||||||
|
android:id="@+id/toolbar"
|
||||||
|
style="@style/Widget.Kotatsu.Toolbar"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content" />
|
||||||
|
|
||||||
|
<com.google.android.material.progressindicator.CircularProgressIndicator
|
||||||
|
android:id="@+id/progressBar"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:indeterminate="true" />
|
||||||
|
|
||||||
|
</FrameLayout>
|
||||||
Loading…
Reference in New Issue