Как добавить экземпляр stagewebviewbridge на сцену с FB 4.6
Я использую следующий код в Flash Builder 4.6 (в качестве тестового мобильного приложения для Android и IOS, пытаясь заменить stagewebview на stagewebviewbridge, чтобы воспользоваться преимуществами общения на JavaScript)...
Код взят непосредственно из документации и кажется прямым, но экземпляр webview не отображается, и кажется, что я могу получить только ту трассировку, где в консоли отображается "END_DISK_PARSING"...
функция onDeviceReady никогда не вызывается прослушивателем событий для DEVICE_READY по некоторым причинам...
Это не выдает никакой ошибки, и консоль показывает только "End_Disk_Parsing". Я использую FB 4.6 premium, flex sdk ver 4.12 и пытаюсь протестировать на устройстве Android (HTC One) и имею разрешение на доступ к Интернету, указанное в файле -app.xml.
Кто-нибудь знаком с SWVBridge и знает, что я должен делать по-другому здесь?
Я много раз использовал стандартное представление stagewebview и хорошо знаком с тем, как это работает, но пока не могу получить какие-либо видимые результаты на сцене с помощью stagewebviewbridge...
код Im, используя следующее:
import es.xperiments.media.StageWebViewDisk;
import es.xperiments.media.StageWebviewDiskEvent;
import es.xperiments.media.StageWebViewBridge;
import es.xperiments.media.StageWebViewBridgeEvent;
import flash.events.Event;
import flash.events.MouseEvent;
// this is our main view
public var view:StageWebViewBridge;
public function init1():void{
// init the disk filesystem
StageWebViewDisk.addEventListener( StageWebviewDiskEvent.END_DISK_PARSING, onInit );
StageWebViewDisk.setDebugMode( true );
StageWebViewDisk.initialize( stage );
}
// Fired when StageWebviewDiskEvent cache process finish
public function onInit( e:StageWebviewDiskEvent ):void{
trace( 'END_DISK_PARSING');
// create the view
view = new StageWebViewBridge( 0,0, 320,240 );
// listen StageWebViewBridgeEvent.DEVICE_READY event to be sure the communication is ok
view.addEventListener(StageWebViewBridgeEvent.DEVICE_READY, onDeviceReady );
// load a test url...
view.loadURL('http://www.google.com');
}
public function onDeviceReady( e:Event ):void{
trace('onDeviceReady\n');
// all is loaded and ok, show the view
addChild( view );
}
1 ответ
Решил это после свежей ночи сна и чашки кофе:
Этот код прекрасно работает для меня:
import es.xperiments.media.StageWebViewBridge;
import es.xperiments.media.StageWebViewBridgeEvent;
import es.xperiments.media.StageWebViewDisk;
import es.xperiments.media.StageWebviewDiskEvent;
import mx.core.UIComponent;
import flash.media.StageWebView;
import spark.events.ViewNavigatorEvent;
protected var webView:StageWebViewBridge;
protected function view1_addedToStageHandler(event:Event):void
{
// OPTIONAL BEFORE INIT OPTIONS SETTING
StageWebViewDisk.setDebugMode( true );
// if we need debug mode assign it before initializaton
// StageWebViewDisk Events. First time app launches it proceses the filesystem
// As it can take some time, depending of the filesize of the included files
// we provide 2 events to know when process start/finish
StageWebViewDisk.addEventListener(StageWebviewDiskEvent.START_DISK_PARSING, onDiskCacheStart);
StageWebViewDisk.addEventListener(StageWebviewDiskEvent.END_DISK_PARSING, onDiskCacheEnd);
StageWebViewDisk.initialize( this.stage );
}
protected function onDiskCacheStart(e:StageWebviewDiskEvent):void
{
trace("SWVD parsing started");
}
protected function onDiskCacheEnd(e:StageWebviewDiskEvent):void {
trace("SWVD parsing ended");
webView = new StageWebViewBridge(0, 50, 400, 450);
webView.addEventListener(Event.ADDED_TO_STAGE, onAddedToStage);
SWVB.addChild(webView);
}
protected function onAddedToStage(e:Event):void
{
webView.loadURL("http://www.google.com");
//webView.loadLocalURL("applink:/index.html");
}
Это также напомнило мне, как бороться с ошибками "добавления дочерних элементов" в проектах Flash Builder / as3... сначала я должен добавить "компонент пользовательского интерфейса" на сцену...
// container ( IVisualElement ) for DisplayObjects
var container:UIComponent = new UIComponent();
addElement( container );
тогда мы можем добавить дочерний элемент к этому компоненту:
container.addChild(webView);
Надеюсь, это поможет кому-то еще.