gpt4 book ai didi

swift - 如何阻止 swiftui 在 HStack 中将内容移出屏幕?

转载 作者:行者123 更新时间:2023-12-04 15:22:22 25 4
gpt4 key购买 nike

我希望 SF 图像自动转到下一行。我知道 HStack 会将内容保持在同一行上,但是我无法提出防止它离开屏幕的解决方案。我也尝试过使用几何阅读器,但这也不起作用。 /image/nLUzb.png

struct SplitTextView: View {
static let input = "B, LB, Y, RT, A, X, B, Right, X, LB, LB, LB"
let letters = input.components(separatedBy: ", ")
var body: some View {
GeometryReader { geo in
HStack (spacing: 10) {
ForEach(0..<self.letters.count) { index in
ButtonGeneratorView(buttonKey: self.letters[index])
}
}.frame(width: geo.size.width/2)
}
}
}

struct ButtonGeneratorView: View {

let buttonKey: String
let color: [String : Color] = ["Y" : Color.yellow,
"B" : Color.red,
"A" : Color.green,
"X" : Color.blue
]

var body: some View {
VStack {
if buttonKey.count == 1 {
Image(systemName: "\(buttonKey.lowercased()).circle.fill")
.font(.system(size: 32))
.foregroundColor(color["\(buttonKey)"])
}

else {
Image(systemName: "questionmark.circle.fill")//SF images for unknown
.font(.system(size: 32))
}
}
}
}

最佳答案

SwiftUI 2.0

在下面的演示中使用 LazyVGrid

demo

struct SplitTextView: View {
static let input = "B, LB, Y, RT, A, X, B, Right, X, LB, LB, LB"
let letters = input.components(separatedBy: ", ")

let layout = [
GridItem(.adaptive(minimum:32), spacing: 10)
]

var body: some View {
LazyVGrid(columns: layout, spacing: 10){
ForEach(0..<self.letters.count) { index in
ButtonGeneratorView(buttonKey: self.letters[index])
}
}
}
}

SwiftUI 1.0

没有原生的内置功能。我在SwiftUI HStack with wrap and dynamic height中提供的类似问题的解决方案, 它也可以适用于此任务。

关于swift - 如何阻止 swiftui 在 HStack 中将内容移出屏幕?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63028254/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com