Recyclerview 刷新适配器时图片闪烁问题

当我们在 Recyclerview 在刷新适配器的时候 如果item中加载了 圆角的图片 图片会发生闪烁.
这里我使用的 Glide加载 根据 Glide官网介绍
在这里插入图片描述
所以我们需要重写这个 三个方法

public class BTransformation extends BitmapTransformation {
    private static final String ID = "com.demo.mvp_demo.hilt.BTransformation";
    private static final byte[] ID_BYTES = ID.getBytes(CHARSET);


    private float radius;

    public BTransformation(int radius) {
        this.radius = radius;
    }


    @Override
    protected Bitmap transform(@NonNull BitmapPool pool, @NonNull Bitmap toTransform, int outWidth, int outHeight) {
        return cornersImage(pool, toTransform);
    }
    //重写三方法 使得磁盘和缓存 正常工作
    @Override
    public boolean equals(@Nullable Object obj) {
        return obj instanceof BTransformation;
    }

    @Override
    public int hashCode() {
        return ID.hashCode();
    }

    @Override
    public void updateDiskCacheKey(@NonNull MessageDigest messageDigest) {
        messageDigest.update(ID_BYTES);
    }
    //画圆角
    private Bitmap cornersImage(BitmapPool pool, Bitmap bitmapSource) {
        Bitmap tempBitmap = null;
        try {
            if (bitmapSource == null) {
                return null;
            }
            tempBitmap = pool.get(bitmapSource.getWidth(), bitmapSource.getHeight(),
                    Bitmap.Config.ARGB_8888);
            if (tempBitmap == null) {
                tempBitmap = Bitmap.createBitmap(bitmapSource.getWidth(),
                        bitmapSource.getHeight(), Bitmap.Config.ARGB_8888);
            }
            Canvas canvas = new Canvas(tempBitmap);
            Paint paint = new Paint();
            paint.setShader(new BitmapShader(bitmapSource, BitmapShader.TileMode.CLAMP,
                    BitmapShader.TileMode.CLAMP));
            paint.setAntiAlias(true);

            RectF rectF = new RectF(0f, 0f, bitmapSource.getWidth(),
                    bitmapSource.getHeight());
            canvas.drawRoundRect(rectF, radius, radius, paint);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return tempBitmap;
    }
    //画圆
    private static Bitmap circleCrop(BitmapPool pool, Bitmap source) {
        if (source == null) return null;
        //获取资源的长宽,获取最小值 子位图的像素个数
        int size = Math.min(source.getWidth(), source.getHeight());
        // 子位图第一个像素在源位图的X坐标
        int x = (source.getWidth() - size) / 2;
        //子位图第一个像素在源位图的y坐标
        int y = (source.getHeight() - size) / 2;
        //创建新位图  source 源位图
        Bitmap squared = Bitmap.createBitmap(source, x, y, size, size);
        //返回一个正好匹配给定宽、高和配置的只包含透明像素的Bitmap
        // 如果BitmapPool中找不到这样的Bitmap,就返回null
        Bitmap result = pool.get(size, size, Bitmap.Config.ARGB_8888);
        //当返回null 时,创建给定宽、高和配置的新位图
        if (result == null) {
            result = Bitmap.createBitmap(size, size, Bitmap.Config.ARGB_8888);
        }
        //画图
        Canvas canvas = new Canvas(result);
        Paint paint = new Paint();
        // 设置shader
        paint.setShader(new BitmapShader(squared, BitmapShader.TileMode.CLAMP, BitmapShader.TileMode.CLAMP));
        //抗锯齿
        paint.setAntiAlias(true);
        float r = size / 2f;
        // 用设置好的画笔绘制一个圆
        canvas.drawCircle(r, r, r, paint);
        return result;
    }
}

这样磁盘和内存使得正常工作.

Activity里

		int radius = 30;
        RequestOptions options = new RequestOptions().transform(new BTransformation(radius));
        Glide.with(this).load(url).apply(options).into(iv_main_img);

这里默认实现的 圆角 如果需要实现圆形 需要在 transform 放在里面 将方法替换成 circleCrop方法 来实现 使用 circlecrop 方法可以将 构造方法删掉 不传入 radius 因为 不需要用到 实现 圆角 则需要 构造传参 radius

在这里插入图片描述
在此记录一下

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
RecyclerView原生适配器RecyclerView的一个重要组件,用于将数据与RecyclerView中的视图进行绑定。RecyclerView原生适配器提供了一些默认的视图绑定方法,如创建视图、绑定数据、设置视图大小等。同,它也允许我们自定义视图绑定方法,以满足不同的需求。 RecyclerView原生适配器的基本用法如下: 1. 创建一个继承自RecyclerView.Adapter适配器类,实现必要的方法,如onCreateViewHolder、onBindViewHolder和getItemCount等。 2. 在onCreateViewHolder方法中创建视图,并返回一个ViewHolder对象。 3. 在onBindViewHolder方法中将数据与视图进行绑定。 4. 在getItemCount方法中返回数据项的数量。 5. 将适配器对象设置到RecyclerView中即可显示数据。 示例代码如下: ``` public class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> { private List<String> mData; public MyAdapter(List<String> data) { mData = data; } @Override public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new ViewHolder(view); } @Override public void onBindViewHolder(ViewHolder holder, int position) { holder.mTextView.setText(mData.get(position)); } @Override public int getItemCount() { return mData.size(); } public static class ViewHolder extends RecyclerView.ViewHolder { public TextView mTextView; public ViewHolder(View itemView) { super(itemView); mTextView = itemView.findViewById(R.id.text_view); } } } ``` 在上面的代码中,我们定义了一个MyAdapter类,继承自RecyclerView.Adapter,并在其中实现了必要的方法。在onCreateViewHolder方法中,我们使用LayoutInflater来创建视图,并将其封装在ViewHolder对象中返回。在onBindViewHolder方法中,我们将数据与视图进行绑定。在getItemCount方法中,我们返回数据项的数量。最后,我们将适配器对象设置到RecyclerView中即可显示数据。 需要注意的是,RecyclerView原生适配器只提供了基本的视图绑定方法,如果需要实现更复杂的视图绑定,我们可以使用第三方的适配器库,如BaseRecyclerViewAdapterHelper等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值