How to call a function when a slider changes in SwiftUI

January 18, 2020
SwiftUI Swift

There are times you might want to call a function when a slider changes in SwiftUI. I did this recently to send out the slider’s value to another device when the slider is moving. I couldn’t wait to send out the final value since that would be a delayed response for the user.

After the code example, I’ll explain the three steps.

1. Declare a state variable for the value of the slider

This is the variable that the slider is currently. It needs to be declared with a State property wrapper since the value is going to change. It also needs to have a Float type since a Slider needs a Binding<Float>.

2. Create a slider with a new binding variable

In this step, we are creating a Binding variable. A Binding variable is a computed property. By creating it as the value that the slider is using, we can utilize the setter to call the function every time the value is changing.

3. Create the function to call when the slider changes value

Make sure to make the function that you need to call when the slider changes values.

If you enjoy my posts, streams, and apps, consider buying me the juice of life that is coffee.

or support my work monthly on Patreon.

Supporting me on Ko-Fi, Buy Me a Coffee, or on Patreon will have your name listed as a supporter at the end of my streams for that month and on my supporters page.