我想在 LazyVStack 中获取视图的框架。嵌入 ScrollView 中的 LazyVStack 显示聊天消息(文本和图像)。
因为内容是动态调整大小的,所以我无法使用 GeometryReader 代理。将 GeometryReader 放入我的 LazyVStack 中会破坏布局。 (我认为是因为动态调整大小。)。
还有其他方法可以获取 LazyVStack 中视图的框架吗?
下面是我想要做的事情的简单表示。理想情况下,我希望在 MessageView 中有一个 GeometryReader,但这会扰乱垂直间距。
struct ChatView: View {
var body: some View {
GeometryReader { geometry in
ScrollView {
LazyVStack {
ForEach(messages, id: \.id) { message in
MessageView(message: message)
}
}
}
}
}
}
struct MessageView: View {
var message: Message
var body: some View {
// GeometryReader here is not possible with dynamic row heights
if message.text != nil {
Text(message.text!)
} else if message.imageData != nil {
Image(uiImage: UIImage(data: message.imageData!)) // <-- Get frame of this Image
}
}
}
将 MessageView 合并到 ChatView 中是不可取的,因为 MessageView 涉及许多视图并且需要是一个独立的结构。
你需要使用GeometryReader
在视图背景中要测量哪个帧,例如
var body: some View {
if message.text != nil {
Text(message.text!)
} else if message.imageData != nil {
Image(uiImage: UIImage(data: message.imageData!))
.background(GeometryReader { gp in
// gp.frame(in: .global) // << eg. frame in global coordinates
})
}
}
也可以看看https://stackoverflow.com/a/62466397/12299030 https://stackoverflow.com/a/62466397/12299030
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)