详解Swift 利用Opration和OprationQueue来下载网络图片

 更新时间:2017年09月17日 16:51:52   作者:水桶前辈  
这篇文章主要介绍了详解Swift 利用Opration和OprationQueue来下载网络图片的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下

详解Swift 利用Opration和OprationQueue来下载网络图片

1. 基于Opration封装的获取网络数据组件

import Foundation 
import UIKit 
 
public typealias OpreationClosure = ((_ data:Data? , _ error: Error?) -> Void) 
 
class LJOpreationManager: Operation { 
   
  /** 
   * 下载用的url 
   */ 
  public var imageUrl : String? 
   
  /** 
   * 定义闭包属性,可选类型 
   */ 
  public var ljcallBackClosure : OpreationClosure? 
   
  func initWitParamter(_ url: String, _ callback: @escaping OpreationClosure) -> LJOpreationManager { 
     
    if url != "" 
    { 
      self.imageUrl = url 
      self.ljcallBackClosure = callback 
    } 
    return self 
  } 
   
  //MARK: -- start 
  override func start() { 
     
    print("start ljManager method") 
    self.startRequest() 
  } 
   
  func startRequest() 
  { 
    //1、创建URL下载地址 
    let url:URL! = URL(string:self.imageUrl!); 
     
    //2、创建Request对象 
    var urlRequest:URLRequest = URLRequest(url:url); 
    urlRequest.httpMethod = "GET" 
    urlRequest.httpShouldUsePipelining = true; 
     
    //不需要缓存 
    //urlRequest.cachePolicy = .reloadIgnoringLocalCacheData 
     
    //3、创建会话 
    let config = URLSessionConfiguration.default 
    let session = URLSession(configuration: config, delegate:self, delegateQueue: .main) 
     
    //4、下载任务 
    //2>-- -- URLSessionDataDelegate 模式 
    let loadDataTask = session.dataTask(with: urlRequest) 
     
    //5、启动任务 
    loadDataTask.resume() 
  } 
   
  //初始化一个data,用来存储下载下来的数据 
  private var _responseData: NSMutableData! 
  var responseData: NSMutableData!{ 
    get{ 
      if _responseData == nil { 
        _responseData = NSMutableData() 
      } 
      return _responseData 
    } 
    set{ 
      self._responseData = newValue 
    } 
  } 
} 
 
// MARK - URLSessionDataDelegate 模式获取数据 
extension LJOpreationManager:URLSessionDataDelegate 
{ 
  @available(iOS 7.0, *) 
  func urlSession(_ session: URLSession, dataTask: URLSessionDataTask, didReceive response: URLResponse, completionHandler: @escaping (URLSession.ResponseDisposition) -> Swift.Void) 
  { 
    //允许继续加载数据 
    completionHandler(.allow) 
  } 
   
  @available(iOS 7.0, *) 
  func urlSession(_ session: URLSession, dataTask: URLSessionDataTask, didReceive data: Data) 
  { 
    //每次获取的data在此拼装 
    //print("Data......\(data)") 
    self.responseData.append(data) 
     
    let currentBytes :Float = Float(self.responseData.length) 
    let allTotalBytes :Float = Float((dataTask.response?.expectedContentLength)!) 
     
    let proValu :Float = Float(currentBytes/allTotalBytes) 
    print("URLSessionDataDelegate----下载进度:------\(proValu*100)%"); 
  } 
   
  func urlSession(_ session: URLSession, task: URLSessionTask, didCompleteWithError error: Error?) 
  { 
    if ljcallBackClosure != nil ,let data = self.responseData{ 
       
      weak var weakSelf : LJOpreationManager? = self 
      DispatchQueue.main.async 
        { 
          print("URLSessionDataDelegate----数据下载完毕") 
          //将接收的数据结果回调到前台,用于进度展示 
          weakSelf?.ljcallBackClosure!(data as Data ,nil) 
      } 
    } 
  } 
} 

2. 基于OprationQueue封装的网络数据管理组件

