首頁 > 軟體

Android圖片載入框架Coil的詳細使用總結

2022-07-28 22:02:38

簡介

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內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com