iOS - Как установить imageview родительского контроллера представления через дочерний контейнер?

В настоящее время я использую контейнерное представление, и я хочу изменить значение родительского контроллера представления imageView через дочерний контроллер представления с использованием делегатов, но он всегда возвращает nil,

import UIKit

protocol updateImage {
    func userIsDone(image:UIImage)
}

class ViewController: UIViewController, updateImage{

    @IBOutlet weak var imageView:UIImageView!
    var image = UIImage(named: "hello.png")

    override func viewDidLoad() {
        super.viewDidLoad()
        self.imageView.image=self.image
    }

    func userIsDone(image: UIImage) {
        self.image=image
    }

    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {

        if segue.identifier == "containerChild"{

            let nextView = segue.destinationViewController as! ControllerChild
            nextView.image=self.image
            nextView.delegate=self
        }
    }
}

class ControllerChild:UIViewController{

    var image=UIImage(named: "newhello.png")
    var delegate: updateImage? = nil

    override func viewDidLoad() {
        super.viewDidLoad()
    }

    @IBAction func changeImage(sender:UIButton){

        if(delegate != nil){
            self.delegate!.userIsDone(self.image!)
            print("I am Called!")
        }
    }
}

1 ответ

Решение

Удалить эту строку:

nextView.image = image

И изменить userIsDone функция для:

func userIsDone(image: UIImage) {
    imageView.image = image
}

Привет

Как примечания стороны:

  • В Swift вам не нужно использовать self снаружи блоков / закрытий. Например, вам не нужно self.imageView.image = self.image -- просто imageView.image = image Сделаю.
  • Протоколы должны быть в верхнем регистре, как UpdateImage (вместо updateImage).
  • Вам не нужно это дополнительное .png чтобы ссылаться на изображения, просто название, например: "hello",

Apple описывает условные обозначения кода Swift в своей удивительной книге Swift.

Вот код, переработанный (Swift 3):

import UIKit

protocol UpdateImageProtocol {
    func userIsDone(image: UIImage)
}

class ViewController: UIViewController, UpdateImageProtocol {

    @IBOutlet weak var imageView: UIImageView!
    var image = UIImage(named: "hello")

    override func viewDidLoad() {
        super.viewDidLoad()
        userIsDone(image: image!)
    }

    func userIsDone(image: UIImage) {
        imageView.image = image
    }

    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        if segue.identifier == "containerChild" {
            let nextView = segue.destination as! ChildViewController
            nextView.delegate = self
        }
    }
}

class ChildViewController: UIViewController {

    var image = UIImage(named: "newHello")
    var delegate: UpdateImageProtocol?

    @IBAction func changeImage(sender: UIButton) {
        delegate?.userIsDone(image: image!)
    }
}
Другие вопросы по тегам