leeyuno
leeyuno

Reputation: 47

How can I passing data UIViewContoller from UIView in swift3

How can i passing data uiviewController from uiview

I am Using function but it was not working

protocol name is startcalldelegate and function name is startcall

UIView Code

protocol StartCallDelegate: class {
func startCall(localNickname :String, remoteNickname :String)}

class CardView: UIView {

let managedObjectContext = (UIApplication.shared.delegate as! AppDelegate).persistentContainer.viewContext

weak var delegate: CardViewDelegate?
weak var socketdelegate: StartCallDelegate?

@IBOutlet weak var UserPhoto: UIImageView!
@IBOutlet weak var UserNickName: UILabel!
@IBOutlet weak var UserAge: UILabel!
@IBOutlet weak var UserPeople: UILabel!

var localNickname: String = ""
var remoteNickname: String = ""

@IBAction func SendMessage(_ sender: Any) {
    print("SendMessage")

    //print(localNickName)
    //print(UserNickName.text!)
}

@IBAction func SendVideoCall(_ sender: Any) {
    print("SendVideoCall")

    let entityDescription = NSEntityDescription.entity(forEntityName: "Profile", in: managedObjectContext)
    let request = NSFetchRequest<NSFetchRequestResult>()
    request.entity = entityDescription

    do {
        let objects = try managedObjectContext.fetch(request)

        if objects.count > 0 {
            let match = objects[0] as! NSManagedObject
            localNickname = match.value(forKey: "nick") as! String

        } else {
            print("Nothing founded")
        }
    } catch {
        print("error")
    }

    remoteNickname = UserNickName.text!

    socketdelegate?.startCall(localNickname: localNickname, remoteNickname: remoteNickname)
    delegate?.VideoChatSegue()

}

}

UIViewcontroller Code

class ViewController: UIViewcontroller, StartCallDelegate {
 var localNickname: String = ""
 var remoteNickname: String = ""

 override func viewDidLoad() {
     super.viewDidLoad()
     print(localNickname)
     print(remoteNickname)
}

    func startCall(localNickname: String, remoteNickname: String) {
    print("Action startcall func")
    self.localNickname = localNickname
    self.remoteNickname = remoteNickname
}

startCall func not working

Upvotes: 0

Views: 577

Answers (1)

KKRocks
KKRocks

Reputation: 8322

You need to define delegate in viewcontroller' ViewDidLoad

 let objOardView = CardView() // this is only test purpose
 objOardView.socketdelegate = self

Upvotes: 1

Related Questions