UICollectionView滚动Alamofire

时间:2016-07-23 02:18:14

标签: ios swift uicollectionview uicollectionviewcell

问题是当第一次加载应用程序时,对于延迟连接,当滚动收集时图像加载到错误的位置,图像将改变几次,直到滚动结束并且图像将会移动回到正确的形象。我不知道为什么会这样。加载应用程序后,图像采取正确的位置。我使用Alamofire和Alamofire Image。

型号说明:

import UIKit
import SwiftyJSON
import Alamofire
import AlamofireImage

class Noticia: NSObject {
    //MARK: - Properties
    var name:String = ""
    var image:String = ""
    var number:Int = 0
    let photoCache = AutoPurgingImageCache(
        memoryCapacity: 100 * 1024 * 1024,
        preferredMemoryUsageAfterPurge: 60 * 1024 * 1024
    )

    override init() {

    }

    func setData(obj:JSON)->Noticia{
        self.name = obj["titulo"].stringValue
        self.image = obj["imagen_portada"].stringValue
        self.number = Int(obj["id"].stringValue)!
        return self
    }

    //MARK: - Image Caching

    func cacheImage(image: Image, urlString: String) {
        photoCache.addImage(image, withIdentifier: urlString)
    }

    func cachedImage(urlString: String) -> Image? {
        return photoCache.imageWithIdentifier(urlString)
    }

}

的ViewController

func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCellWithReuseIdentifier("Cell", forIndexPath: indexPath) as! NoticiaCell
    let cell2 = collectionView.dequeueReusableCellWithReuseIdentifier("CellBillboard", forIndexPath: indexPath) as! BillboardCell
    //Billboard Cell
    if(indexPath.item == 0){
        cell2.contact = noticia[indexPath.item]
        return cell2
    }else{
        //Square News Cell
        cell.contact = noticia[indexPath.item]
        cell.layer.borderColor = ConstantProjectClass.colorBorderWebBizarro.CGColor
        cell.layer.borderWidth = ConstantProjectClass.noticiasBorderWidth
        //Layout custom
        cell.setNeedsLayout()
        cell.layoutIfNeeded()
        return cell
    }

}

Noticia Cell

import UIKit
import Alamofire
import AlamofireImage

class NoticiaCell: UICollectionViewCell {
    //MARK: - Properties
    @IBOutlet weak var labelView: UILabel!
    @IBOutlet weak var imageView: UIImageView!
    @IBOutlet weak var topLabelConstraint: NSLayoutConstraint!
    @IBOutlet weak var topImageConstraint: NSLayoutConstraint!
    var imageUrlString:String?

    var contact:Noticia = Noticia(){
        didSet{
            self.labelView.text = self.contact.name

            imageUrlString = self.contact.image

            self.imageView.image = nil

            if let imageFromCache = self.contact.cachedImage(imageUrlString!){
                self.imageView.image = imageFromCache
                return
            }

            Alamofire.request(.GET, self.contact.image)
                .responseImage { response in
                    if let image = response.result.value {
                        dispatch_async(dispatch_get_main_queue(), {
                            let imageToCache = image
                            self.imageView.image = imageToCache
                            self.contact.cacheImage(imageToCache, urlString: self.contact.image)
                        })
                    }
                }
            }
    }
}

任何帮助?

1 个答案:

答案 0 :(得分:0)

在阅读了几篇文章之后,我创立了解决方案:

<强>的ViewController

    func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCellWithReuseIdentifier("Cell", forIndexPath: indexPath) as! NoticiaCell
        let cell2 = collectionView.dequeueReusableCellWithReuseIdentifier("CellBillboard", forIndexPath: indexPath) as! BillboardCell
        print("entro")
        //Billboard Cell
        if(indexPath.item == 0){
            cell2.contact = noticia[indexPath.item]
            return cell2
        }else{
            //Square News Cell
            cell.labelView.text = noticia[indexPath.item].name

            imageUrlString = noticia[indexPath.item].image

            cell.imageView.image = nil

            if let imageFromCache = noticia[indexPath.item].cachedImage(imageUrlString!){
                cell.imageView.image = imageFromCache

            }else{

                Alamofire.request(.GET, noticia[indexPath.item].image)
                    .responseImage { response in
                        if let image = response.result.value {
                            let imageToCache = image

                            if let updatedCell = collectionView.cellForItemAtIndexPath(indexPath) as? NoticiaCell{
                                updatedCell.imageView.image = imageToCache
                            }

                            self.noticia[indexPath.item].cacheImage(imageToCache, urlString: self.noticia[indexPath.item].image)

                        }
                }
            }

            cell.layer.borderColor = ConstantProjectClass.colorBorderWebBizarro.CGColor
            cell.layer.borderWidth = ConstantProjectClass.noticiasBorderWidth
            //Layout custom
            cell.setNeedsLayout()
            cell.layoutIfNeeded()
            return cell

        }
    }

密钥是以下代码:

if let updatedCell = collectionView.cellForItemAtIndexPath(indexPath) as? NoticiaCell{
    updatedCell.imageView.image = imageToCache
}