如何使用FB 4.6添加stagewebviewbridge实例

时间:2014-09-07 05:02:41

标签: actionscript-3 flex air flash-builder stagewebviewbridge

我在flash builder 4.6中使用以下代码(作为android和ios的测试移动应用程序,尝试用stagewebviewbridge替换stagewebview以利用javascript通信的好处)......

代码直接来自文档并且看起来很简单,但是webview实例没有显示,似乎我只能在控制台中显示“END_DISK_PARSING”的跟踪...

由于某种原因,DEVICE_READY的事件监听器永远不会调用onDeviceReady函数...

它不会产生任何错误,控制台只显示“End_Disk_Parsing”。我使用FB 4.6 premium,flex sdk ver 4.12并尝试在Android设备(HTC One)上进行测试,并拥有-app.xml文件中指定的Internet权限。

任何熟悉SWVBridge的人都知道我应该采取哪些不同的做法?

我已经使用了很多次的默认stagewebview,并且非常熟悉它是如何工作的,但到目前为止还无法获得stagewebviewbridge的任何舞台可见结果......

代码我使用以下:

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 个答案:

答案 0 :(得分:2)

经过一夜新的睡眠和一杯咖啡后解决了这个问题:

此代码适用于我:

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项目中处理'添加孩子'错误......首先我必须在舞台上添加'ui组件'......

// container ( IVisualElement ) for DisplayObjects
var container:UIComponent = new UIComponent();
addElement( container );

然后我们可以将child添加到该uicomponent:

container.addChild(webView);

希望这有助于其他人。