import Foundation 
 
class LJWebImageManager: NSObject { 
   
  /// Shared manager used . 
  public static let shared = LJWebImageManager() 
  public var ljquee = OperationQueue() 
   
  override init() { 
    if #available(iOS 8.0, *) { 
      self.ljquee.qualityOfService = .background 
    } else { 
    } 
  } 
   
  public func requestByUrl(_ url: String,_ callback: @escaping OpreationClosure) -> LJOpreationManager { 
    let operation = LJOpreationManager().initWitParamter(url, callback) 
    ljquee.addOperation(operation) 
     
    return operation 
  } 
} 

3. 此处下载一张图片

func setCellData(_ labelNameStr:String, imageUrlStr:String) 
{ 
  titleLabel.text = labelNameStr as String 
  /* Session 的delegate模式下载图片或者数据*/ 
  _ = LJWebImageManager.shared.requestByUrl(imageUrlStr, { (data, error) in 
     
    if error == nil, data != nil { 
      let newImage = UIImage(data: data! as Data) 
       
      DispatchQueue.main.async{ 
        let titleImage = UIImageView(frame: CGRect(x: 0, y: 5, width: 40, height: 40)) 
        titleImage.image = newImage 
        self.contentView.addSubview(titleImage) 
      } 
    } 
    else 
    { 
      print(error ?? "") 
    } 
  }) 
} 

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

您可能感兴趣的文章:

相关文章

  • iOS Xcode创建文件时自动生成的注释方法

    iOS Xcode创建文件时自动生成的注释方法

    下面小编就为大家分享一篇iOS Xcode创建文件时自动生成的注释方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • iOS多Target环境配置的完整步骤

    iOS多Target环境配置的完整步骤

    这篇文章主要给大家介绍了关于iOS多Target环境配置的完整步骤,文中通过示例代码介绍的非常详细,对各位iOS开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-10-10
  • iOS如何巧妙解决NSTimer的循环引用详解

    iOS如何巧妙解决NSTimer的循环引用详解

    这篇文章主要给大家介绍了关于iOS如何巧妙解决NSTimer的循环引用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-03-03
  • iOS 二维码扫描相关功能实现

    iOS 二维码扫描相关功能实现

    这篇文章主要介绍了iOS 二维码扫描相关功能实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • iOS中视频播放器的简单封装详解

    iOS中视频播放器的简单封装详解

    要实现封装视频播放器,首先需要实现视频播放器,然后再去考虑怎样封装可以让以后自己使用起来方便快捷。iOS9之前可以使用MediaPlayer来进行视频的播放,iOS9之后系统推荐使用AVFoundation框架实现视频的播放。下面通过本文来看看详细的介绍吧。
    2016-10-10
  • 如何利用FutureBuilder提高开发效率

    如何利用FutureBuilder提高开发效率

    这篇文章主要给大家介绍了关于如何利用FutureBuilder提高开发效率的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • Unity iOS混合开发界面切换思路解析

    Unity iOS混合开发界面切换思路解析

    这篇文章主要介绍了Unity iOS混合开发界面切换思路解析的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-09-09
  • iOS下拉刷新 UIScrollVie异常闪动问题

    iOS下拉刷新 UIScrollVie异常闪动问题

    这篇文章主要介绍了iOS下拉刷新 UIScrollVie异常闪动问题,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03
  • iOS11 SectionHeader 胡乱移动且滑动时出现重复内容的解决方法

    iOS11 SectionHeader 胡乱移动且滑动时出现重复内容的解决方法

    这篇文章主要介绍了iOS11 SectionHeader 胡乱移动且滑动时出现重复内容的解决方法,需要的朋友可以参考下
    2017-11-11
  • searchDisplayController 引起的数组越界处理办法

    searchDisplayController 引起的数组越界处理办法

    这篇文章主要介绍了searchDisplayController 引起的数组越界处理办法,需要的朋友可以参考下
    2015-07-07

最新评论