gpt4 book ai didi

ios - 在collectionviewcontroller中点击图片时在detailviewcontroller中获取图片详情

转载 作者:行者123 更新时间:2023-11-28 09:09:26 24 4
gpt4 key购买 nike

我的 CollectionViewController 包含一个图像。当我在我的 CollectionViewController 中单击图像时,它会将我带到我想要编辑图像细节的 detailviewcontroller。当我输入 URL 等详细信息,然后单击后退按钮时,它应该从 URL 获取图像并替换我的 CollectionViewController 中的图像。

我有两个问题:

  • 当我在 CollectionViewController 中单击图像时,它会打开 detailviewcontroller,但它不会显示我单击的图像的 url。
  • 当我点击后退按钮时,它不会将我带回到 CollectionViewController。
import Foundation

class Photo {
var url: String = ""
var data: NSData? = nil
var Title: String = ""
var Tags: String = ""

func loadImage(completionHandler: (data: NSData?) ->Void) {
let queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_LOW, 0)
dispatch_async(queue) {
let mainQueue = dispatch_get_main_queue()
if let url = NSURL(string: self.url) {
if let data = NSData(contentsOfURL: url) {
sleep(3)
dispatch_async(mainQueue) {
self.data = data
completionHandler(data: data)
}
return
}

dispatch_async(mainQueue) {
completionHandler(data: nil)
}
}
}
}
}

细节 View Controller

import UIKit

class ViewController: UIViewController, UITextFieldDelegate {

var photo: Photo!

@IBOutlet weak var textURL: UITextField!

@IBOutlet weak var textTitle: UITextField!
@IBOutlet weak var textTags: UITextField!
@IBOutlet weak var imageView: UIImageView!

override func viewDidLoad() {
super.viewDidLoad()

// Do any additional setup after loading the view, typically from a nib.
}

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

func textFieldShouldReturn(textField: UITextField) -> Bool {
let urlString = textField.text
photo.url = urlString
let DatatoImage: (NSData?) -> Void = {
if let d = $0 {
let image = UIImage(data: d)
self.imageView.image = image
} else {
self.imageView.image = nil
}
//textField.resignFirstResponder()
}
if let d = photo.data {
DatatoImage(d)
textField.resignFirstResponder()
let image = UIImage(data: d)
self.imageView.image = image
} else {
photo.loadImage(DatatoImage)
}
return true
}
}

我的主视图 Controller

import UIKit

let reuseIdentifier = "Cell"

class PhotosCollectionViewController: UICollectionViewController {

var photos = Array<Photo>()

override func viewDidLoad() {
super.viewDidLoad()
let photo = Photo()
photo.url = "http://www.griffith.edu.au/__data/assets/image/0019/632332/gu-header-logo.png"

photos.append(photo)

// Uncomment the following line to preserve selection between presentations
// self.clearsSelectionOnViewWillAppear = false

// Register cell classes
self.collectionView!.registerClass(PhotoCollectionViewCell.self, forCellWithReuseIdentifier: reuseIdentifier)

// Do any additional setup after loading the view.
}

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

override func numberOfSectionsInCollectionView(collectionView: UICollectionView) -> Int {
//#warning Incomplete method implementation -- Return the number of sections
return 1
}


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

override func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
let cell = collectionView.dequeueReusableCellWithReuseIdentifier(reuseIdentifier, forIndexPath: indexPath) as PhotoCollectionViewCell

let photo = photos[indexPath.row]
if let d = photo.data {
let image = UIImage(data: d)
cell.imageView.image = image

photo.url = "\(photo.url)"
photo.Title = "\(photo.Title)"
} else {
photo.loadImage {
if $0 != nil {
collectionView.reloadItemsAtIndexPaths([indexPath])
}
}
}
return cell
}

// Uncomment this method to specify if the specified item should be highlighted during tracking
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
if let indexPath = sender as? NSIndexPath {
let photo = photos[indexPath.row]
}
if (segue.identifier == "showDetail") {
if let dvc = segue.destinationViewController as? ViewController {
let photo = Photo()
dvc.photo = photo
}
}
}

override func collectionView(collectionView: UICollectionView, shouldHighlightItemAtIndexPath indexPath: NSIndexPath) -> Bool {
performSegueWithIdentifier("showDetail", sender: indexPath)
return true
}

最佳答案

在您的 prepareForSegue 方法中,您有这一行,

let photo = Photo()

这会创建一个新的 Photo 对象,它不会获取您在所选单元格中显示的对象。您在 if let 语句中得到了正确的引用。使用那个(let photo = photos[indexPath.row])。

至于后退按钮,如果该后退按钮是您在推送到新 Controller 时自动获得的按钮,则您不必编写任何代码来实现它。

关于ios - 在collectionviewcontroller中点击图片时在detailviewcontroller中获取图片详情,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29775062/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com