简介
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 Glide是一款功用强大且灵敏的图片加载库。经过深入了解其作业原理和运用办法,你可以愈加自如地运用这个优秀的库,进步运用的图片加载体会。
引荐
android_startup: 供给一种在运用启动时可以愈加简单、高效的办法来初始化组件,优化启动速度。不仅支撑Jetpack App Startup的全部功用,还供给额定的同步与异步等候、线程控制与多进程支撑等功用。
AwesomeGithub: 依据Github的客户端,纯练习项目,支撑组件化开发,支撑账户暗码与认证登陆。运用Kotlin言语进行开发,项目架构是依据JetPack&DataBinding的MVVM;项目中运用了Arouter、Retrofit、Coroutine、Glide、Dagger与Hilt等流行开源技能。
flutter_github: 依据Flutter的跨平台版本Github客户端,与AwesomeGithub相对应。
android-api-analysis: 结合具体的Demo来全面解析Android相关的知识点, 协助读者可以更快的把握与理解所论述的关键。
daily_algorithm: 每日一算法,由浅入深,欢迎加入一起共勉。