Есть два способа сделать то, что вы просите. Первый - это то, что звучит так, как вы просите, второй - то, что я бы порекомендовал.
Во-первых:
Создайте приложение main.mxml, а затем создайте отдельные файлы component1.mxml и component2.mxml для каждого из ваших состояний. Затем в вашем приложении настройте его так:
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600" xmlns:local="*">
<s:states>
<s:State name="State1"/>
<s:State name="State2"/>
</s:states>
<fx:Declarations>
<!-- Place non-visual elements (e.g., services, value objects) here -->
</fx:Declarations>
<local:Component1 includeIn="State1"/>
<local:Component2 includeIn="State2"/>
</s:Application>
Второй способ, который я рекомендую из-за вашего описания приложения, разбивает его на несколько модулей SWF с помощью одного приложения SWF. Таким образом, пользователь загружает только то, что он планирует использовать. В этом сценарии сделайте то же самое, что и раньше, но создайте модули вместо компонентов.
<?xml version="1.0" encoding="utf-8"?>
<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx" minWidth="955" minHeight="600" xmlns:local="*">
<s:states>
<s:State name="State1"/>
<s:State name="State2"/>
</s:states>
<fx:Declarations>
<!-- Place non-visual elements (e.g., services, value objects) here -->
</fx:Declarations>
<mx:ModuleLoader url="Component1.swf" includeIn="State1"/>
<mx:ModuleLoader url="Component2.swf" includeIn="State2"/>
</s:Application>