android canvas 模糊效果,使用Glide实现高斯模糊效果

使用Glide实现高斯模糊效果,供大家参考,具体内容如下

先来看效果

b33e44f6a3d7c5ce2fbd080cabe79fd5.png

b5bf6f113c05306e8359177b62ee285e.png

第一步:引入依赖

implementation 'com.github.bumptech.glide:glide:4.7.1'

implementation 'jp.wasabeef:glide-transformations:2.0.1'

第二步:自定义继承自BitmapTransformation的类

import android.content.Context;

import android.graphics.Bitmap;

import android.graphics.Canvas;

import android.graphics.Paint;

import android.os.Build;

import android.renderscript.RSRuntimeException;

import androidx.annotation.NonNull;

import com.bumptech.glide.Glide;

import com.bumptech.glide.load.engine.bitmap_recycle.BitmapPool;

import com.bumptech.glide.load.resource.bitmap.BitmapTransformation;

import java.nio.charset.Charset;

import java.security.MessageDigest;

import jp.wasabeef.glide.transformations.internal.FastBlur;

import jp.wasabeef.glide.transformations.internal.RSBlur;

/**

* 虚化Transformation

* 更多效果参考:https://github.com/wasabeef/glide-transformations

*/

public class BlurTransformation extends BitmapTransformation {

private static String STRING_CHARSET_NAME = "UTF-8";

private static final String ID = "com.kevin.glidetest.BlurTransformation";

private static Charset CHARSET = Charset.forName(STRING_CHARSET_NAME);

private static final byte[] ID_BYTES = ID.getBytes(CHARSET);

private static int MAX_RADIUS = 25;

private static int DEFAULT_DOWN_SAMPLING = 1;

private Context mContext;

private BitmapPool mBitmapPool;

private int mRadius;

private int mSampling;

public BlurTransformation(Context context) {

this(context, Glide.get(context).getBitmapPool(), MAX_RADIUS, DEFAULT_DOWN_SAMPLING);

}

public BlurTransformation(Context context, BitmapPool pool) {

this(context, pool, MAX_RADIUS, DEFAULT_DOWN_SAMPLING);

}

public BlurTransformation(Context context, BitmapPool pool, int radius) {

this(context, pool, radius, DEFAULT_DOWN_SAMPLING);

}

public BlurTransformation(Context context, int radius) {

this(context, Glide.get(context).getBitmapPool(), radius, DEFAULT_DOWN_SAMPLING);

}

public BlurTransformation(Context context, int radius, int sampling) {

this(context, Glide.get(context).getBitmapPool(), radius, sampling);

}

public BlurTransformation(Context context, BitmapPool pool, int radius, int sampling) {

mContext = context.getApplicationContext();

mBitmapPool = pool;

mRadius = radius;

mSampling = sampling;

}

@Override

protected Bitmap transform(@NonNull BitmapPool pool, @NonNull Bitmap toTransform, int

outWidth, int outHeight) {

Bitmap source = toTransform ;

int width = source.getWidth();

int height = source.getHeight();

int scaledWidth = width / mSampling;

int scaledHeight = height / mSampling;

Bitmap bitmap = mBitmapPool.get(scaledWidth, scaledHeight, Bitmap.Config.ARGB_8888);

if (bitmap == null) {

bitmap = Bitmap.createBitmap(scaledWidth, scaledHeight, Bitmap.Config.ARGB_8888);

}

Canvas canvas = new Canvas(bitmap);

canvas.scale(1 / (float) mSampling, 1 / (float) mSampling);

Paint paint = new Paint();

paint.setFlags(Paint.FILTER_BITMAP_FLAG);

canvas.drawBitmap(source, 0, 0, paint);

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR2) {

try {

bitmap = RSBlur.blur(mContext, bitmap, mRadius);

} catch (RSRuntimeException e) {

bitmap = FastBlur.blur(bitmap, mRadius, true);

}

} else {

bitmap = FastBlur.blur(bitmap, mRadius, true);

}

//return BitmapResource.obtain(bitmap, mBitmapPool);

return bitmap;

}

@Override

public int hashCode() {

return ID.hashCode();

}

@Override

public boolean equals(Object obj) {

return obj instanceof BlurTransformation;

}

@Override

public void updateDiskCacheKey(MessageDigest messageDigest) {

messageDigest.update(ID_BYTES);

}

}

第三步:实际使用

String url="url";

Glide.with(this).load(url)

.apply(RequestOptions.bitmapTransform(new BlurTransformation(this,25,3)))

.into(img);

//参数用来设置模糊程度

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

时间: 2020-12-16

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值