- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{ [self downloadImage]; } -(void)downloadImage{ dispatch_group_t group = dispatch_group_create(); dispatch_queue_t queue = dispatch_get_global_queue(0, 0); dispatch_group_async(group, queue, ^{ NSURL *url = [NSURL URLWithString:@"https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1530167525247&di=f09b0f4412a2825e4ae641079691cd14&imgtype=0&src=http%3A%2F%2Fpic35.photophoto.cn%2F20150617%2F0013026499624253_b.png"]; NSData *data = [NSData dataWithContentsOfURL:url]; self.image1 = [UIImage imageWithData:data]; }); dispatch_group_async(group, queue, ^{ NSURL *url = [NSURL URLWithString:@"https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1530167525247&di=184be5b28b34bf0670e9cb065fef673c&imgtype=0&src=http%3A%2F%2Fpic22.nipic.com%2F20120724%2F16351_204302573152_2.png"]; NSData *data = [NSData dataWithContentsOfURL:url]; self.image2 = [UIImage imageWithData:data]; }); dispatch_group_notify(group,queue , ^{ //1创建图形上下文 UIGraphicsBeginImageContext(CGSizeMake(200, 200)); //2.画图 [self.image1 drawInRect:CGRectMake(0, 0, 200, 100)]; self.image1 = nil;//此时不需要图片了 //3.画图 [self.image2 drawInRect:CGRectMake(0, 100, 200, 100)]; self.image2 = nil;//此时不需要图片了 //4.从图形上下文获取图片 UIImage *tempImage = UIGraphicsGetImageFromCurrentImageContext(); //5.关闭上下文 UIGraphicsEndImageContext(); //6更新UI dispatch_async(dispatch_get_main_queue(), ^{ self.imageView.image = tempImage; }); }); }
swift 版 下载图片
//保证 下载完图片在分享 private func getDownloadImage(urlStrArr:[String], block:@escaping (_ imageArr:[UIImage])->()){ var downloadImageArr : [UIImage] = [] var tempBlock : ((_ imageArr:[UIImage])->())? = nil tempBlock = block let group = DispatchGroup() let diyQueue = DispatchQueue(label: "diyQueue") for (_, urlStr) in urlStrArr.enumerated(){ group.enter() diyQueue.async { if let tempUrl = URL.init(string: urlStr){ if let tempData = try? Data.init(contentsOf: tempUrl){ if let tempImage = UIImage.init(data: tempData){ downloadImageArr.append(tempImage) group.leave() } } } } } //走完队列 group.notify(queue: diyQueue) { //这个地方可以合并数据, 图片合并操作等等 //主线程刷新 DispatchQueue.main.async { tempBlock?(downloadImageArr) } } }
调用
getDownloadImage(urlStrArr: [dataStruct.relationQrCodeUrl]) { [weak self](imageArr:[UIImage]) in self?.downloadView.updateImage(downImage: imageArr[0]) }
分类:
OC 线程操作
, OC 画图 UIGraphics
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现