当前位置: 首页 > news >正文

长沙网站设计咨询电话昆明网站建设哪家

长沙网站设计咨询电话,昆明网站建设哪家,校园 网站建设 知乎,网站配图尺寸文章目录 Android Coil总结概述添加依赖用法基本用法占位图变形自定义ImageLoader取消加载协程支持缓存清除缓存监听 简单封装 Android Coil总结 概述 Coil 是一个用于 Android 的 Kotlin 图像加载库,旨在简化图像加载和显示的过程。它基于 Kotlin 协程&#xff0…

文章目录

  • Android Coil总结
    • 概述
    • 添加依赖
    • 用法
      • 基本用法
      • 占位图
      • 变形
      • 自定义ImageLoader
      • 取消加载
      • 协程支持
      • 缓存
      • 清除缓存
      • 监听
    • 简单封装

Android Coil总结

概述

Coil 是一个用于 Android 的 Kotlin 图像加载库,旨在简化图像加载和显示的过程。它基于 Kotlin 协程,提供了简洁的 API 和高效的性能。

添加依赖

implementation "io.coil-kt:coil:2.4.0"

用法

基本用法

// 加载网络图片
binding.imageView1.load("https://www.wanandroid.com/resources/image/pc/logo.png")// 加载本地资源图片
binding.imageView2.load(R.drawable.logo)// 加载本地路径图片
val file = File(cacheDir.path + "/logo.png")
binding.imageView3.load(file)

占位图

binding.imageView1.load(imgUrl) {crossfade(true) // 淡入淡出placeholder(R.drawable.placeholder) // 加载时占位error(R.drawable.error) // 加载失败占位
}

变形

binding.imageView1.load(imgUrl) {transformations(CircleCropTransformation()) // 圆形
}
binding.imageView2.load(imgUrl) {transformations(RoundedCornersTransformation(16F)) // 圆角
}

自定义ImageLoader

val imageLoader = ImageLoader.Builder(context).crossfade(true).build()
val request = ImageRequest.Builder(context).data(imgUrl).target(binding.imageView1).build()
imageLoader.enqueue(request)

取消加载

val disposable = binding.imageView1.load(imgUrl)
disposable.dispose() // 取消加载

协程支持

Coil 基于 Kotlin 协程,可以协程中使用。

lifecycleScope.launch {val imageLoader = context.imageLoaderval request = ImageRequest.Builder(context).data(imgUrl).build()val drawable = imageLoader.execute(request).drawablebinding.imageView1.setImageDrawable(drawable)
}

缓存

binding.imageView1.load(imgUrl) {diskCachePolicy(CachePolicy.ENABLED) // 启用磁盘缓存memoryCachePolicy(CachePolicy.ENABLED) // 启用内存缓存
}

清除缓存

val imageLoader = context.imageLoader
imageLoader.memoryCache?.clear()
imageLoader.diskCache?.clear()

监听

binding.imageView1.load(imgUrl) {listener(onStart = { Log.e("TAG", "开始") },onSuccess = { request, result -> Log.e("TAG", "成功") },onError = { request, result -> Log.e("TAG", "失败") },onCancel = { Log.e("TAG", "取消") })
}

简单封装

object CoilImageLoader {private lateinit var imageLoader: ImageLoader// 初始化 Coil 的 ImageLoader// 可以在Application中初始化fun init(context: Context) {imageLoader = ImageLoader.Builder(context).crossfade(true) // 启用淡入淡出效果.build()}// 加载网络图片fun loadImage(imageView: ImageView, url: String) {imageView.load(url, imageLoader) {placeholder(R.drawable.placeholder) // 设置占位图error(R.drawable.error) // 设置错误图}}// 加载圆形图片fun loadCircleImage(imageView: ImageView, url: String) {imageView.load(url, imageLoader) {transformations(CircleCropTransformation()) // 圆形裁剪}}// 加载圆角图片fun loadRoundedCornersImage(imageView: ImageView, url: String, radius: Float) {imageView.load(url, imageLoader) {transformations(RoundedCornersTransformation(radius)) // 圆角}}// 清除内存缓存fun clearMemoryCache() {imageLoader.memoryCache?.clear()}// 清除磁盘缓存fun clearDiskCache(context: Context) {imageLoader.diskCache?.clear()}
}
http://www.yayakq.cn/news/600089/

相关文章:

  • 网站乱码解决办法200M电信宽带做网站
  • 公司网站海报怎么做网站建设空间是指什么软件
  • dedecms做多语言的网站网站建设哪家
  • 网站建站报价表做家装家居网站
  • 南平摩托车罚款建设网站缴费网站建设需求统计表
  • 文库网站建设wordpress 物流主题
  • 网站流程设计企业管理咨询师报考条件
  • 怎样做_网站做seowordpress注册显示密码
  • 辽阳网站建设哪家好网站哪个公司做的
  • 如何做一个论坛网站来推网站
  • 网站做快照东莞今天发生的重大新闻
  • 大理网站推广wordpress修改字体
  • 免费微信网站建设凡科快图网站
  • asp.net mvc 网站开发之美 pdf加强网站建设会
  • 大理网站建设滇icp备seo服务商
  • 网站开发详细报价孝感网站开发找优搏
  • 合肥seo网站排名优化公司常见的域名
  • 菏泽网站推广推广公司好做吗
  • 网站推广做哪个比较好网站做可以退款吗
  • 东莞网站推广营销网站建设基地
  • 手机端做的优秀的网站网站内容与目录结构图
  • 搭建电商网站部门网站建设总结
  • 企业营销型网站建设的可行性定制手机微网站
  • 建网站收费哈尔滨做网站公司有哪些
  • 门户网站建设报告哦文案代写平台
  • 中国电力建设集团网站做商城网站要请程序员吗
  • 网站被墙工业设计大赛官网
  • 西安做网站找哪家公司好个人网站成功案例
  • 如何做网站预览网站开发费会计处理
  • php做网站示例展示型网站建设模板