How to use the ToggleButton component (AS3/Starling version)
The ToggleButton
class is a button that may be selected and deselected when triggered. Like a button, a toggle button's skin, label, and icon can all be customized for each state, including separate styles for when the toggle button is selected and deselected.
The Basics
First, let's create a ToggleButton
control, give it a label, and add it to the display list:
var toggle:ToggleButton = new ToggleButton();
toggle.label = "Click Me";
this.addChild( toggle );
A toggle button may be selected and deselected when it is triggered, or we can change the button's selection programatically by setting the isSelected
property:
button.isSelected = true;
If we listen to the Event.CHANGE
event, we can track whether the user has triggered the button to change the selection:
toggle.addEventListener( Event.CHANGE, toggle_changeHandler );
Check for the new value of isSelected
in the listener:
function toggle_changeHandler( event:Event ):void
{
var toggle:ToggleButton = ToggleButton( event.currentTarget );
trace( "toggle.isSelected has changed:", toggle.isSelected );
}
Skinning a ToggleButton
A number of skins and styles may be customized on a toggle button, expanding on the options provided by buttons. For full details about what skin and style properties are available, see the ToggleButton
API reference. We'll look at a few of the most common properties below.
Background skins, labels, and icons
In addition to the states provided by the Button
class, the ToggleButton
class supports some extra states that will be used when the button is selected.
The defaultSelectedSkin
property works in a similar way to the defaultSkin
property from the Button
class. If the ToggleButton
is selected, and a skin isn't provided for the current state, the defaultSelectedSkin
will be used.
The same setSkinForState()
may set skins for the selected states of a ToggleButton. In addition to the states available to a regular Button
, the following states may be referenced for a ToggleButton
:
ButtonState.UP_AND_SELECTED
ButtonState.DOWN_AND_SELECTED
ButtonState.HOVER_AND_SELECTED
ButtonState.DISABLED_AND_SELECTED
Likewise, a ToggleButton
provides the defaultSelectedIcon
property for styling the icon when selected. The setIconForState()
method may also use the extra states defined above, like ButtonState.UP_AND_SELECTED
and ButtonState.DOWN_AND_SELECTED
.