我希望在按uigesturerecognizer的提示进行点击时,全屏显示在表格视图单元格内的图像。

问题是我的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])
}

最佳答案

我认为您应该先检查并更改didSelect中的 call
功能来自:

override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
    self.addImageViewWithImage(image: postedImage[indexPath.row])
}


override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
    let cell = tableView.cellForRow(at: indexPath) as! FeedTableViewCell
    self.addImageViewWithImage(image: cell.postedImage.image)
}

现在,您的 addImageViewWithImage 将接受单元格中包含的ImageView中的图像。

关于ios - 点按Swift时全屏显示uitableviewcell中的图像,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/45536405/

10-14 23:16