MultiToggleButton
  • November 11, 2023

A UIButton subclass that implements tap-to-toggle button text. (Like the camera flash and timer buttons)

Usage


Just create it with the states, and it’s good to go:

let toggleButton = MultiToggleButton(image: myImage, states: [“First”, “Second”, “Last”])

Get and set the current state:

let state = toggleButton.currentStateIndex
toggleButton.currentStateIndex = 0

Add a tap action (in addition to the built-in state toggle):

toggleButton.action = { (sender) -> () in
doStuff(sender.currentStateIndex)
}

Set different colors for different states (nil uses the button’s tintColor):

toggleButton.colors = [nil, .gray, .red]

Set different images for different states:

toggleButton.images = [myFirstImage, mySecondImage, myLastImage]

Or do it all at once:

let toggleButton = ToggleButton(
images: [myFirstImage, mySecondImage, myLastImage],
states: [“First”, “Second”, “Last”],
colors: [nil, .gray, .red],
action: { (sender) -> () in doStuff(sender.currentStateIndex) }
)

Installation


CocoaPods:

 

pod ‘MultiToggleButton’

Legacy versions:

Swift version MultiToggleButton version
4.0 (Xcode 9.4) pod 'MultiToggleButton', '~> 1.7.1'
3 pod 'MultiToggleButton', '~> 1.5.2'
2.3 pod 'MultiToggleButton', '~> 1.4.0'

Swift Package Manager:

 

dependencies: [
.package(url: “https://github.com/yonat/MultiToggleButton”, from: “1.8.4”)
]

GitHub


View Github

#swift #toggle #uibutton
YOU MIGHT ALSO LIKE...
SwiftUI Charts

Build custom charts with SwiftUI Styles      

SwiftUICharts

A simple line and bar charting library that support accessibility written using SwiftUI.

Swipeable cards

Swipeable Cards with SwiftUI

RGStack

This UI attempts to capture the Quibi Card Stack and the associated User Interaction.

🃏 CardStack

A easy-to-use SwiftUI view for Tinder like cards on iOS, macOS & watchOS.