当前位置:首页 > 谈天说地

Android图片加载框架Coil的详细使用总结

34资源网2022-07-29654

简介

coil 是一个 android 图片加载库,通过 kotlin 协程的方式加载图片。特点如下:

  • 更快: coil 在性能上有很多优化,包括内存缓存和磁盘缓存,把缩略图存保存在内存中,循环利用 bitmap,自动暂停和取消图片网络请求等。
  • 更轻量级: coil 只有2000个方法(前提是你的 app 里面集成了 okhttp 和 coroutines),coil 和 picasso 的方法数差不多,相比 glide 和 fresco 要轻量很多。
  • 更容易使用: coil 的 api 充分利用了 kotlin 语言的新特性,简化和减少了很多样板代码。
  • 更流行: coil 首选 kotlin 语言开发并且使用包含 coroutines, okhttp, okio 和 androidx lifecycles 在内最流行的开源库。
    coil 名字的由来:取 coroutine image loader 首字母得来。

github:https://github.com/coil-kt/coil

文档:https://coil-kt.github.io/coil/image_loaders/

添加依赖:

implementation("io.coil-kt:coil:1.4.0")

简单使用

// url
imageview.load("https://www.example.com/image.jpg")

// resource
imageview.load(r.drawable.image)

// file
imageview.load(file("/path/to/image.jpg"))

// and more...

可以使用 lambda 语法轻松配置请求选项:

imageview.load("https://www.example.com/image.jpg") {
    crossfade(true) //渐进进出
    placeholder(r.drawable.image) //加载中占位图
    transformations(circlecroptransformation())  //圆形图
    error(r.drawable.image) //加载错误占位图
}

高斯模糊

//正常图片
mbinding.image1.load(imageurl)

//高斯模糊-轻微模糊
mbinding.image11.load(imageurl) {
     transformations(blurtransformation(this@mainactivity, 5f, 10f))
     scale(scale.fill)
}

//高斯模式-严重模糊
mbinding.image12.load(imageurl) {
     transformations(blurtransformation(this@mainactivity, 20f, 40f))
     scale(scale.fill)
 }

效果图:

圆角

        //没有圆角
        mbinding.image1.load(imageurl){
            transformations(roundedcornerstransformation())
            scale(scale.fill)
        }

        //圆角一样
        mbinding.image11.load(imageurl) {
            transformations(roundedcornerstransformation(20f))
            scale(scale.fill)
        }

        //圆角不一样
        mbinding.image12.load(imageurl) {
            transformations(
                roundedcornerstransformation(
                    topleft = 20f,
                    topright = 20f,
                    bottomleft = 50f,
                    bottomright = 50f
                )
            )
            scale(scale.fill)
        }

效果图:

圆形

布局文件

<imageview
     android:id="@+id/image1"
     android:layout_gravity="center"
     android:layout_width="150dp"
     android:layout_height="150dp" />

代码:

mbinding.image1.load(imageurl){
     transformations(circlecroptransformation())
     scale(scale.fill)
}

效果图:

灰色变换 grayscaletransformation

简单来说就是把彩色图变成灰色的

mbinding.image1.load(imageurl) {
    transformations(grayscaletransformation())
}

效果图:

gif

添加依赖

implementation("io.coil-kt:coil-gif:1.4.0")

官方文档:https://coil-kt.github.io/coil/gifs/

创建 gif imageloader 实例

val imageloader = imageloader.builder(context)
    .componentregistry {
        if (sdk_int >= 28) {
            add(imagedecoderdecoder(context))
        } else {
            add(gifdecoder())
        }
    }
    .build()
    
 //设置全局唯一实例
 coil.setimageloader(imageloader)

加载 gif 图片:

mbinding.image1.load(gifurl)

效果图如下:

监听下载过程

mbinding.image1.load(imageurl) {
      listener(
           onstart = { request ->
               log.d("coil-", "onstart")
            },
           onerror = { request, throwable ->
               log.d("coil-", "onerror")
           },
           oncancel = { request ->
               log.d("coil-", "oncancel")
           },
           onsuccess = { request, metadata ->
               log.d("coil-", "onsuccess")
           }
       )
}

取消下载

val imageurl = "https://t7.baidu.com/it/u=433422559,1779762296&fm=193&f=gif"

