通过点击 SwiftUI 滑块来设置其值

bjr*_*rnt 3 slider swiftui

如何Slider通过点击 SwiftUI 来更改它的值?

bjr*_*rnt 6

这是我使用GeometryReader创建的最小实现,该实现四舍五入到最接近的值:

struct TappableSlider: View {
    var value: Binding<Float>
    var range: ClosedRange<Float>
    var step: Float

    var body: some View {
        GeometryReader { geometry in
            Slider(value: self.value, in: self.range, step: self.step)
                .gesture(DragGesture(minimumDistance: 0).onEnded { value in
                    let percent = min(max(0, Float(value.location.x / geometry.size.width * 1)), 1)
                    let newValue = self.range.lowerBound + round(percent * (self.range.upperBound - self.range.lowerBound))
                    self.value.wrappedValue = newValue
                })
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

它可以像普通滑块一样使用,例如

TappableSlider(value: $sliderValue, in: 1...7, step: 1.0)
Run Code Online (Sandbox Code Playgroud)