Caused by: java.lang.IllegalStateException: Cannot pool recycled bitmap

Caused by: java.lang.IllegalStateException: Cannot pool recycled bitmap
at com.bumptech.glide.load.engine.bitmap_recycle.LruBitmapPool.put(LruBitmapPool.java:108)
at com.bumptech.glide.load.resource.bitmap.BitmapResource.recycle(BitmapResource.java:57)
at com.bumptech.glide.load.engine.EngineResource.recycle(EngineResource.java:75)
at com.bumptech.glide.load.engine.ResourceRecycler.recycle(ResourceRecycler.java:22)
at com.bumptech.glide.load.engine.Engine.onResourceReleased(Engine.java:398)
at com.bumptech.glide.load.engine.EngineResource.release(EngineResource.java:116)
at com.bumptech.glide.load.engine.Engine.release(Engine.java:362)
at com.bumptech.glide.request.SingleRequest.clear(SingleRequest.java:326)
at com.bumptech.glide.manager.RequestTracker.clearAndRemove(RequestTracker.java:72)
at com.bumptech.glide.RequestManager.untrack(RequestManager.java:663)
at com.bumptech.glide.RequestManager.untrackOrDelegate(RequestManager.java:631)
at com.bumptech.glide.RequestManager.clear(RequestManager.java:627)
at com.bumptech.glide.RequestManager.onDestroy(RequestManager.java:374)
at com.bumptech.glide.manager.ActivityFragmentLifecycle.onDestroy(ActivityFragmentLifecycle.java:65)
at com.bumptech.glide.manager.SupportRequestManagerFragment.onDestroy(SupportRequestManagerFragment.java:215)
at androidx.fragment.app.Fragment.performDestroy(Fragment.java:2830)
at androidx.fragment.app.FragmentManagerImpl.moveToState(FragmentManagerImpl.java:1028)
at androidx.fragment.app.FragmentManagerImpl.moveFragmentToExpectedState(FragmentManagerImpl.java:1238)
at androidx.fragment.app.FragmentManagerImpl.moveToState(FragmentManagerImpl.java:1303)
at androidx.fragment.app.FragmentManagerImpl.dispatchStateChange(FragmentManagerImpl.java:2659)
at androidx.fragment.app.FragmentManagerImpl.dispatchDestroy(FragmentManagerImpl.java:2644)
at androidx.fragment.app.FragmentController.dispatchDestroy(FragmentController.java:329)
at androidx.fragment.app.FragmentActivity.onDestroy(FragmentActivity.java:366)
at androidx.appcompat.app.AppCompatActivity.onDestroy(AppCompatActivity.java:233)
at com.scjl.littlemasteralbum.base.BaseActivity.onDestroy(BaseActivity.kt:79)
at com.scjl.littlemasteralbum.ui.activity.second.OtherDetailActivity.onDestroy(OtherDetailActivity.kt:195)
at android.app.Activity.performDestroy(Activity.java:8181)
at android.app.Instrumentation.callActivityOnDestroy(Instrumentation.java:1342)
at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:4986)
at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:5030)
at android.app.servertransaction.DestroyActivityItem.execute(DestroyActivityItem.java:44)

記錄一下Glide加載bitmap 報錯的解決方式 Cannot pool recycled bitmap

發生問題原因:

我是在recycleview中使用SubsamplingScaleImageView組件,返回上個界面就會奔潰,就報此錯,但是你使用正常的imageview就不會。

解決辦法:

把bitmap轉化爲可變的 resource.copy(Bitmap.Config.ARGB_8888, true),加上此句就不會報這個錯了。。

private fun displayImg(
        imageView: SubsamplingScaleImageView,
        data: ProductAllBean
    ) {
        var option = RequestOptions()
        option.diskCacheStrategy(DiskCacheStrategy.NONE)
        option.skipMemoryCache(true)
        var taget= object : CustomTarget<Bitmap>() {
            override fun onResourceReady(
                resource: Bitmap,
                transition: Transition<in Bitmap>?
            ) {
                if (resource != null) {
                    var mBitmap = resource.copy(Bitmap.Config.ARGB_8888, true)
                    imageView.setImage(ImageSource.bitmap(mBitmap))
                    imageView.setMinimumScaleType(SubsamplingScaleImageView.SCALE_TYPE_CUSTOM)
                }
            }
            override fun onLoadCleared(placeholder: Drawable?) {
            }
        }
        GlideApp.with(context).asBitmap().apply(option).load(data.thumbImageUrl).into(taget)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章