現在、私は非常に単純なGUI描画を実験しています...「エンジン」(あなたはそれをそれと呼ぶことができると思います)。その要点:
- ユーザーの要求に見舞われるFrontControllerがあります。各リクエストにはuidがあります
- 各uid(「ページ」を読む)には、その上に存在するコンポーネント(「モジュール」)の宣言があります
- コンポーネントはSpriteサブクラスであり、本質的には一意です
当然、これらのスプライトを非表示/表示する方法が必要です。現在、私はFlexがデフォルトで持っているのとほとんど同じように持っています。つまり、「コンプが表示される場所にいる場合は、作成してキャッシュし、再び表示されるたびに再利用する」という方法です。
addChild問題は、 /removeChildまたはトグルを介して-隠したり表示したりするためのより適切で効率的な方法です-visibleです。
私の見方はそれです:
- visible速くて汚い(最初のテストで)
- visible- Event.ADDEDまたはのようなバブリングイベントのチェーンを作成しません- Event.REMOVED
- 非表示のコンポーネントはマウスイベントを取得しません
したがってremoveChild、コンポーネントが画面上で不要になる(またはキャッシュが大きすぎるなど)と確信しているときに呼び出すものになります。
stackoverflow'ers / AS3に夢中になっている人々はどう思いますか?
更新:ここに良い読み物があります(グーグルを忘れました)。
私は固執しvisibleます; それは私の仕事により適しているようです。アドビによるマニュアル「フラッシュプラットフォームのパフォーマンスの最適化」(p。69は私にさらに自信を与えました。
これが私が興味のある人のために物事をテストするために立てたコードスニペットです:
package 
{
import flash.display.Sprite;
import flash.display.Stage;
import flash.events.Event;
import flash.events.KeyboardEvent;
import flash.ui.Keyboard;
import flash.utils.getTimer;
/**
 * Simple benchmark to test alternatives for hiding and showing
 * DisplayObject.
 * 
 * Use:
 * <code>
 * new DisplayBM(stage);
 * </code>
 * 
 * Hit:
 * - "1" to addChild (note that hitting it 2 times is expensive; i think
 * this is because the player has to check whether or not the comp is
 * used elsewhere)
 * - "q" to removeChild (2 times in a row will throw an exception) 
 * - "2" to set visible to true
 * - "w" to set visible to false
 * 
 * @author Vasi Grigorash
 */    
public class DisplayBM{
    public function DisplayBM(stage:Stage){
        super();
        var insts:uint = 5000;
        var v:Vector.<Sprite> = new Vector.<Sprite>(insts);
        var i:Number = v.length, s:Sprite
        while (i--){
            s = new Sprite;
            s.graphics.beginFill(Math.random() * 0xFFFFFF);
            s.graphics.drawRect(
                Math.random() * stage.stageWidth, 
                Math.random() * stage.stageHeight,
                10, 
                10
            );
            s.graphics.endFill();
            v[i] = s;
        }
        var store:Object = {};
        store[Event.ADDED] = null;
        store[Event.REMOVED] = null;
        var count:Function = function(e:Event):void{
            store[e.type]++;
        }
        var keydown:Function = function (e:KeyboardEvent):void{
            var key:String
            //clear event counts from last run
            for (key in store){
                store[key] = 0;
            }
            stage.addEventListener(Event.ADDED, count);
            stage.addEventListener(Event.REMOVED, count);
            var s0:uint = getTimer(), op:String;
            var i:Number = v.length;
            if (e.keyCode === Keyboard.NUMBER_1){
                op = 'addChild';
                while (i--){
                    stage.addChild(v[i]);
                }
            }
            if (e.keyCode === Keyboard.Q){
                op = 'removeChild';
                while (i--){
                    stage.removeChild(v[i]);
                }
            }
            if (e.keyCode === Keyboard.NUMBER_2){
                op = 'visibile';
                while (i--){
                    v[i].visible = true;
                }
            }
            if (e.keyCode === Keyboard.W){
                op = 'invisibile';
                while (i--){
                    v[i].visible = false;
                }
            }
            if (op){
                //format events
                var events:Array = [];
                for (key in store){
                    events.push(key + ' : ' + store[key])
                }
                trace(op + ' took ' + (getTimer() - s0) + ' ' + events.join(','));
            }
            stage.removeEventListener(Event.ADDED, count);
            stage.removeEventListener(Event.REMOVED, count);
        }
        //autodispatch
        stage.addEventListener(KeyboardEvent.KEY_DOWN, keydown);
    }
}
}