DataNavigator和INavigatorLayout

时间:2013-09-16 07:47:13

标签: actionscript-3 flex flex4 flex4.5

我认为我的问题是针对高级Flex开发人员或专家。 我的任务相对简单:我需要构建某种水平的“gallery”组件,而IMGO新的Apache {4.0} SDK适用于此任务。 换句话说,我需要与具有特定INavigatorLayout的DataNavigator相同 - 与DataNavigator相同,但更简单 - 没有任何透视,但项目之间平滑过渡。可能这样的布局已经存在?

谢谢你提前。 安德鲁。

1 个答案:

答案 0 :(得分:1)

好吧,我找到了满意的解决方案,它对我有用,但主要的想法是:

package 
{
import com.greensock.TweenLite;
import spark.layouts.HorizontalLayout;
import spark.layouts.supportClasses.INavigatorLayout;
import mx.core.IVisualElement;

/**
 * @author Andrew
 */
public class LobbyNavigatorLayout3 extends HorizontalLayout implements INavigatorLayout
{
    public function LobbyNavigatorLayout3()
    {
    }


    private var _selectedElement:IVisualElement;
    public function get selectedElement() : IVisualElement
    {
        return  _selectedElement;
    }

    public function get selectedIndex() : int
    {
        return target.getElementIndex(_selectedElement);
    }

    public var ttt:Number = 0;

    public function set selectedIndex(value : int) : void
    {
        if (!target) return;
        var firstEl:IVisualElement = target.getElementAt(0);
        if (!firstEl) return;

        var shift:Number = (600 + gap) * value;

        TweenLite.to(this, 1, {ttt:shift, onUpdate:function ():void { 


            updateDisplayList(target.width, target.height);
            }} );

        _selectedElement = target.getElementAt(value);

    }


    override public function updateDisplayList(unscaledWidth : Number, unscaledHeight : Number) : void
    {
        super.updateDisplayList(unscaledWidth, unscaledHeight);
        for (var i : int = 0; i < target.numElements; i++) 
        {
            var el:IVisualElement = target.getElementAt(i);
            el.setLayoutBoundsPosition(el.x - ttt, 0);
        }
    }
}
}

需要说这是用于useVirtualLayout = false;需要一些额外的工作来解决这个问题,但现在它适合我,如果你觉得你能做到这一点 - 欢迎你!