val disposable = mbinding.image1.load(imageurl)

//取消加载
disposable.dispose()

替换 okhttp 实例

coil 底层是使用 okhttp 作为网络请求工具,可以设置 okhttpclient 实例

val okhttpclient = okhttpclient.builder()
       .cache(coilutils.createdefaultcache(this))
       .build()

val imageloader = imageloader.builder(this).okhttpclient {
     okhttpclient
}.build()
        
coil.setimageloader(imageloader)

自定义

  val okhttpclient = okhttpclient.builder()
            .cache(coilutils.createdefaultcache(this))
            .build()

        val imageloader = imageloader.builder(this)
            .availablememorypercentage(0.2)
            .diskcachepolicy(cachepolicy.enabled)  //磁盘缓策略 enabled、read_only、write_only、disabled
            .crossfade(true) //淡入淡出
            .crossfade(1000)  //淡入淡出时间
            .okhttpclient {  //设置okhttpclient实例
                okhttpclient
            }.build()

        coil.setimageloader(imageloader)

availablememorypercentage 设置用于此 imageloader 的内存缓存和位图池的可用内存百分比,范围:0-1 , 如果为0 , 则禁用内存缓存。

默认行为:

memorycachepolicy 内存缓存策略,有4中策略,默认为 cachepolicy.enabled

diskcachepolicy 磁盘缓存策略,方式和内存策略一直

crossfade 开启淡入淡出

coil 源码分析

coil 是一个单例类

总结

到此这篇关于android图片加载框架coil详细使用的文章就介绍到这了,更多相关android图片加载框架coil内容请搜索萬仟网以前的文章或继续浏览下面的相关文章希望大家以后多多支持萬仟网!

看完文章,还可以扫描下面的二维码下载快手极速版领4元红包

快手极速版二维码

快手极速版新人见面礼

除了扫码领红包之外,大家还可以在快手极速版做签到,看视频,做任务,参与抽奖,邀请好友赚钱)。

邀请两个好友奖最高196元,如下图所示:

快手极速版邀请好友奖励

扫描二维码推送至手机访问。

版权声明:本文由34楼发布,如需转载请注明出处。

本文链接:https://www.34l.com/post/20002.html

分享给朋友:

相关文章

适合普通人做的小本创业点子

适合普通人做的小本创业点子

适合普通人做的小本创业生意有什么??随着零售行业的兴起,小型超市便利店生意成为创业者首选的项目之一,主要原因在于:投入资金小、回笼快,不需要太大的现金流来支撑、一年半左右就能回本。这对于拥有一部分闲置资金,想创业的投资者来说简直是很好的创业…

互联网公司好日子到头,逻辑彻底变了

互联网公司好日子到头,逻辑彻底变了

好日子到头了,逻辑彻底变了,互联网公司已经不再是香饽饽。有两个重要的信号。…

哪家的云主机好(国内五大云主机服务商)

哪家的云主机好(国内五大云主机服务商)

导言:博睿数据(股票代码688229)十余年专注APM领域,已为超过2000余家大型企业提供专业数据服务。依托先进的测评技术及丰富的行业经验,博睿宏远倾力打造了一个公开透明的性能测评栏目——【Bonree指数】。该栏目致力于呈现各行业的整体…

虚拟内存太低怎么设置(电脑磁盘空间不足清理步骤)

虚拟内存太低怎么设置(电脑磁盘空间不足清理步骤)

在电脑的平时使用中,经常会出现内存不足的提示,有时可能小伙伴们会疑惑了,明明自己是16G内存的性能为何也能出现这种提示呢?这是当你在运行多个大程序的时候,对内存的需求非常大,当物理内存不能满足需求时,有可能导致程序关闭而数据保存错误。那么在…

扫地机器人市场的2021:后浪翻涌,前浪头疼

扫地机器人市场的2021:后浪翻涌,前浪头疼

编者按:本文来自锋见,创业邦经授权发布。 转眼2021年已接近尾声,2022年即将来临。回顾过去这一年,注定是不平凡的一年,特别是对于扫地机器人行业来说,2021年发生了不少大事,对行业影响深远。今天我们就来盘点和点评一下。 科技改变生活,…