0

我有一个应用程序正在从 Web 服务器加载大量图像数据。数据通过以下方式保存到 ipad:

func saveParsedObject(objectToSave:AnyObject,dataCode:Int)
    {
        var path:String! = self.convertDataCodeToPath(dataCode)
        println( "saveParsedObject - object::\(objectToSave)")
        if NSKeyedArchiver.archiveRootObject(objectToSave, toFile: path)
        {
            println("Success writing parsed object to file!")
        }
        else
        {
            println("Unable to write parsed object to file!")
        }
    }

数据稍后打开:

func loadParsedObject(dataCode:Int) -> AnyObject?
    {
        var path:String! = self.convertDataCodeToPath(dataCode)
        println( " ****** path = \(path) ****** ")
        var dataFromDisk:AnyObject?
        dataFromDisk = NSKeyedUnarchiver.unarchiveObjectWithFile(path)
        println( " ****** dataFromDisk = \(dataFromDisk) ****** ")
        return dataFromDisk
    }

使用以下代码保存图像数据:

if let imgURLString = imageURLString
        {
            println(" ////// Image is not nil /////// ")
            let imageURL = NSURL(string: imageURLString)
            let imageData = NSData(contentsOfURL: imageURL!)

            //println(imageData)
            if let imgData = imageData
            {
                self.productImage = UIImage(data: imageData!)
            }
            else
            {
                println("Image data = nil")
                //println(productName)
            }

        }

由于数据没有保存,UIImage(contentsOfFile:String)所以当我稍后执行此操作时,它正在被缓存:

if let isProductImgNil = productModel.productImage?
        {
            println(" -- product image is not nil -- ")
// productView is my custom view for my productData which is in my productModel object
                productView.backgroundImage.image = productModel.productImage?
//productView.backgroundImage is a UIImageView
//productModel.productImage is a UIImage
        }

我找到了这些链接并尝试使用它们以使图像不被缓存。然而,问题要大得多。我需要下载一个图像,将其保存到 HDD 并加载它,contentsOfFile它接受一个字符串而不是NSData对象,我不知道如何正确执行此操作,或者即使这种方法确实有意义。

以下是链接:

(1) Swift + 从 DocumentDirectory 保存和加载图像

(2) SO:基本的UIImage内存管理

(3) SO:我的错误,但本地图像位于 .xcassets

(4) SO: Answers 说我应该做什么,我做什么,但是 UImage 不能加载 NSData 并禁用缓存

解决方案 1

结果:这就是我在开始时所做的(在(4)中解释)数据被缓存但没有加载两次,应用程序在一段时间后崩溃(在(3)中解释

上面的代码

解决方案 2

结果:数据被缓存并再次加载(甚至更糟)。崩溃的速度更快...

代码

解析时保存数据(使用链接(1)):

if let imgURLString = imageURLString
        {
            println(" ////// Image is not nil /////// ")
            let imageURL = NSURL(string: imageURLString)
            let imageData = NSData(contentsOfURL: imageURL!)

            var selectedImage = UIImage(data:imageData!)


            let fileManager = NSFileManager.defaultManager()

            var paths = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as String

            var filePathToWrite = "\(paths)/\(imageURLString.lastPathComponent)"

            var imageData1: NSData = UIImagePNGRepresentation(selectedImage)

            fileManager.createFileAtPath(filePathToWrite, contents: imageData1, attributes: nil)

            var getImagePath = paths.stringByAppendingPathComponent(imageURLString.lastPathComponent)

            finalImagePath = getImagePath

            if (fileManager.fileExistsAtPath(getImagePath))
            {
                println(" --------------- ")
                println(" Model - FILE AVAILABLE");
                println(getImagePath)
                println(" --------------- ")
                //Pick Image and Use accordingly
                //var imageis: UIImage = UIImage(contentsOfFile: getImagePath)!

                //let data: NSData = UIImagePNGRepresentation(imageis)

            }
            else
            {
                println(" Model - FILE NOT AVAILABLE");

            }

        }

并加载数据:

 let fileManager = NSFileManager.defaultManager()

    if (fileManager.fileExistsAtPath(productModel.finalImagePath!))
    {
        println("FILE AVAILABLE");
        productView.backgroundImage.image = UIImage(contentsOfFile:productModel.finalImagePath)!
    }
    else
    {
        println(" - - - - - ")
        println(productModel.finalImagePath!)
        println("FILE NOT AVAILABLE");

    }

记笔记:

productView.backgroundImage.image = UIImage(contentsOfFile:productModel.finalImagePath)!

这对缓存没有帮助......但是将图像加载到视图中。

欢迎任何建议。我将在一个较小的项目中尝试其他一些东西,因为这可能是一个项目问题。

我还将尝试实现对象池 DP,但不知何故,我认为它不会有太大帮助,因为一个类别有 202 种产品并且内存会跃升至大约 250-300 MB。如果我打开其他任何东西,我会收到内存警告。更少的内存峰值和应用程序崩溃。

我也可以尝试动态加载,因为产品正在加载到 UIScrollView 中,但这将是很多工作,因为我没有太多时间。是的,我知道我应该使用 CoreData,但我没有时间学习它。应用程序必须在大约 40 天内完成(剩下的时间不多),我是 swift 的新手 :)。谢谢你的帮助 :)。

4

1 回答 1

1

如果你没有太多时间,你应该使用SDWebImage. 它以正确的方式为您完成这一切。

于 2015-04-05T22:39:45.030 回答