rxjava3 - 使用数据绑定设置图像

rxjava3 - setImage using databinding

我还是不明白为什么调用成功的Retrofit 没有显示你要下载的图片。大家能看出来吗?

可能是

依赖项:

    implementation 'io.reactivex.rxjava3:rxandroid:3.0.0'
    implementation 'io.reactivex.rxjava3:rxjava:3.0.0'
    implementation 'com.squareup.retrofit2:adapter-rxjava3:2.9.0'

这里是 ViewModel class:

class MainViewModel : ViewModel() {

private val retrofitWorker = RetrofitWorker()

private var byteArray = MutableLiveData<ByteArray?>()

var bitmap: LiveData<Bitmap>? = null

fun getRxImage() {
    retrofitWorker.createService(RetrofitApi::class.java).getImageWithRxJava()
        .doOnSuccess { responseBody ->

            if (responseBody.isSuccessful || responseBody.body() != null || responseBody.errorBody() == null) {
                Log.d("result", "isSuccessful")

                val bytes = responseBody.body()!!.bytes()
                byteArray.postValue(bytes)
                bitmap = Transformations.map(byteArray) {
                    BitmapFactory.decodeByteArray(it, 0, it!!.size)
                }
            }
        }
        .doOnError {
            Log.d("result", "error")
        }
        .subscribeOn(Schedulers.newThread())
        .observeOn(AndroidSchedulers.mainThread())
        .subscribe()
   }
}

改造工人类:

class RetrofitWorker {
private val BASE_URL =
    "https://en.wikipedia.org/"

private val retrofit: Retrofit

init {
    retrofit = Retrofit.Builder()
        .client(OkHttpClient())
        .baseUrl(BASE_URL)
        .addCallAdapterFactory(RxJava3CallAdapterFactory.create())
        .build()
}

fun <T> createService(service: Class<T>): T = retrofit.create(service)
}

interface RetrofitApi {
    @GET("wiki/Wikipedia:Extended_image_syntax#/media/File:Westminstpalace.jpg")
    fun getImageWithRxJava(): Single<Response<ResponseBody>>
}

绑定适配器class

@BindingAdapter("imageResult")
fun bindImage(imgView: ImageView, bitmap: Bitmap?) {
   bitmap?.let {
        imgView.setImageBitmap(bitmap)
    }
}

activity.xml

<data>

    <variable
        name="viewModel"
        type="com.ddd.multithreadcompare.MainViewModel" />
</data>

<androidx.constraintlayout.widget.ConstraintLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">
        <ImageView
        android:id="@+id/imageView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="32dp"
        android:contentDescription="@string/itsanimage"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="@+id/coroutines_button"
        app:layout_constraintHorizontal_bias="0.458"
        app:layout_constraintStart_toStartOf="@+id/rxjava_button"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintVertical_bias="0.5"
        app:imageResult="@{viewModel.bitmap}" />
</androidx.constraintlayout.widget.ConstraintLayout>

有没有可能是数据绑定出了问题? 也许某处没有连接?

可能是您的 url 有问题?您尝试使用最终图像 url 了吗? https://upload.wikimedia.org/wikipedia/commons/3/39/Westminstpalace.jpg

解决方案: 转换图方向错误。

Transformations.map(byteArray) {
                    BitmapFactory.decodeByteArray(it, 0, it!!.size)
}

解决方案:

private val _bitmap = MutableLiveData<Bitmap>()
val bitmap: LiveData<Bitmap>
    get() = _bitmap

在 Success 中我们可以使用:

if (responseBody.isSuccessful || responseBody.body() != null || responseBody.errorBody() == null) {
                    val bytes = responseBody.body()!!.bytes()
                    val bitmap = BitmapFactory.decodeByteArray(bytes, 0, bytes.size)
                    _bitmap.postValue(bitmap)
                }