Как использовать редактирование объекта среды из функции класса?

Я новичок в быстром программировании. Я пытался поиграть с объектом среды для обновления представлений, изменив значение объекта среды специально с помощью функции класса. У меня есть два подпредставления в представлении содержимого, так как я хочу видеть, обновляются ли оба подпредставления вместе при изменении строки в объекте среды UserData.

Однако появляется сообщение об ошибке "Поток 1: Неустранимая ошибка: не обнаружен объект ObservableObject типа UserData". View.environmentObject(_:) для UserData может отсутствовать...'

В SceneDelagate.swift я внедрил объект среды:

let userData = UserData()

window.rootViewController = UIHostingController(rootView:contentView.environmentObject(userData))

UserData.swift

final class UserData: ObservableObject {

    @Published var image: UIImage? = nil
    @Published var string  = "" 



}

StringGenerator.swift

class StringGenerator {

    @EnvironmentObject var userData: UserData


    func changeURL(){
        print("Changing string now from \(userData.string)")
        if self.userData.string == "HELLO"{
            self.userData.string = "BYE"

        }
        else{
            self.userData.string = "HELLO"
        }
        print("to \(userData.string)")
    }
}

SubView1.swift

struct SubView1: View {
    @EnvironmentObject var userData: UserData



    var body: some View {
        Text("\(userData.string)")

    }
}

SubView2.swift

struct SubView2: View {
    @EnvironmentObject var userData: UserData



    var body: some View {
        Text("\(userData.string)")

    }
}

ContentView.swift

struct ContentView: View {
    @EnvironmentObject var userData: UserData

    let stringGenerator = StringGenerator()

    var body: some View {

        VStack{

            Button(action: {
                print("Changing Text Now !")
                self.stringGenerator.changeURL()
                print("\(self.userData.string)")
            }) {
                Text("Change Text ")
            }


            SubView1()
            SubView2()


        }


    }
}

В общем, я хочу знать, как изменить объект среды с помощью функции класса.

Код вылетает, когда я его запускаю. В чем проблема?

1 ответ

Решение

Вот решение:

1) в ContentView

struct ContentView: View {
    @EnvironmentObject var userData: UserData

    let stringGenerator: StringGenerator   // declare-only

2) в генераторе

class StringGenerator {

    var userData: UserData   // just member
    init(userData: UserData) {
      self.userData = userData
    }

3) в SceneDelegate

let userData = UserData()

// inject generator via constructor with same user data
let contentView = ContentView(stringGenerator: 
                              StringGenerator(userData: userData))

window.rootViewController = UIHostingController(rootView: 
                              contentView.environmentObject(userData))
Другие вопросы по тегам