Пользовательский вид контейнера Swiftui с использованием UiviewResentable - Как это сделать правильно?IOS

Программируем под IOS
Ответить
Anonymous
 Пользовательский вид контейнера Swiftui с использованием UiviewResentable - Как это сделать правильно?

Сообщение Anonymous »

Swiftui scrollview отсутствует, которые мне нужны, поэтому я использовал uiviewrepresentable для создания пользовательского контейнера на основе uiscrollview . Я нашел разные уроки, показывающие, как создавать пользовательские виды контейнеров. Однако, хотя одно решение работает без каких -либо проблем, другое решение, кажется, блокирует привязки, некоторые как и я не понимаю, почему.
Итак, вопрос в том, почему ContaMerViewa работает правильно, пока ContaMerViewB Blocs> CODES -CODES/CODERES CODES ARTESE PRESTES ARTESE. об использовании uiscrollview , но проблема одинакова:

[*] Версия A создает UihostingController в координаторе, в то время как версия B использует MakeUiview для выполнения одинакового. @State Свойство.
[*] Изменения текста в ContainErviewa правильно показаны в A и B.
[*] Изменения текста в ContaMERVIEWB показаны только в A.
Таким образом, «входящие» привязки не правильно обрабатываются в codeviewb . почему?struct ContainerViewA: UIViewRepresentable {
let content: Content

@inlinable init(@ViewBuilder content: () -> Content) {
self.content = content()
}

func makeUIView(context: Context) -> UIView {
let view = UIView()

let hostingController = context.coordinator.hostingController
hostingController.view.frame = view.bounds
hostingController.view.autoresizingMask = [.flexibleWidth, .flexibleHeight]

view.addSubview(hostingController.view)

return view
}

func updateUIView(_ uiView: UIView, context: Context) {
context.coordinator.hostingController.rootView = self.content
}

func makeCoordinator() -> Coordinator {
return Coordinator(hostingController: UIHostingController(rootView: content))
}

class Coordinator: NSObject {
var hostingController: UIHostingController

init(hostingController: UIHostingController) {
self.hostingController = hostingController
}
}
}

struct ContainerViewB: UIViewRepresentable {
var content: Content

init(@ViewBuilder content: () -> Content) {
self.content = content()
}

func makeUIView(context: Context) -> UIView {
let view = UIView()

let hostingController = UIHostingController(rootView: content)
hostingController.view.frame = view.bounds
hostingController.view.autoresizingMask = [.flexibleWidth, .flexibleHeight]

view.addSubview(hostingController.view)

return view
}

func updateUIView(_ uiView: UIView, context: Context) {

}

func makeCoordinator() -> Coordinator {
Coordinator(parent: self)
}

class Coordinator: NSObject, UIScrollViewDelegate {
private var parent: ContainerViewB

init(parent: ContainerViewB) {
self.parent = parent
super.init()
}
}
}

struct ContainerTestView: View {
@State private var textA: String = ""
@State private var textB: String = ""

var body: some View {
VStack {
ContainerViewA {
TextField("TextA", text: $textA)
Text("Typed A: \(textA)")
Text("Typed B: \(textB)")
}

ContainerViewB {
TextField("TextB", text: $textB)
Text("Typed A: \(textA)")
Text("Typed B: \(textB)")
}
}
}
}


Подробнее здесь: https://stackoverflow.com/questions/795 ... -correctly
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «IOS»