Glide设置圆角图片(支持自定义圆角位置)

最近项目中有显示数据的需求,圆角父控件中最左端放置图片,此时显示起来图片的直角盖住了父控件的圆角,故需要对图片进行圆角处理后再显示。

网上大多数都是通过实现Transformation,在transform方法中进行自定义处理,后来我发现Glide中的自带的设置圆形图片的RoundedCorners类,借鉴此类可以通过官方提供的TransformationUtils工具类来实现,具体实现如下:

public class RoundRadiusTransform extends BitmapTransformation {

//  此处用实际类的完整路径
    private static final String ID = "com.xxx.xxx.xxxx.xxx.RoundRadiusTransform";
    private static final byte[] ID_BYTES = ID.getBytes(CHARSET);

    private final int roundingRadius;

    private boolean isLeftTop, isRightTop, isLeftBottom, isRightBottom;

    private static RoundRadiusTransform mInstance;

    public RoundRadiusTransform(int roundingRadius) {
        this.roundingRadius = roundingRadius;
    }

    /**
     * 需要设置圆角的部分
     *
     * @param leftTop     左上角
     * @param rightTop    右上角
     * @param leftBottom  左下角
     * @param rightBottom 右下角
     */
    public void setNeedCorner(boolean leftTop, boolean rightTop, boolean leftBottom, boolean rightBottom) {
        isLeftTop = leftTop;
        isRightTop = rightTop;
        isLeftBottom = leftBottom;
        isRightBottom = rightBottom;
    }

    @Override
    protected Bitmap transform(@NonNull BitmapPool pool, @NonNull Bitmap toTransform, int outWidth, int outHeight) {
        return TransformationUtils.roundedCorners(pool, toTransform,
                isLeftTop ? roundingRadius : 0,
                isRightTop ? roundingRadius : 0,
                isRightBottom ? roundingRadius : 0,
                isLeftBottom ? roundingRadius : 0);
    }

    public static RoundRadiusTransform getDefault() {
        if (mInstance == null) {
            synchronized (RoundRadiusTransform.class) {
                if (mInstance == null) {
                    mInstance = new RoundRadiusTransform(ScreenUtils.dp2px(MainApplication.getInstance(), 6));
                    mInstance.setNeedCorner(true, false, true, false);
                }
            }
        }
        return mInstance;
    }

    @Override
    public boolean equals(Object o) {
        if (o instanceof RoundRadiusTransform) {
            RoundRadiusTransform other = (RoundRadiusTransform) o;
            return roundingRadius == other.roundingRadius;
        }
        return false;
    }

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

    @Override
    public void updateDiskCacheKey(@NonNull MessageDigest messageDigest) {
        messageDigest.update(ID_BYTES);

        byte[] radiusData = ByteBuffer.allocate(4).putInt(roundingRadius).array();
        messageDigest.update(radiusData);
    }
}

上面示例中默认设置的是左边6dp的圆角右边直角的显示样式。如果您看了RoundedCorners源码,就会发现有很大的相似性,只是在transform方法返回时有区别。

所以有时候没有必要重复发明轮子,有些轮子的零部件就在第三方提供的工具中,所需要的只是我们花点时间了解组拼下而已。

你可能感兴趣的:(Glide设置圆角图片(支持自定义圆角位置))