How to use the TabBar component (AS3/Starling version)

The TabBar class displays a set of togglable buttons with a vertical or horizontal layout, where only one button at a time may be selected. A tab bar's tabs may be added or removed at runtime through its data provider, and the first and last tabs may be optionally styled differently. For instance, one could create a more "pill" shaped control that looks more like a segmented button bar than a set of tabs.

Screenshot of a Feathers TabBar component
A TabBar component skinned with MetalWorksMobileTheme

The Basics

First, let's create a TabBar control, set its data provider to display a few tabs, and add it to the display list:

var tabs:TabBar = new TabBar();
tabs.dataProvider = new ArrayCollection(
[
    { label: "One" },
    { label: "Two" },
    { label: "Three" },
]);
this.addChild( tabs );

The label field in each item from the data provider will set the label property on the corresponding tab. In addition to the label, you can also provide an icon for a tab by setting the defaultIcon field, which gets passed to the tab's defaultIcon property.

For full details about which properties can be set on tabs, see the description of the dataProvider property.

To know when the selected tab changes, we need to listen to Event.CHANGE:

tabs.addEventListener( Event.CHANGE, tabs_changeHandler );

A listener might look something like this:

function tabs_changeHandler( event:Event ):void
{
    var tabs:TabBar = TabBar( event.currentTarget );
    trace( "selectedIndex:", tabs.selectedIndex );
}

The selectedIndex property indicates the zero-based index of the currently selected tab.

Skinning a TabBar

Except for a couple of layout properties, most of the skinning happens on the tabs. For full details about what skin and style properties are available, see the TabBar API reference. We'll look at a few of the most common ways of styling a tab bar below.

Layout

For layout, you can set the direction property to Direction.HORIZONTAL or Direction.VERTICAL.

The gap property sets the extra space, measured in pixels, between tabs. You can also use the firstGap property to provide a different gap after the first tab, and the lastGap property to provide a different gap before the last tab.

The distributeTabSizes property controls whether the combined size of tabs fill the entire length of the TabBar or if they use the minimum space required.

Skinning the Tabs

This section only explains how to access the tab sub-components, which are simply toggle buttons. Please read How to use the ToggleButton component for full details about the skinning properties that are available on ToggleButton components.

With a Theme

If you're creating a theme, you can target the TabBar.DEFAULT_CHILD_STYLE_NAME_TAB style name.

getStyleProviderForClass( ToggleButton )
    .setFunctionForStyleName( TabBar.DEFAULT_CHILD_STYLE_NAME_TAB, setTabStyles );

The styling function might look like this:

private function setTabStyles( tab:ToggleButton ):void
{
    var skin:ImageSkin = new ImageSkin( texture );
    skin.scale9Grid = new Rectangle( 2, 3, 1, 6 );
    tab.defaultSkin = skin;
    tab.fontStyles = new TextFormat( "Helvetica", 20, 0x3c3c3c );
}

You can override the default style name to use a different one in your theme, if you prefer:

tabBar.customTabStyleName = "custom-tab";

You can set the function for the customTabStyleName like this:

getStyleProviderForClass( ToggleButton )
    .setFunctionForStyleName( "custom-tab", setCustomTabStyles );

Without a Theme

If you are not using a theme, you can use tabFactory to provide skins for the tabs:

tabBar.tabFactory = function():ToggleButton
{
    var tab:ToggleButton = new ToggleButton();

    //skin the tab here, if not using a theme
    var skin:ImageSkin = new ImageSkin( texture );
    skin.scale9Grid = new Rectangle( 2, 3, 1, 6 );
    tab.defaultSkin = skin;
    tab.fontStyles = new TextFormat( "Helvetica", 20, 0x3c3c3c );

    return tab;
};

Skinning the First and Last Tabs

This section only explains how to access the first and last tab sub-components. Please read How to use the ToggleButton component for full details about the skinning properties that are available on ToggleButton components.

The tab bar's first and last tabs will have the same skins as the other tabs by default. However, their skins may be customized separately, if desired.

For the first tab, you can customize the name with customFirstTabStyleName. If you aren't using a theme, then you can use firstTabFactory.

For the last tab, you can customize the name with customLastTabStyleName. If you aren't using a theme, then you can use lastTabFactory.

Separate skins for the first and last tabs are completely optional.