SwiftUI - 按下按钮时如何更改所有其他按钮的颜色?
Posted
技术标签:
【中文标题】SwiftUI - 按下按钮时如何更改所有其他按钮的颜色?【英文标题】:SwiftUI - How to change the colour of all other buttons when pressing on button? 【发布时间】:2019-11-07 16:02:35 【问题描述】:在我的代码下面,我有一个设置,其中有 4 个按钮,每次按下按钮时,它都充当切换按钮(如单选按钮)。我想要实现的是在按下其中一个按钮时将所有其他按钮变为灰色。一次只能有一个按钮为绿色或处于活动状态。
struct hzButton: View
var text: String
@State var didTap: Bool
var body: some View
Button(action:
if self.didTap == true
self.didTap = false
else
self.didTap = true
selectFreq(frequency: self.text)
)
Text(text)
.font(.body)
.fontWeight(.semibold)
.foregroundColor(Color.white)
.multilineTextAlignment(.center)
.padding(.all)
.background(didTap ? Color.green : Color.gray)
.cornerRadius(6.0)
.frame(width: nil)
struct Row: Identifiable
let id = UUID()
let headline: String
let numbers: [String]
struct ContentView: View
var rows = [
Row(headline: "", numbers: ["250","500","750","1000"]),
]
var body: some View
HStack
ForEach(rows) row in
HStack
ForEach(row.numbers, id: \.self) text in
hzButton(text: text, didTap: false)
【问题讨论】:
【参考方案1】:在 SwiftUI 中,一切都是由状态变化触发的。要实现单选按钮样式更改,您需要执行以下操作:
struct MyRadioButton: View
let id: Int
@Binding var currentlySelectedId: Int
var body: some View
Button(action: self.currentlySelectedId = self.id , label: Text("Tap Me!") )
.foregroundColor(id == currentlySelectedId ? .green : .red)
struct MyRadioButtons: View
@State var currentlySelectedId: Int = 0
var body: some View
VStack
MyRadioButton(id: 1, currentlySelectedId: $currentlySelectedId)
MyRadioButton(id: 2, currentlySelectedId: $currentlySelectedId)
MyRadioButton(id: 3, currentlySelectedId: $currentlySelectedId)
MyRadioButton(id: 4, currentlySelectedId: $currentlySelectedId)
当共享的 currentSelectedId 发生变化时,所有依赖于该状态的按钮都会相应更新。
【讨论】:
谢谢@Michael!我已经找了几个星期了,很高兴终于找到了!它有效,但我希望我能更好地理解它的逻辑......如果你有时间,如果你能给出更详细的解释(尤其是 @Binding 的部分),我将不胜感激,或者指出我资源更好地解释了这个概念。【参考方案2】:不要将其视为 4 个单独的按钮,每个按钮都有自己的开/关状态,而是将组视为一个整体,以及它们如何表示单个当前值状态。然后,当每个按钮在确定其背景颜色时,它可以考虑“我的值是否与当前选择的值匹配?”。因此,不要在点击按钮时切换布尔值,而是让按钮使用自己的值更新当前选择的值(在组中的所有按钮之间共享)。
【讨论】:
以上是关于SwiftUI - 按下按钮时如何更改所有其他按钮的颜色?的主要内容,如果未能解决你的问题,请参考以下文章