Протокол не передается ViewController (Swift) - PullRequest
0 голосов
/ 26 апреля 2020

Итак, я определил протокол ClickableCell, который должен реагировать на жесты касания на изображении. Я хочу перенаправить на ViewController2, когда пользователь нажимает на изображение, поэтому мой подход заключается в определении протокола, передаче информации о касании в CurrentViewController и использовании протокола в CurrentViewController для перенаправления на ViewController2. Но я использовал операторы print, и он печатал только «TAP TAP TAP» и «DONE», но не часть из CurrentViewController. Может кто-нибудь помочь мне разобраться в проблеме? Спасибо!

MessageCell.swift

protocol ClickableCell {

    func onTapImage(indexPath: IndexPath)

}

class MessageCell: UITableViewCell {



    @IBOutlet weak var leftImage: UIImageView!
    var cellDelegate: ClickableCell?
      var index: IndexPath?

    override func awakeFromNib() {
        super.awakeFromNib()
        self.setupLabelTap()
    }

    @objc func imageTapped(tapGestureRecognizer: UITapGestureRecognizer){
        print("TAP TAP TAP")
        cellDelegate?.onTapImage(indexPath: index!)
        print("DONE")
    }


    func setupLabelTap() {
        let tapGestureRecognizer = UITapGestureRecognizer(target: self, action: #selector(self.imageTapped(tapGestureRecognizer:)))
        self.leftImage.isUserInteractionEnabled = true
        self.leftImage.addGestureRecognizer(tapGestureRecognizer)

    }

}

CurrentViewController

extension CurrentViewController: ClickableCell {

    func onTapImage(indexPath: IndexPath) {
        print("Doesn't Print This")

         let popOverVC = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(identifier: "nextView") as! UIViewController
        self.navigationController?.pushViewController(popOverVC, animated: true)
    }


}




Ответы [ 2 ]

1 голос
/ 26 апреля 2020

Вам нужно присвоить cellDelegate при создании ячейки

extension CurrentViewController: UITableViewDataSource {
  // other your code here

  func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
     let cell = tableView.dequeueReusableCell(withIdentifier: "your_message_cell_id", 
          for: indexPath) as! MessageCell

     /// other setup code here

     cell.cellDelegate = self // << here !!
     return cell
  }
}
0 голосов
/ 26 апреля 2020

Вам необходимо установить делегата. Основная цель шаблона делегата состоит в том, чтобы позволить объекту обмениваться данными обратно с его владельцем в отсоединенном виде.

Так в методе cellForRowAt: -

cell.delegate = self
...