Flex 4: определение индекса (не selectedIndex) для мыши TabBar - PullRequest
0 голосов
/ 25 апреля 2011

У меня есть приложение, в котором я пытаюсь обновить строку для свойства текста надписи, основываясь на вкладке, на которую указывает курсор мыши.Я построил простой пример, показывающий, как я буду обрабатывать функцию eventHandler, если бы я собирался использовать свойство selectedIndex, однако это вкладка с фокусом мыши, которая может быть или не быть selectedItem, чтоЯ хотел бы сослаться, и я не смог найти способ сделать это.

Итак, вот пример:

<s:Label 
    id="descriptionLabel"
    />
<s:TabBar 
    id="audioTB"
    dataProvider="{audioVS}"
    mouseOver="audioTB_mouseOverHandler(event)"
    rollOut="audioTB_rollOutHandler(event)"
    />
<mx:ViewStack 
    id="audioVS"
    >
    <!--- Menu1 -->
    <s:NavigatorContent
        id="audioNC1"
        label="Audio Menu 1"
        >
        <mx:DataGrid
            id="audioDG1"
            />
    </s:NavigatorContent>
    <!--- Menu2 -->
    <s:NavigatorContent
        id="audioNC2"
        label="Audio Menu 2"
        >
        <mx:DataGrid
            id="audioDG2"
            />
    </s:NavigatorContent>
    <!--- Menu3 -->
    <s:NavigatorContent
        id="audioNC3"
        label="Audio Menu 3"
        >
        <mx:DataGrid
            id="audioDG3"
            />
    </s:NavigatorContent>
</mx:ViewStack>
</s:Application>

Любые предложения будут с благодарностью.

Спасибо, Бенни

1 Ответ

1 голос
/ 25 апреля 2011

Я могу предложить вам решить эту проблему, используя настраиваемое событие для кнопок панели вкладок:

package 
{
    import flash.events.Event;

    public class TabButtonEvent extends Event
    {
        public static const TAB_IS_OVER:String = "tabIsOver";

        private var _tabLabel:String;

        public function TabButtonEvent(type:String, tabLabel:String)
        {
            super(type,true,false);
            this._tabLabel = tabLabel;
        }

        public function get tabLabel():String
        {
            return _tabLabel;
        }

        public override function clone():Event
        {
            return new TabButtonEvent(type,tabLabel);
        }
    }
}

Затем вы должны создать свой собственный скин кнопки панели вкладок.Хорошая новость в том, что вы можете использовать наследование:

package
{
import spark.skins.spark.TabBarButtonSkin;
import mx.events.StateChangeEvent;

public class TabBarButtonSkinExt extends TabBarButtonSkin
{
    public function TabBarButtonSkinExt()
    {
        super();
        addEventListener(StateChangeEvent.CURRENT_STATE_CHANGE, currentStateChangeHandler);
    }

    private function currentStateChangeHandler(event:StateChangeEvent):void
    {
        if (event.newState.toLowerCase().indexOf("over") > -1)
        {
            dispatchEvent(new TabButtonEvent(TabButtonEvent.TAB_IS_OVER, hostComponent.label));
        }
    }
}
}

и включить эту кнопку в скин панели вкладок (без наследования, извините):

<?xml version="1.0" encoding="utf-8"?>
<!-- TabBarSkinExt.mxml -->
<s:Skin alpha.disabled="0.5" xmlns:fx="http://ns.adobe.com/mxml/2009" xmlns:s="library://ns.adobe.com/flex/spark" 
    xmlns:fb="http://ns.adobe.com/flashbuilder/2009">
    <fx:Metadata>
        <![CDATA[ 
        /** 
         * @copy spark.skins.spark.ApplicationSkin#hostComponent
         */
        [HostComponent("spark.components.TabBar")]
        ]]>
    </fx:Metadata>
    <fx:Script fb:purpose="styling">
    <![CDATA[
        import mx.core.UIComponent;

        /**
         *  @private
         *  Push the cornerRadius style to the item renderers.
         */
        override protected function updateDisplayList(unscaledWidth:Number, unscaleHeight:Number):void
        {
            const numElements:int = dataGroup.numElements;
            const cornerRadius:int = hostComponent.getStyle("cornerRadius");
            for (var i:int = 0; i < numElements; i++)
            {
                var elt:UIComponent = dataGroup.getElementAt(i) as UIComponent;
                if (elt)
                    elt.setStyle("cornerRadius", cornerRadius);
            }

            super.updateDisplayList(unscaledWidth, unscaledHeight);
        }
    ]]>
    </fx:Script>
    <s:states>
        <s:State name="normal" />
        <s:State name="disabled" />
    </s:states>

    <!--- @copy spark.components.SkinnableDataContainer#dataGroup -->
    <s:DataGroup height="100%" id="dataGroup" width="100%">
        <s:layout>
            <s:ButtonBarHorizontalLayout gap="-1" />
        </s:layout>
        <s:itemRenderer>
            <fx:Component>
                <s:ButtonBarButton skinClass="TabBarButtonSkinExt" />
            </fx:Component>
        </s:itemRenderer>
    </s:DataGroup>
</s:Skin>

А теперь ваше приложение:

<?xml version="1.0" encoding="utf-8"?>
<s:Application minHeight="600" minWidth="955" xmlns:fx="http://ns.adobe.com/mxml/2009"
    xmlns:mx="library://ns.adobe.com/flex/mx" xmlns:s="library://ns.adobe.com/flex/spark">
    <fx:Script>
    <![CDATA[
        import mx.events.FlexEvent;

        protected function audioTB_rollOutHandler(event:MouseEvent):void
        {
            descriptionLabel.text = " ";
        }

        protected function audioTB_initializeHandler(event:FlexEvent):void
        {
            audioTB.addEventListener(TabButtonEvent.TAB_IS_OVER, audioTB_tabIsOverHandler);
        }

        private function audioTB_tabIsOverHandler(event:TabButtonEvent):void
        {
            descriptionLabel.text = event.tabLabel;
            event.stopImmediatePropagation();
        }
    ]]>
    </fx:Script>
    <s:layout>
        <s:VerticalLayout />
    </s:layout>
    <s:Label id="descriptionLabel" />
    <s:TabBar dataProvider="{audioVS}" id="audioTB"
        rollOut="audioTB_rollOutHandler(event)" skinClass="TabBarSkinExt" initialize="audioTB_initializeHandler(event)" />
    <mx:ViewStack id="audioVS">
        <!--- Menu1 -->
        <s:NavigatorContent id="audioNC1" label="Audio Menu 1">
            <mx:DataGrid id="audioDG1" />
        </s:NavigatorContent>
        <!--- Menu2 -->
        <s:NavigatorContent id="audioNC2" label="Audio Menu 2">
            <mx:DataGrid id="audioDG2" />
        </s:NavigatorContent>
        <!--- Menu3 -->
        <s:NavigatorContent id="audioNC3" label="Audio Menu 3">
            <mx:DataGrid id="audioDG3" />
        </s:NavigatorContent>
    </mx:ViewStack>
</s:Application>

Надеюсь, это поможет!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...