我有由UIViewRepresentable实现的UITextView。
struct CustomTextView: UIViewRepresentable {
var tmpTextVM: TmpTextViewModel
func makeUIView(context: UIViewRepresentableContext<CustomTextView>) -> UITextView {
let textView = UITextView()
textView.backgroundColor = UIColor.clear
textView.isScrollEnabled = false
textView.text = "aaaaaaaaaaaaaaaaaa"
textView.font = UIFont(name: "ArialMT", size: 20)
return textView
}
func updateUIView(_ uiView: UITextView, context: Context) {
uiView.textColor = tmpTextVM.color
}}
我想这样使用。
struct ContentView: View {
@ObservedObject var tmpTextVM: TmpTextViewModel
var body: some View {
VStack {
Button(action: {
tmpTextVM.changeColor(UIColor.red)
}){
Image(systemName:"eyedropper.full")
}
CustomTextView(tmpTextVM: tmpTextVM)
.foregroundColor(Color(tmpTextVM.color))
.frame(width:300, height: 300, alignment: .topLeading)
.border(Color.red, width: 1)
}
}
}
在iOS 13上,如果我点击按钮,则会调用updateUIView并更改该文本的颜色,但在iOS 14上不会调用updateUIView。是否有任何方法可以通过更改iOS 14上的ObservedObject来调用视图更新?
这里是TmpTextViewModel及其模型的代码。
class TmpTextViewModel: ObservableObject {
@Published private var tmpTextModel: TmpTextModel = TmpTextModel()
var color: UIColor {tmpTextModel.color}
func changeColor(_ color: UIColor) {
tmpTextModel.color = color
}
}
struct TmpTextModel {
var color:UIColor = UIColor.purple
}
你需要制作“ CustomTextView”以侦听“ TmpTextViewModel”的更改。
只需在“ CustomTextView”中将“ tmpTextVM”声明为“ @ObservedOject”即可。
struct CustomTextView: UIViewRepresentable {
@ObservedObject var tmpTextVM: TmpTextViewModel
//....
}
谢谢 !这样很好!我不明白为什么它可以在iOS13上运行...
我猜这是由于SwiftUI引擎的优化所致。
好的我明白了!谢谢你的帮助!!