0

HEREで説明されているように、tooltipManager を使用しています。

ボタンバーのボタンにカスタム ツールチップを表示したい。

ボタンバーの宣言は次のとおりです。

<mx:ButtonBar id="topToolbar" height="30" dataProvider="{topToolbarProvider}"
            iconField="icon" itemClick="topToolbarHandler(event)"
            buttonStyleName="topButtonBarButtonStyle"
            toolTipField="tooltip"/>

ここまでは、すべて正常に動作します。ツールチップに適切なテキストが表示されます。

次に、前に引用したチュートリアルを使用してカスタム ツールチップ マネージャーを作成しました。

public class TooltipsManager
    {
        private var _customToolTip:ToolTip;

        public function TooltipsManager()
        {
        }

        public function showToolTipRight(evt:MouseEvent, text:String):void
        {
            var pt:Point = new Point(evt.currentTarget.x, evt.currentTarget.y);

            // Convert the targets 'local' coordinates to 'global' -- this fixes the
            // tooltips positioning within containers.
            pt = evt.currentTarget.parent.contentToGlobal(pt);

            customToolTip = ToolTipManager.createToolTip(text, pt.x, pt.y, "errorTipRight") as ToolTip;
            customToolTip.setStyle("borderColor", "0xababab");  

            // Move the tooltip to the right of the target
            var xOffset:int = evt.currentTarget.width + 5;//(customToolTip.width - evt.currentTarget.width) / 2;
            customToolTip.x += xOffset;        
        }

        public function showToolTipAbove(evt:MouseEvent, text:String):void
        {
            var pt:Point = new Point(evt.currentTarget.x, evt.currentTarget.y);

            // Convert the targets 'local' coordinates to 'global' -- this fixes the
            // tooltips positioning within containers.
            pt = evt.currentTarget.parent.contentToGlobal(pt);

            customToolTip = ToolTipManager.createToolTip(text, pt.x, pt.y, "errorTipAbove") as ToolTip;
            customToolTip.setStyle("borderColor", "#ababab");

            // Move tooltip below target and add some padding
            var yOffset:int =  customToolTip.height + 5;
            customToolTip.y -= yOffset;    
        }

        public function showToolTipBelow(evt:MouseEvent, text:String):void
        {

            var pt:Point = new Point(evt.currentTarget.x, evt.currentTarget.y);

            // Convert the targets 'local' coordinates to 'global' -- this fixes the
            // tooltips positioning within containers.
            pt = evt.currentTarget.parent.contentToGlobal(pt);

            customToolTip = ToolTipManager.createToolTip(text, pt.x, pt.y, "errorTipBelow") as ToolTip;
            customToolTip.setStyle("borderColor", "ababab");

            // Move tooltip below the target
            var yOffset:int =  evt.currentTarget.height + 5;
            customToolTip.y += yOffset;        
        }

        // Remove the tooltip
        public function killToolTip():void
        {
            ToolTipManager.destroyToolTip(customToolTip);
        }

        [Bindable]
        public function get customTooltip():ToolTip { return _customToolTip; }
        public function set customTooltip(t:ToolTip):void { _customToolTip = t; }

    }

さて、ここから問題が発生します...
このカスタム ツールチップを使用しようとしていますが、ボタンバーを考慮に入れる方法がわかりません。

TooltipsManager でいつ関数を呼び出せるかを確認する関数を作成しました。

public function showTopToolbarTooltip(e:ToolTipEvent):void{
            trace('blabla');
        }

しかし、それは決して考慮されていないようです。この関数をさまざまなボタンバーのイベント (tooltipcreate、tooltipstart、tooltipend) に配置しましたが、何も起こりません。痕跡一つない…

tooltipManager の関数を呼び出す場所を教えてもらえますか?

どうもありがとうございました。
よろしく、
BS_C3

4

1 に答える 1

0

実は、チュートリアルの一部を飛ばしていました =_= mouseover/out イベントに関数を追加する... 申し訳ありません。

于 2011-11-07T16:12:04.740 に答える