Android專案實戰(五十七):Glide 高斯模糊效果
核心需要高斯模糊的庫
compile 'jp.wasabeef:glide-transformations:2.0.1'
針對於3.7的版本
使用方法為:
//載入背景, Glide.with(MusicPlayerActivity.this) .load(service.getImageUri()) .dontAnimate() .error(R.drawable.no_music_rotate_img) // 設定高斯模糊,模糊程度(最大25) 縮放比例 .bitmapTransform(new BlurTransformation(this, 14, 3)) .into(allBg);
針對4.+
Glide.with(context) .load(url) .apply(RequestOptions.bitmapTransform(new BlurTransformation(25,8))) .into(view);
BlurTransformation 類原始碼:
import android.graphics.Bitmap; import android.graphics.Canvas; import android.graphics.Paint; import android.support.annotation.NonNull; import com.bumptech.glide.load.engine.bitmap_recycle.BitmapPool; import com.bumptech.glide.load.resource.bitmap.BitmapTransformation; import java.security.MessageDigest; import jp.wasabeef.glide.transformations.internal.FastBlur; public class BlurTransformation extends BitmapTransformation { private static final int VERSION = 1; private static final String ID = "BlurTransformation." + VERSION; private static int MAX_RADIUS = 25; private static int DEFAULT_DOWN_SAMPLING = 1; private int radius; private int sampling; public BlurTransformation() { this(MAX_RADIUS, DEFAULT_DOWN_SAMPLING); } public BlurTransformation(int radius) { this(radius, DEFAULT_DOWN_SAMPLING); } public BlurTransformation(int radius, int sampling) { this.radius = radius; this.sampling = sampling; } @Override protected Bitmap transform(@NonNull BitmapPool pool, @NonNull Bitmap toTransform, int outWidth, int outHeight) { int width = toTransform.getWidth(); int height = toTransform.getHeight(); int scaledWidth = width / sampling; int scaledHeight = height / sampling; Bitmap bitmap = pool.get(scaledWidth, scaledHeight, Bitmap.Config.ARGB_8888); Canvas canvas = new Canvas(bitmap); canvas.scale(1 / (float) sampling, 1 / (float) sampling); Paint paint = new Paint(); paint.setFlags(Paint.FILTER_BITMAP_FLAG); canvas.drawBitmap(toTransform, 0, 0, paint); bitmap = FastBlur.blur(bitmap, radius, true); return bitmap; } @Override public String toString() { return "BlurTransformation(radius=" + radius + ", sampling=" + sampling + ")"; } @Override public boolean equals(Object o) { return o instanceof BlurTransformation && ((BlurTransformation) o).radius == radius && ((BlurTransformation) o).sampling == sampling; } @Override public int hashCode() { return ID.hashCode() + radius * 1000 + sampling * 10; } @Override public void updateDiskCacheKey(@NonNull MessageDigest messageDigest) { messageDigest.update((ID + radius + sampling).getBytes(CHARSET)); } }
相關文章
- Android動態高斯模糊效果教程Android
- Android實現快速高斯模糊Android
- Android:簡單靠譜的動態高斯模糊效果Android
- 前端 -- 頁面濾鏡效果及高斯模糊效果前端
- Flutter BackdropFilter 實現高斯模糊FlutterFilter
- Android NDK之旅——圖片高斯模糊Android
- Android 圖片高斯模糊處理Android
- Android影象處理 - 高斯模糊的原理及實現Android
- Android 圖片高斯模糊解決方案Android
- 直播平臺原始碼,用CSS製作毛玻璃效果(高斯模糊效果)原始碼CSS
- android實戰專案六imageview做一個幻燈片效果AndroidView
- 後處理 - 高斯模糊
- Android MVP模式專案實戰AndroidMVP模式
- 高斯模糊的演算法演算法
- iOS專案開發實戰——檢視動畫效果iOS動畫
- 【影象演算法】高斯模糊+徑向縮放模糊演算法
- Android自定義弧形[方形加弧形]IamgeView並新增高斯模糊AndroidView
- Java 實現高斯模糊和影像的空間卷積Java卷積
- Java 實現高斯模糊和影象的空間卷積Java卷積
- 圖片模糊效果實現(RenderScript)
- iOS中實現模糊效果教程iOS
- 使用Glide快速實現毛玻璃效果IDE
- Android tinker熱修復——實戰接入專案Android
- Fresco實踐-高斯模糊、圓形圓角、URL、File、Assets、Resource
- Android專案實戰之高仿網易雲音樂專案介紹Android
- Android 專案實戰--手機衛士(實現splash)Android
- SVG實現動態模糊動畫效果SVG動畫
- SVG 實現動態模糊動畫效果SVG動畫
- Android知識問答與分享專案實戰Android
- android學習視訊(實戰專案演練)Android
- Android專案實戰之高仿網易雲音樂建立專案和配置Android
- dubbo專案實戰
- HarmonyOS 實戰專案
- Flutter學習 —- 螢幕截圖和高斯模糊Flutter
- Flutter學習 ---- 螢幕截圖和高斯模糊Flutter
- iOS專案開發實戰——使用CALayer實現圖片的淡入淡出效果iOS
- python實戰專案Python
- TypeScript + 大型專案實戰TypeScript