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

【iOS】SDWebImage

文章目录

  • 前言
  • SDWebImage
    • SDWebImage 的主要组件包括:
    • 常用方法及简单用法示例
  • 总结

前言

  在写知乎日报项目时,遇到了图片加载和通过API异步加载图片的问题,在组内成员的引导下,去学习了SDWebImage开源库。

SDWebImage

  SDWebImage 是一个用 Objective-C 编写的开源库,主要用于异步加载和缓存图片。
  SDWebImage 提供了一个异步图片下载器,允许在后台线程下载图片,避免阻塞主线程。
SDWebImage 实现了异步的内存和磁盘缓存机制,具有自动缓存到期处理。
SDWebImage 支持包括 GIF 和 WebP 在内的多种图片格式,且能确保同一个 URL 的图片不会被重复下载,确保无效的 URL 不会被反复加载,支持后台图片解压缩处理,以减少主线程的负担。

SDWebImage 的主要组件包括:

UIImageView+WebCache:为 UIImageView 提供网络图片加载和缓存的扩展。
SDWebImageManager:作为下载器和缓存的桥梁,管理图片的下载和缓存。
SDWebImageDownloader:负责图片的下载操作。
SDImageCache:负责图片的缓存,包括内存缓存和磁盘缓存。

常用方法及简单用法示例

在使用SDWebImage库之前,首先要将其导入所需项目内。
然后在需要的文件里引用头文件:

#import "UIImageView+WebCache.h"

使用时,调用sd_setImageWithURL:方法缓存图片,这就是新版本的新方法,旧方法是setImageWithURL:。下面是常用的几个方法

  1. sd_setImageWithURL:
//图片缓存的基本代码
[self.image1 sd_setImageWithURL:imagePath1];
  1. sd_setImageWithURL: completed:
//用block 可以在图片加载完成之后做些事情
[self.image2 sd_setImageWithURL:imagePath2 completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {
      //在图片加载完成之后想触发的事情
      NSLog(@"加载完成");
}];
  1. sd_setImageWithURL: placeholderImage:
//给一张默认图片,先使用默认图片,当图片加载完成后再替换
[self.image1 sd_setImageWithURL:imagePath1 placeholderImage:[UIImage imageNamed:@"default"]];
  1. sd_setImageWithURL: placeholderImage: completed:
//使用默认图片,而且用block 在完成后做一些事情
[self.image1 sd_setImageWithURL:imagePath1 placeholderImage:[UIImage imageNamed:@"default"] completed:^(UIImage *image, NSError *error, SDImageCacheType cacheType, NSURL *imageURL) {         
      NSLog(@"加载完成");        
}];
  1. sd_setImageWithURL: placeholderImage: options:
//options 选择方式
[self.image1 sd_setImageWithURL:imagePath1 placeholderImage:[UIImage imageNamed:@"default"] options:SDWebImageRetryFailed];
//如果你只需要内存缓存,那么在options这里选择SDWebImageCacheMemoryOnly就可以了。

简单应用:

    NSURL *url = [NSURL URLWithString:@"https://news-at.zhihu.com/api/7/prefetch-launch-images/1080*1920"];
    self.imageView = [[UIImageView alloc] init];
    UIImage *placeholderImage = [UIImage imageNamed:@"placeholder"];
    [self.imageView sd_setImageWithURL:url placeholderImage:placeholderImage];
    
    [self.view addSubview:self.imageView];

总结

  我在知乎日报编写中运用了这个库函数,但是我并未获取到图片(在模拟器上没加载出来),不清楚是API的问题还是代码哪里出了差错,还在研究,另外,我暂时只学习了SDWebImage的常用方法和基本用法,至于运用时可能碰见的其他问题,还有待发现和解决。

参考文章:iOS SDWebImage的使用


http://www.kler.cn/a/378492.html

相关文章:

  • Python 条件语句
  • yolo系列各种环境配置运行
  • C# 中 发送HTTP请求 实现Ajax功能
  • Java面向对象 C语言字符串常量
  • c++ 贪心算法
  • Redis高级篇之缓存一致性详细教程
  • 高效处理数据的一把钥匙:探索MySQL事务机制
  • Linux 练习三
  • scp免密上传文件
  • 华为OD机试 - 字符串分割(二) - 双指针(Python/JS/C/C++ 2024 C卷 100分)
  • [ vulnhub靶机通关篇 ] 渗透测试综合靶场 Corrosion1 通关详解 (附靶机搭建教程)
  • 基于Spring Boot + Vue的气象智慧监测系统设计与实现
  • python读word中的表格和插入表格
  • 电子电气架构 --- Trace 32(劳特巴赫)多核系统的调试
  • Freertos学习日志(1)-基础知识
  • 11.1组会汇报-基于区块链的安全多方计算研究现状与展望
  • 【原创分享】详述中间件的前世今生
  • .Net Framework里演示怎么样使用StringBuilder、Math.Min和String.Format
  • c# 实现文件更新通知
  • JavaEE-多线程初阶(1)
  • MySQL-基础汇总
  • 知识见闻 - Workday公司介绍
  • springboot 基于google 缓存,实现防重复提交
  • 掌握ElasticSearch(六):分析过程
  • linux当中用到的系统调用和库函数
  • elementUI tabs 吸顶功能实现,拉到最底部时候点击tab 回到最初位置