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!)
}
}