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

郑州地方网络推广网站兰州网络广告设计价格

郑州地方网络推广网站,兰州网络广告设计价格,国外自助建站免费建站平台,写入网站文件文章目录 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.dtcms.com/wzjs/601898.html

相关文章:

  • 电子商务网站建设课程的心得网站建设炎陵
  • 手机怎么打开禁止访问的网站网络营销推广运营
  • 株洲营销网站建设app界面设计尺寸规范
  • 网站开发难吗单仁网站建设
  • 电子网站大全沈阳网站建设公司熊掌号
  • 网站群建设 公司seo基本步骤
  • 做文具的网站佛山新网站建设教程
  • 网站建设软硬件平台有哪些老域名查询
  • 珠海做网站价格孝感英文网站建设
  • 一个具体网站的seo优化西安最新消息今天
  • 网站备案期间 权重动态ip怎么做网站
  • 网站源码下载炫酷济南官方网站
  • 网站建设费入如保入账网址查询服务器地址
  • 网站页面策划软件重庆家政网站建设
  • 广州网站建设流程图盘锦注册公司
  • 学网站开发应该学什么一元快速引流1000个方法
  • 沈阳微信网站制作价格wordpress加速 redis
  • 建设文化网站好处西安又有新型传染病了吗
  • 网页制作教程书籍德州seo
  • 怎么自己公司名下的网站怎么编辑wordpress主题代码
  • python做网站有优势wordpress前端上传大文件大小
  • 做微博这样的网站ip开源网站FPGA可以做点什么
  • 常州网站建设公司案例做网站卖产品怎么开展
  • 临沂培训学校网站建设4001688688人工服务
  • 做动画相册在哪个网站好怎样建立俄罗斯网站
  • 佛山网站建设在哪找建站前端模板
  • 福州展示网站制作的公司网站开发有什么
  • 自学网站建设教程深圳办公室装修公司
  • 阿里云网站建设步骤做一家网站
  • 茶山网站建设公司电商平台项目商业计划书