RecycleView中使用Glide加载图片,在列表刷新时刷屏.

网上大部分解释是RecycleView的条目动画导致的,其实是不准确的.

第一步:

GlideApp.with(context)
            .asBitmap()
            .load(url)
            .into(object : SimpleTarget<Bitmap>() {
                override fun onResourceReady(resource: Bitmap, transition: Transition<in Bitmap>?) {
                    //TODO 核心方法 自己将加载完成的资源塞给 imageView
                    //TODO 使用Glide的into方法会出现Glide默认动画,且 .dontAnimate()无效
                    imageView.setImageBitmap(resource)
                }
            })
如果遇到到圆角或者圆形图片则直接写一个继承ImageView的自定义控件,使用 canvas?.clipPath(path)裁剪,
不只是圆角,通过path添加,任意形状都可以裁剪出来.

第二步:
open class ImageViewWithRadius : AppCompatImageView {

    private var radius: Float = 0.0f

    constructor(context: Context) : this(context, null)
    constructor(context: Context, attrs: AttributeSet?) : this(context, attrs, 0)
    constructor(context: Context, attrs: AttributeSet?, defStyleAttr: Int) : super(
        context,
        attrs,
        defStyleAtt
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值