我希望当我的表格视图单元格内的图像按照uigesturerecognizer的提示进行完全屏蔽时。在桌面单元内全屏显示一个图像Swift
问题是我的didSelectRowAt函数不能识别postedimage
标识符。
使用未解决的标识符 'postedImage'
如何解决此问题得到什么?
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! FeedTableViewCell
imageFiles[indexPath.row].getDataInBackground { (data, error) in
if let imageData = data {
if let downloadedImage = UIImage(data: imageData) {
cell.postedImage.image = downloadedImage
}
}
}
cell.postedImage.image = UIImage(named: "test.png")
return cell
}
func removeImage() {
let imageView = (self.view.viewWithTag(100)! as! UIImageView)
imageView.removeFromSuperview()
}
func addImageViewWithImage(image: UIImage) {
let imageView = UIImageView(frame: self.view.frame)
imageView.contentMode = .scaleAspectFit
imageView.backgroundColor = UIColor.black
imageView.image! = image
imageView.tag = 100
let dismissTap = UITapGestureRecognizer(target: self, action: #selector(self.removeImage))
dismissTap.numberOfTapsRequired = 1
imageView.addGestureRecognizer(dismissTap)
self.view.addSubview(imageView)
}
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
self.addImageViewWithImage(image: postedImage[indexPath.row])
}
份额更多的信息,如果这没有帮助。 –
这允许我打开图像,但是当我再次点击以关闭图像时,会转到数组中的下一个图像。 另外我忘了提及'imageView.image! = image'应该是'imageView.image = image'。 –
@JackRichards这是因为攻击你的didselect方法而再次触发,因为它优先于轻击手势。你将不得不添加一个不同的逻辑,基本上检查图像是否打开,如果是,然后关闭图像或任何你想做的事情。也许使用一些标志。 –