Другой набор всплывающих окон для другой вкладки - PullRequest
0 голосов
/ 04 октября 2011

Предположим, у меня есть приложение с вкладками.Можно ли заставить всплывающее окно появляться только на данной вкладке?Поэтому, если я изменю вкладку, всплывающее окно (-ы) будет скрыто.Пока что я не нашел никакого решения для этого.Так что любая идея будет принята с благодарностью:)

1 Ответ

1 голос
/ 04 октября 2011

Вам придется самостоятельно обрабатывать различные наборы всплывающих окон: Flex может добавлять и удалять только те всплывающие окна, которые будут отображаться на верхнем уровне вашего приложения.

РЕДАКТИРОВАТЬ: Вот маленький образец.

<?xml version="1.0"?>
<!-- containers\navigators\TNSimple.mxml -->
<s:Application
    xmlns:fx="http://ns.adobe.com/mxml/2009" 
    xmlns:mx="library://ns.adobe.com/flex/mx" 
    xmlns:s="library://ns.adobe.com/flex/spark"
    creationComplete="onCreationComplete()"
    >
    <fx:Script>
        <![CDATA[

            import mx.managers.PopUpManager;
            import spark.components.TitleWindow;
            import mx.events.IndexChangedEvent;

            private var popups:Array = [];

            private function onCreationComplete():void
            {
                popups = [[],[],[]];
            }

            private function createPopup():void
            {
                var foo:TitleWindow = new TitleWindow();

                PopUpManager.addPopUp(foo, this);

                PopUpManager.centerPopUp(foo);

                popups[nav.selectedIndex].push(foo);
            }

            private function onTabChange(event:IndexChangedEvent):void
            {
                var i:int;

                var oldArray:Array = popups[event.oldIndex];
                for (i = 0; i < oldArray.length; i++) {
                    PopUpManager.removePopUp(oldArray[i]);
                }

                var newArray:Array = popups[event.newIndex];
                for (i = 0; i < newArray.length; i++) {
                    PopUpManager.addPopUp(newArray[i], this);
                }
            }
        ]]>
    </fx:Script>
    <mx:TabNavigator id="nav" borderStyle="solid" x="50" y="50" change="onTabChange(event)">
        <mx:VBox label="Accounts" 
            width="300" 
            height="150">
            <mx:Button label="pop" click="createPopup()"/>
        </mx:VBox>

        <mx:VBox label="Stocks" 
            width="300" 
            height="150">
            <mx:Button label="pop" click="createPopup()"/>
        </mx:VBox>

        <mx:VBox label="Futures" 
            width="300" 
            height="150">
            <mx:Button label="pop" click="createPopup()"/>
        </mx:VBox>   
    </mx:TabNavigator>
</s:Application>
...