android 图片加载库(3)- Glide 加载圆形图片

简介

一直以来,对于图片的圆形显示一直都是一个长生不衰的话题,随着各大图片加载库的进化和替换,加载圆形图片的方法一直都在进步,这里我们梳理一下,虽然现在有现成的开元方案使用,但是我们还是从学习的角度来看看那些自行的实现,还是很考验绘图方面的基础的,这一直都是我们广大 android 的弱项。

方案

其实我们有很多选择来加载圆形图片,这里我列举一下:

  • 使用官方实现
  • 扩展官方基类 BitmapTransformation
  • 开源库 glide-transformations
  • 开源库 CircleImageView

官方实现

Glide 的官方实现很简单,也是效果最好的了

  GlideApp.with(activity)
                .load(url)
                 // 裁剪成圆形,和系统缓存完美配合
                .circleCrop()
                .into(imageView);

BitmapTransformation

这个类是 Glide 推出的变换扩展的基类,继承这个类我们可以实现任意的对图片资源的扩展,当然裁剪成圆形也是 OK 的

这里有一个实现,不是很好,因为最后一个方法没有做实现,这是有关图片缓存的。所以会造成一个问题,每次重新加载这个圆形图片资源,因为没有缓存走会走一次解码原始资源,变换裁剪的过程,因为要占用原始资源,所以view 原先显示的这个图片资源就会被清空,而图片重新处理又需要一点点时间,多一造成了 view 会有一下的白屏闪过。

public class GlideCircleTransform extends BitmapTransformation {
    
    public GlideCircleTransform(Context context) {
        super(context);
    }

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

    private static Bitmap circleCrop(BitmapPool pool, Bitmap source) {
        if (source == null) return null;
        int size = Math.min(source.getWidth(), source.getHeight());
        int x = (source.getWidth() - size) / 2;
        int y = (source.getHeight() - size) / 2;
        Bitmap squared = Bitmap.createBitmap(source, x, y, size, size);
        Bitmap result = pool.get(size, size, Bitmap.Config.ARGB_8888);
        if (result == null) {
            result = Bitmap.createBitmap(size, size, Bitmap.Config.ARGB_8888);
        }
        Canvas canvas = new Canvas(result);
        Paint paint = new Paint();
        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;
    }

    @Override
    public void updateDiskCacheKey(MessageDigest messageDigest) {
        messageDigest.update(getClass().getName().getBytes());
    }
}

开源库 glide-transformations

这个开源库,使用起来也很简单的,地址:glide-transformations

  GlideApp.with(activity)
                .asBitmap()
                .load(url)
                .transform(new CropCircleTransformation())
                .into(imageView);
    // Glide transform
    implementation 'jp.wasabeef:glide-transformations:3.0.0'
    // If you want to use the GPU Filters
    implementation 'jp.co.cyberagent.android.gpuimage:gpuimage-library:1.4.1'

最新是3.1.0版本,但是需要API 27支持,3.0.0 API 26就可以了。


开源库 CircleImageView

这个是经典的圆形图片组件,有很多人都在用,但是这个组件和 Glide 结合起来很麻烦,需要专门自定义 Glide 的 transition 过度动画,和自定义 trageView 才能正常显示,要不然会出现第一次加载不显示,没有过度动画的,问题。我是是在没心情做 CircleImageView 的适配了,有时间做完了再放上吧。

若是想用的话,我们可以声明 Glide 获取的资源类型为 Bitmap,在 into 中自己操作资源,这样可以正常显示,但是无法使用过度动画了。

GlideApp.with(activity)
                .asBitmap()
                .load(url)
                .into(new SimpleTarget<Bitmap>() {
                    @Override
                    public void onResourceReady(Bitmap resource, Transition<? super Bitmap> transition) {
                        imageView.setImageBitmap(resource);
                    }
                });

不推荐用这个开源组件,地址我放上吧,有兴趣的可以去玩玩:CircleImageView

dependencies {
    ...
    compile 'de.hdodenhof:circleimageview:2.2.0'
}

结论

这个使用 Glide 加载圆形图片,除了使用官方实现,其他所有方式都存在无法缓存变换后位图的问题,都会造成一个短暂的白屏。


参考资料:

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,372评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,368评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,415评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,157评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,171评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,125评论 1 297
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,028评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,887评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,310评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,533评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,690评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,411评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,004评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,659评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,812评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,693评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,577评论 2 353

推荐阅读更多精彩内容