Getting started with MXML in the Feathers SDK (legacy AS3/Starling version)

In the following beginner-level tutorial, we'll create our first Feathers SDK application that includes a simple Button component. We'll set some properties, listen for an event, and skin the button with a theme.

Prerequisites

  • Download the Feathers SDK, and set it up in your favorite development environment.

  • Add MetalWorksMobileTheme.swc, included with the Feathers SDK, to your project's build settings. You can find this SWC inside the Feathers SDK. Look for frameworks/themes/MetalWorksMobileTheme/MetalWorksMobileTheme.swc.

Final Result

feathers-hello-world.jpg

Walkthrough

Let's create a new project. The main MXML class will be based on the feathers.core.Application component. We'll start with the following code:

<f:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
    xmlns:f="library://ns.feathersui.com/mxml">
</f:Application>

The Feathers namespace must be included in your MXML document to add Feathers components. This identifier for this namespace is library://ns.feathersui.com/mxml. To reference a Feathers component, you must use the f: prefix before the name of the class. We're using the Application component, so the XML element should be <f:Application/>.

Theme

Next, we want to provide some skins for our components with a theme. By default, the Feathers components are not skinned. However, several example themes are included with Feathers to easily provide sample skins to all components. A theme can be instantiated by setting the theme property on the Application.

<f:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
    xmlns:f="library://ns.feathersui.com/mxml"
    theme="feathers.themes.MetalWorksMobileTheme">
</f:Application>

When a new component initializes, the theme will create appropriate skins, including backgrounds, icons, text formats, and skins for sub-components, and pass them in to each component automatically.

In the Prerequisites section above, we added MetalWorksMobileTheme.swc to our project. If the compiler gives us errors because it cannot find MetalWorksMobileTheme, we may have forgotten to add this SWC file.

Create a Button component

Let's add a Button as a child of the Application:

<f:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
    xmlns:f="library://ns.feathersui.com/mxml"
    theme="feathers.themes.MetalWorksMobileTheme">
 
    <f:Button label="Click Me"/>

</f:Application>

It's as simple as adding a <f:Button/> element as a child of the <f:Application/> element. As you can see, we've set the label property of the Button using an XML attribute.

Listen for events

Now, let's add an event listener to the button:

<f:Button label="Click Me" triggered="button_triggeredHandler(event)"/>
 
<fx:Script><![CDATA[
 
    private function button_triggeredHandler( event:Event ):void
    {
    }
 
]]></fx:Script>

Similar to setting a property, we can add an event listener using an attribute with the string value of the event's type. The value of Event.TRIGGERED constant is "triggered", so that's what we use in the MXML.

We need to define the listener in ActionScript. To add ActionScript code to an MXML class, we need to create a <fx:Script/> element. Inside this element, we can add properties and methods just like we would in an ActionScript class.

Because ActionScript code may contain characters that are not valid XML, we must add <![CDATA[ at the beginning of a script block and ]]> at the end.

We will want to refer to our button as a variable in ActionScript, so we should add an id to it:

<f:Button id="button" label="Click Me"
    triggered="button_triggeredHandler(event)"/>

Our listener function should look something like this:

private function button_triggeredHandler( event:Event ):void
{
    TextCallout.show( "Hi, I'm Feathers!\nHave a nice day.", this.button );
}

The Event.TRIGGERED listener displays a message in a TextCallout component. We've referenced the button that we created in MXML using the button variable name. The TextCallout component is automatically skinned by the theme, just like the Button.

Layouts

Finally, let's adjust the layout a bit to put the button in the center of the screen:

<f:layout>
    <f:AnchorLayout/>
</f:layout>
 
<f:Button id="button" label="Click Me"
    triggered="button_triggeredHandler(event)">
    <f:layoutData>
        <f:AnchorLayoutData horizontalCenter="0" verticalCenter="0"/>
    </f:layoutData>
</f:Button>

Previously, we learned that there are two ways to set a property of a component. The first way to set a property was to add an attribute. We've set the horizontalCenter and verticalCenter properties on an AnchorLayoutData instance in the same way.

Sometimes, it may be easier to set properties by adding child element with the property's name (prefixed by the namespace). In the code above, we set the layout property of the LayoutGroup to an AnchorLayout instance, and we set the layoutData property of the Button to an AnchorLayoutData instance.

Conclusion

That should get you started with the very basics of working with the Feathers SDK and MXML. For more detailed information about the capabilities of MXML, read The complete guide to MXML in the Feathers SDK