Android Glide使用姿势与原理分析

简介

Android Glide是一款强大的图片加载库,提供了丰富的功能和灵活的使用方式。本文将深入分析Glide的工作原理,并介绍一些使用姿势,助你更好地运用这个优秀的库。

原理分析

Glide的原理复杂而高效。它首先基于给定的图片URL或资源ID进行加载,支持多种数据源,包括网络请求、本地文件和ContentProvider等。Glide通过缓存机制提高加载速度,同时还会将压缩后的图片存储在磁盘中,节省内存和流量。

Glide设计了一种称为RequestBuilder的模式,允许我们通过链式调用方法配置图片加载参数。这种设计让代码更简洁易读。

此外,Glide支持图片变换和加载动画,可以应用各种变换效果,如圆形图片、圆角图片和灰度图片等,同时也可以为图片加载过程添加动画效果,提升用户体验。

使用姿势

以下是优化后的一些Glide使用姿势,帮助你更充分地使用这个库:

添加依赖

首先,在项目中添加Glide的依赖:

implementation 'com.github.bumptech.glide:glide:4.12.0'
kapt 'com.github.bumptech.glide:compiler:4.12.0'

加载图片

使用Glide加载图片非常简单,只需以下几行代码:

Glide.with(context)
     .load(url)
     .into(imageView)

这里的context是上下文对象,url是图片的URL,imageView是显示图片的ImageView。

设置占位符和错误图片

你可以利用placeholder()方法设置加载过程中显示的占位符图片,以及使用error()方法设置加载失败时显示的图片:

Glide.with(context)
     .load(url)
     .placeholder(R.drawable.placeholder)
     .error(R.drawable.error)
     .into(imageView)

设置缩略图

Glide支持设置缩略图,以提高加载速度。通过thumbnail()方法设置缩略图的URL或资源ID:

Glide.with(context)
     .load(url)
     .thumbnail(0.1f)
     .into(imageView)

图片变换

你可以使用transform()方法为图片添加变换效果。例如,使用circleCrop()方法可将图片裁剪成圆形,roundedCorners()方法可将图片角变为圆角:

Glide.with(context)
     .load(url)
     .transform(CircleCrop())
     .into(imageView)

加载动画

通过animate()方法,你可以为图片加载过程添加动画效果。例如,使用crossFade()方法添加淡入淡出效果:

Glide.with(context)
     .load(url)
     .animate(R.anim.fade_in)
     .into(imageView)

图片压缩

Glide通过根据目标ImageView的大小和ScaleType来计算图片的实际大小,并进行压缩。

在加载图片时,需要指定目标ImageView的宽高和ScaleType。Glide会根据这些信息决定图片的压缩方式。

若目标ImageView的宽高比例与图片的比例不一致,Glide会根据ScaleType计算缩放比例,然后将图片按比例压缩,以适应ImageView大小。

若目标ImageView的宽高比例与图片的比例一致,Glide会直接加载原始图片,不进行压缩。

通过这种方式,Glide根据目标ImageView来自动进行图片压缩,以提高加载速度和节省内存。

另外,Glide也支持自定义图片压缩策略。我们可以实现Transformation接口来定义自己的压缩算法。

自定义图片压缩策略

自定义图片压缩策略通过实现Transformation接口实现。该接口包含transform()方法,可以在其中定义自定义的压缩操作。

以下是一个示例,展示如何实现自定义的图片压缩策略:

class CustomTransformation : Transformation<Bitmap> {
    override fun transform(
        context: Context,
        resource: Resource<Bitmap>,
        outWidth: Int,
        outHeight: Int
    ): Resource<Bitmap> {
        val originalBitmap = resource.get()
        // 自定义压缩算法
        val compressedBitmap = customCompress(originalBitmap)
        return BitmapResource(compressedBitmap, Glide.get(context).bitmapPool)
    }

    override fun getId(): String {
        return "customTransformation" // 返回唯一标识符,用于缓存
    }

    private fun customCompress(bitmap: Bitmap): Bitmap {
        // 自定义压缩算法实现
        // ...
        return compressedBitmap
    }
}

使用自定义图片压缩策略时,可以在Glide的链式调用中应用:

Glide.with(context)
     .load(url)
     .transform(CustomTransformation())
     .into(imageView)

通过实现Transformation接口,你可以根据需求制定不同的压缩算法,以满足特定的图片压缩需求。

图片缓存

Glide使用双缓存策略来管理图片缓存。它在内存中缓存未经压缩的原始图片,提升加载速度,同时还会将压缩后的图片存储在磁盘中,节省内存和流量。

Glide的缓存机制非常智能。它根据图片的URL或资源ID生成唯一的缓存键,以确保不同的图片不会混淆。此外,Glide支持自定义缓存的大小和有效期

,以适应不同需求。

Glide的缓存机制是其优秀性能的关键之一。通过内存缓存和磁盘缓存的组合,它能够高效地管理已加载的图像数据,从而提高后续加载的速度。

内存缓存

Glide使用内存缓存来存储最近使用的图像数据,以便快速访问。内存缓存基于LRU(Least Recently Used,最近最少使用)算法,保留最近加载的图像数据。当应用需要再次访问这些图像时,可以直接提供,从而避免频繁的网络请求和磁盘读取。

磁盘缓存

磁盘缓存分为活动资源缓存和非活动资源缓存。

  • 活动资源缓存(Active Resources Cache): 这是一个小型、可写的磁盘缓存,存储当前正在使用的图像数据。它有助于减少频繁加载的图片的重复磁盘读取。
  • 未活动资源缓存(Inactive Resources Cache): 这是一个更大、只读的磁盘缓存,用于长期存储已加载的图像数据。当活动资源缓存已满时,Glide会将不再活跃的图片从活动缓存中移至未活动资源缓存,以腾出空间供新图片使用。

缓存策略

Glide允许开发者根据需求设置不同的缓存策略。例如:

  • DiskCacheStrategy.ALL: 在内存和磁盘上都缓存。
  • DiskCacheStrategy.NONE: 不使用磁盘缓存。
  • DiskCacheStrategy.DATA: 只缓存原始数据。
  • DiskCacheStrategy.RESOURCE: 只缓存转换后的资源。
  • DiskCacheStrategy.AUTOMATIC: 根据图片数据源自动选择缓存策略。

清除缓存

若图片发生变化或需要释放存储空间,可手动清除Glide缓存。使用以下代码可清除磁盘缓存:

Glide.get(context).clearDiskCache()

清除内存缓存可使用:

Glide.get(context).clearMemory()

综上所述,Glide的缓存机制通过内存和磁盘缓存的组合,高效地提高了图像加载性能。这种机制使得相同图像能够更快地加载,节省了用户流量,并在离线或网络不稳定时也能正常显示图像。

更多Android 可以查看我的个人介绍!!!

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

推荐阅读更多精彩内容