从SWIFTUI调用UIKit函数 [英] Call UIKIT function from SWIFTUI

查看:0
本文介绍了从SWIFTUI调用UIKit函数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个情节提要UIKit函数getAcctBalance()。在我的UIKit文件中,我显示了一个UIHostingController来加载SWIFTUI视图。在SWIFTUI视图中,我想调用我的函数getAcctBalance()。

SWIFTUI:

import SwiftUI
import SWXMLHash

struct UserDashboard: View {
    
    @ObservedObject var userModel: UserDashboardModel

    Button(action: {
       UserDashboardHostVC.getAcctBalance() //This function call is not working
    }){
       Text("Load Balance")
    }

    Text(userModel.totalBalance) //by default it is 0.0 and when button is pressed it should return 599
}

UIKit:

import UIKit

class UserDashboardModel: ObservableObject {
    @Published var totalBalance     = 0.0
}

class UserDashboardHostVC: UIViewController {
    
    var userModel = UserDashboardModel()

    override func viewDidLoad() {
        super.viewDidLoad()
        
        let controller = UIHostingController(rootView: UserDashboard(userModel: self.userModel))
        controller.view.translatesAutoresizingMaskIntoConstraints = false
        self.addChild(controller)
        self.view.addSubview(controller.view)
        controller.didMove(toParent: self)

    }
    func getAcctBalance {
        userModel.totalBalance = 599
}

推荐答案

这里有一个示例

class UserDashboardModel: ObservableObject {
    @Published var totalBalance     = 0.0
    internal var uIViewController: UserDashboardHostVC? = nil
    
    func getAcctBalance(){
        if uIViewController != nil{
            uIViewController!.getAcctBalance()
        }else{
            print("view controller is not connected")
        }
    }
}
struct UserDashboard: View {
    
    @ObservedObject var userModel: UserDashboardModel
    var body: some View{
        VStack{
            Button(action: {
                userModel.getAcctBalance() //Call shared model
            }){
                Text("Load Balance")
            }
            
            Text(userModel.totalBalance.description) //Now it will change
        }.frame(width: 400, height: 400, alignment: .center)
    }
}
class UserDashboardHostVC: UIViewController {
    
    var userModel = UserDashboardModel()
    
    override func viewDidLoad() {
        super.viewDidLoad()
        //Crucial connection
        userModel.uIViewController = self
        let controller = UIHostingController(rootView: UserDashboard(userModel: self.userModel))
        
        self.addChild(controller)
        self.view.addSubview(controller.view)
        controller.view.translatesAutoresizingMaskIntoConstraints = false
        //Update constraints per use case
        controller.view.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
        controller.view.centerYAnchor.constraint(equalTo: view.centerYAnchor).isActive = true
        controller.didMove(toParent: self)
        
    }
    func getAcctBalance() {
        userModel.totalBalance = 599
    }
}

这篇关于从SWIFTUI调用UIKit函数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