2016-11-15 56 views
1

我正在创建从用户收集的图像数组。这个数组被用来在UICollectionView中显示图像。我正在将图像收集/存储在名为ImageStore.swift的文件中,请参阅下面的内容。另请参阅我的UICollection视图中的数组。我在数组中放置什么来传递图像?创建收集图像数组

视图控制器与UICollectionView:

class PhotosViewController: UIViewController, UICollectionViewDelegate, UICollectionViewDataSource { 
override func viewDidLoad() { 
    super.viewDidLoad() 
} 

override func viewWillAppear(animated: Bool) { 
    super.viewWillAppear(animated) 

    let layout: UICollectionViewFlowLayout = UICollectionViewFlowLayout() 
    layout.sectionInset = UIEdgeInsets(top: 20, left: 10, bottom: 10, right: 10) 
    layout.itemSize = CGSize(width: 100, height: 100) 

    let myCollectionView:UICollectionView = UICollectionView(frame: self.view.frame, collectionViewLayout: layout) 
    myCollectionView.dataSource = self 
    myCollectionView.delegate = self 
    myCollectionView.registerClass(RDCellCollectionViewCell.self, forCellWithReuseIdentifier: "MyCell") 
    myCollectionView.backgroundColor = UIColor.whiteColor() 
    self.view.addSubview(myCollectionView) 
} 

func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int { 
    return images.count 
} 

var images: [UIImage] = [ 

] 

func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell { 
    let myCell = collectionView.dequeueReusableCellWithReuseIdentifier("MyCell", forIndexPath: indexPath) as! RDCellCollectionViewCell 
    myCell.imageView.image = images[indexPath.item] 
    myCell.backgroundColor = UIColor.grayColor() 
    return myCell 
} 

func collectionView(collectionView: UICollectionView, didSelectItemAtIndexPath indexPath: NSIndexPath) 
{ 
    print("User tapped on item \(indexPath.row)") 
} 


override func didReceiveMemoryWarning() { 
    super.didReceiveMemoryWarning() 
    // Dispose of any resources that can be recreated. 
} 

}

ImageStore.swift:

class ImageStore: NSObject { 

let cache = NSCache() 

func setImage(image: UIImage, forKey key: String) { 
    cache.setObject(image, forKey: key) 

    let imageURL = imageURLForKey(key) 

    if let data = UIImageJPEGRepresentation(image, 0.5) { 
     data.writeToURL(imageURL, atomically: true) 
    } 
} 
func imageForKey(key: String) -> UIImage? { 
    if let existingImage = cache.objectForKey(key) as? UIImage { 
     return existingImage 
    } 

    let imageURL = imageURLForKey(key) 
    guard let imageFromDisk = UIImage(contentsOfFile: imageURL.path!) else { 
     return nil 
    } 

    cache.setObject(imageFromDisk, forKey: key) 
    return imageFromDisk 
} 

func deleteImageForKey(key: String) { 
    cache.removeObjectForKey(key) 

    let imageURL = imageURLForKey(key) 
    do { 
     try NSFileManager.defaultManager().removeItemAtURL(imageURL) 
    } 
    catch let deleteError { 
     print("Error removing the image from disk: \(deleteError)") 
    } 
} 

func imageURLForKey(key: String) -> NSURL { 
    let documentsDirectories = 
    NSFileManager.defaultManager().URLsForDirectory(.DocumentDirectory, inDomains: .UserDomainMask) 
    let documentDirectory = documentsDirectories.first! 

    return documentDirectory.URLByAppendingPathComponent(key) 
} 

}

详细视图控制器:

var imageStore: ImageStore! 

@IBAction func takePicture(sender: UIBarButtonItem) { 

    let imagePicker = UIImagePickerController() 

    if UIImagePickerController.isSourceTypeAvailable(.Camera) { 
     imagePicker.sourceType = .Camera 
    } else { 
     imagePicker.sourceType = .PhotoLibrary 
    } 
    imagePicker.delegate = self 

    presentViewController(imagePicker, animated: true, completion: nil) 
} 

func imagePickerController(picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String: AnyObject]) { 

    let image = info[UIImagePickerControllerOriginalImage] as! UIImage 

    imageStore.setImage(image, forKey: item.itemKey) 

    imageView.image = image 

    dismissViewControllerAnimated(true, completion: nil) 
} 
+1

请复制并过去您的代码并移除图像。 – shallowThought

+0

我复制并粘贴了代码。 – Allie

+0

^@shallowThought – Allie

回答

0

如果你想所有的图像添加到一个数组,你可以简单地这样做:

let imagesArray = [UIImage(named: "img1"), UIImage(named: "img2"), UIImage(named: "img3"), UIImage(named: "img4")] 

,如果你想添加的图像,这是你会怎么做:

imagesArray.append(UIImage(named: "imageName")) 
+0

这很容易,但我的图像正在被用户上传。我没有命名它们。 – Allie

1

用于大型数据集的最佳方法是使用SQLite数据库来存储可以通过捕获图像的时间戳进行区分的文件名。 如果您在应用程序中使用脱机功能。

1.Create table for image name 
|user_id|image_name| 
|  |   | 
|  |   | 

2.Get all image name from database for particular user and store it in Array 
3.Search for image in document directory 

    --Update or delete the image from the database and document directory according to user action 
+0

谢谢你这个好主意。我从来没有使用过SQLite数据库。你可以看看我的代码,并帮助我设置它?我不知道从哪里开始。 – Allie

+0

我提出了一个新的问题来解决这个问题。请参阅http://stackoverflow.com/questions/41042541/building-sqlite-database-with-photos – Allie