Форум Flasher.ru

Форум Flasher.ru (http://www.flasher.ru/forum/index.php)
-   Flex (http://www.flasher.ru/forum/forumdisplay.php?f=84)
-   -   Custom Flex Preloader (http://www.flasher.ru/forum/showthread.php?t=174017)

Varlamov_AS 16.01.2012 11:52

Custom Flex Preloader
 
Доброго времени суток.
Передо мной встала задача создания прелоадера самой флешки. Программа написана на AS 3.0/Flex без использования Movie CLip'ов. После долгих часов "чтения интернетов" получился такой вариант:
Код AS3:

package {
import flash.display.*;
import flash.events.*;
 
import mx.events.FlexEvent;
import mx.preloaders.DownloadProgressBar;
import mx.preloaders.IPreloaderDisplay;
 
public class Preloader extends DownloadProgressBar implements IPreloaderDisplay {
 
    [Embed(source="gui/progressBar/progressBarSources/background.png")]
    private var _backGround:Class;
 
    [Embed(source="gui/progressBar/progressBarSources/frontground.png")]
    private var _frontGround:Class;
 
    private var _imgBackGround:Bitmap = new _backGround;
    private var _imgFrontGround:Bitmap = new _frontGround;
 
    public function Preloader() {
        super();
    }
 
    override public function set preloader(preloader:Sprite):void {
        preloader.addEventListener(ProgressEvent.PROGRESS, handleProgress);
        preloader.addEventListener(Event.COMPLETE, handleComplete);
        preloader.addEventListener(FlexEvent.INIT_PROGRESS, handleInitProgress);
        preloader.addEventListener(FlexEvent.INIT_COMPLETE, handleInitComplete);
    }
 
    override public function initialize():void {
        this.addChild(_imgBackGround);
        this.addChild(_imgFrontGround);
        this.x = this.stage.stageWidth / 2 - _imgBackGround.width / 2;
        this.y = this.stage.stageHeight / 2 - _imgFrontGround.height / 2;
    }
 
    private function loaderCompleteHandler(event:Event):void {
        //
    }
 
    private function handleProgress(event:ProgressEvent):void {
        var percentage:Number = event.bytesLoaded / event.bytesTotal;
 
        if (percentage <= 1) {
            _imgFrontGround.scaleX = 1 - percentage;
            _imgFrontGround.x = uint(_imgBackGround.width * percentage) + 1;
        }
        if (percentage > 1)
            _imgFrontGround.visible = false;
    }
 
    private function handleComplete(event:Event):void {
    }
 
    private function handleInitProgress(event:Event):void {
    }
 
    private function handleInitComplete(event:Event):void {
        dispatchEvent(new Event(Event.COMPLETE));
    }
 
    private function handleIOError(event:IOErrorEvent):void {
    }
}
}

не могли бы вы дать какие-то советы или посоветовать какие-либо статьи, чтобы сделать наиболее качественный и эффективный прелоадер. Сам я начал изучать Flex/AS3 недавно и очень надеюсь на вашу помощь.

P.S.: используется прелоадер следующим образом:
Код AS3:

<s:Application xmlns:fx="http://ns.adobe.com/mxml/2009"
              xmlns:s="library://ns.adobe.com/flex/spark"
              xmlns:gui="gui.styles.*"
              width="760" height="730"
              backgroundColor="#001144"
              preloader="Preloader"
              addedToStage="creationCompleteHandler()">


GBee 16.01.2012 12:47

Да вроде все хорошо, кроме долгих часов поиска, а что-то не работает?

Varlamov_AS 16.01.2012 13:25

Есть некоторые проблемы.
1) Меня волнуют пустые обработчики. Мне кажется, что это угрожает стабильности.
2) Почему-то если выводить процентаж через trace, он всегда 1 (100%):
Код AS3:

private function handleProgress(event:ProgressEvent):void {
        var percentage:Number = event.bytesLoaded / event.bytesTotal;
 
        trace(percentage);
 
        if (percentage <= 1) {
            _imgFrontGround.scaleX = 1 - percentage;
            _imgFrontGround.x = uint(_imgBackGround.width * percentage) + 1;
        }
        if (percentage > 1)
            _imgFrontGround.visible = false;
    }


Astraport 16.01.2012 14:12

Цитата:

Меня волнуют пустые обработчики. Мне кажется, что это угрожает стабильности.
С чего это? Ну трейсите event.data если хотите.
Цитата:

Почему-то если выводить процентаж через trace, он всегда 1 (100%):
У Flex глобальная проблема с прелоадерами. Часто сталкивался сам и другие люди подтверждают, что прелоадер часто не выводится, особенно если размер SWF небольшой (в пределах 2 Мб). Но на пару секунд появляется просто заливка цвета бэкграунд.

GBee 16.01.2012 14:19

1) Не подписывйтесь :о)
2) Локально = моментально.

alatar 16.01.2012 14:25

Глобальная проблема с писателями прелоадеров, особенно если размер прелоадера стремится к размеру приложения.
Цитата:

1) Меня волнуют пустые обработчики.
Обрабатывайте. Почему handleInitProgress пустой? Инициализация, в зависимости от приложения, может быть достаточно продолжительной операцией. Нет обработчиков RSLEvent.
Вы для какой версии SDK писали этот прелоадер?
Цитата:

2) Почему-то если выводить процентаж через trace, он всегда 1 (100%):
Как вы это тестировали? При загрузке с винчестера?

Varlamov_AS 16.01.2012 14:35

Версия SDK: flex_sdk_4.6.0.23201B
А загружал локально, с винчестера.

alatar 16.01.2012 15:37

Цитата:

А загружал локально, с винчестера.
Это ответ на ваш второй вопрос. См. ответ GBee.
Цитата:

Версия SDK: flex_sdk_4.6.0.23201B
Обрабатывать надо все три фазы. Загрузка приложения, загрузка RSL, инициализация.
Для примера можете посмотреть код mx.preloaders.SparkDownloadProgressBar

Varlamov_AS 16.01.2012 16:35

Получатся локально я никак не смогу качественно протестировать прелоадер?
А за советы и помощь большое спасибо, буду дальше разбираться.

alatar 16.01.2012 16:41

Тестировать можно по разному. Визуально и с родным приложением в комплекте? Только с доп. инструментами, типа древнего Speed Simulator.


Часовой пояс GMT +4, время: 20:47.

Copyright © 1999-2008 Flasher.ru. All rights reserved.
Работает на vBulletin®. Copyright ©2000 - 2024, Jelsoft Enterprises Ltd. Перевод: zCarot
Администрация сайта не несёт ответственности за любую предоставленную посетителями информацию. Подробнее см. Правила.