Glide 自定义圆角、铺满FitXY

在 Android 开发中,使用 Glide 来加载图片时,有时需要对图片进行特定的处理,比如设置圆角或者使图片完全填充到一个视图中(类似于 ImageView 的 scaleType 中的 FitXY)。以下是如何使用 Glide 来实现这些自定义需求的处理方案。

1. 自定义圆角

Glide 本身不直接支持圆角,但可以通过使用 Transformation 来实现。你可以使用 RoundedCorners 转换来添加圆角效果。例如:

java 复制代码
import com.bumptech.glide.Glide;
import com.bumptech.glide.load.resource.bitmap.RoundedCorners;
import com.bumptech.glide.request.RequestOptions;

Glide.with(context)
    .load(url)
    .apply(new RequestOptions().transform(new RoundedCorners(radius)))
    .into(imageView);

这里的 radius 是圆角的半径。

2. 铺满 FitXY

Glide 默认情况下会尽可能保持图片的宽高比,但如果你需要像 ImageView 的 FitXY 那样铺满整个视图,可以通过自定义 Transformation 来实现。这通常涉及到重写图片的尺寸处理方式,使其完全匹配目标 ImageView 的尺寸。

你可以创建一个自定义的 Transformation 类来实现这一点:

java 复制代码
import android.graphics.Bitmap;
import com.bumptech.glide.load.engine.bitmap_recycle.BitmapPool;
import com.bumptech.glide.load.resource.bitmap.BitmapTransformation;
import com.bumptech.glide.load.Key;

import java.security.MessageDigest;
/**
 * <p>
 * Description: [使用 BitmapTransformation 来实现图像的拉伸效果 (FitXY 的效果)]
 * </p>
 * // 使用 Glide 加载图片
 *         Glide.with(this)
 *                 .load(imgUrl)
 *                 .placeholder(R.drawable.default) // 占位图
 *                 .error(R.drawable.default) // 错误图
 *                 .transform(new FitXYTransformation (this), new GlideRoundTransformUtil(this, 3)) // 使用自定义的 FitXY 和圆角变换
 *                 .into(imageView);
 * ${tags}
 */
public class FitXYTransformation extends BitmapTransformation {
    private static final String ID = "com.example.glide.FitXYTransformation";
    private static final byte[] ID_BYTES = ID.getBytes(Key.CHARSET);

    @Override
    protected Bitmap transform(BitmapPool pool, Bitmap toTransform, int outWidth, int outHeight) {
        return Bitmap.createScaledBitmap(toTransform, outWidth, outHeight, false);
    }

    @Override
    public boolean equals(Object o) {
        return o instanceof FitXYTransformation;
    }

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

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

然后,使用这个自定义的 Transformation:

java 复制代码
Glide.with(context)
    .load(url)
    .apply(new RequestOptions().transform(new FitXYTransformation()))
    .into(imageView);

结合使用圆角和 FitXY

如果你需要同时应用圆角和 FitXY 效果,可以将两个转换结合起来:

java 复制代码
Glide.with(context)
    .load(url)
    .apply(new RequestOptions().transform(new FitXYTransformation(), new RoundedCorners(radius)))
    .into(imageView);

这样,图片首先会被缩放以铺满 ImageView,然后应用圆角效果。注意,这种组合可能会导致圆角不太明显,因为首先图片被缩放填充了整个视图。

通过这些方法,你可以灵活地使用 Glide 来满足不同的图片显示需求。

相关推荐
zhangphil15 天前
Android Glide判断当前运行环境是否为主线程的工具方法,Kotlin
android·kotlin·glide
好评笔记16 天前
多模态论文笔记——GLIDE(DALL·E 2模型核心部件)
论文阅读·人工智能·深度学习·aigc·transformer·glide·dall·e 2
好评笔记16 天前
多模态论文笔记——GLIDE(DALL·E 2模型的核心部件)
论文阅读·人工智能·深度学习·计算机视觉·transformer·glide·dall·e 2
袁震1 个月前
Android-Glide缓存机制
android·缓存·移动开发·glide
袁震1 个月前
Android-Glide详解二
android·移动开发·glide
袁震1 个月前
Android-Glide详解
android·移动开发·glide
飞翔的时光机1 个月前
Glide 加载图片并应用滤镜效果
glide
zhangphil2 个月前
Android矩阵Matrix实现Glide图像fitCenter转换为centerCrop,Kotlin
android·kotlin·glide
zhangphil2 个月前
Android Glide批量加载Bitmap,拼接组装大Bitmap,更新单个AppCompatImageView,Kotlin(2)
android·kotlin·glide