4

StageWebView Flash 显示时为白色

因此,我一直在使用Adob​​e Animate创建一个通用 Air 应用程序,该应用程序可以移植到多个平台,即 Mac、Windows 和 iOS。

它使用 StageWebView 显示嵌入在 HTML 页面上的视频,这些页面有自己的自定义 html5 视频播放器,除了一件简单但令人讨厌的事情外,一切都运行良好。

每当我显示 Stage Web View 时,您会在页面显示之前看到一闪而过的白色。

现在我最初认为这是检查 URL 加载完成或格式错误的 HTML 文档的问题,但似乎并非如此。

经过几次尝试消除该问题后,我确实注意到,如果我使用嵌入式 Air WebKit 而不是使用桌面设备中的本机 WebKit,它确实会消失。

(下面的代码)在加载时导致白色闪烁:

var webView:StageWebView = new StageWebView(true);

(下面的代码)这解决了这个问题,但是嵌入式 WebKit 不支持我的 HTML 标签,如视频和进度,并且不再正常工作。

var webView:StageWebView = new StageWebView();

来自 Adob​​e 的设置信息:

useNative :Boolean (default = false) — 当 useNative 为 false 时,AIR 中嵌入的 WebKit 版本将用作所创建 StageWebView 的源。当 useNative 为 true 时,AIR 将使用系统的默认 Web 引擎。移动平台只支持使用系统web引擎,所以在移动平台上useNative被忽略了。

令人沮丧的是,我设置了一个监听器来检查加载完成,但这并没有解决这个问题。因此,作为一种解决方法,我将显示的 StageWebView 隐藏在屏幕之外,然后在延迟后将其位置移动到我想要的位置,这不是很好。

其他尝试将其显示为小作为像素将其调整到位仍然会导致问题。

/*  Check for Stage Web View Errors */
webView.addEventListener(ErrorEvent.ERROR, onError);
function onError(e:ErrorEvent):void {
    trace("Stage Web View error: " + e);
}

/*  Function to not show Stage Web View until loaded.   */
function onCompleteHandler(e:Event):void {
    webView.assignFocus();
    // Delay the Stage Web View to fix white flash issue.
    setTimeout(callWebView,500);
    webView.removeEventListener(Event.COMPLETE,onCompleteHandler);
}

/*  Multi-Function Stage Web View Loader, Just add file path string to call */
function webviewFilePath(path:String):void {
    webView.stage = this.stage;
    // Prep filepath
    filePath = new File(new File(path).nativePath).url;
    // Load file path
    webView.loadURL(filePath);
    // Add listener for Complete URL Load then Show
    webView.addEventListener(Event.COMPLETE,onCompleteHandler);
}

/*  Function to call Stage Web View independantly so it can be delayed with a timer */
function callWebView() {
    webView.viewPort = new Rectangle(posX(viewX), posY(viewY), viewWidth, viewHeight);
}

关于如何缓解或解决问题的任何提示或提示都会很棒。

当然,如果 Adob​​e 真的更新了嵌入式 Air WebKit,这可能会首先解决整个问题,但我怀疑这很快就会发生。

部分修复

因此,当我最初加载舞台 Web 视图时问题仍然存在,但我已设法在应用程序使用期间尽量减少其外观。

问题的一个主要部分是我如何重置 StageWebView 以准备我想要加载的新页面或当我想要关闭视图时。

我在重置 StageWebView 时有点过火了,因为已知 StageWebView 中的音频即使在隐藏时也会继续播放。

/*  Function to Reset Stage Web View    */
function resetWebView():void {
    webView.loadString("<!DOCTYPE HTML><html><body></body></html>");
    //webView.viewPort = new Rectangle(0, 0, 0, 0);
    webView.stage = null;
    //webView.viewPort = null;
}

我意识到我可以简单地隐藏 StageWebView 并加载一个空白页面,同时它从视图中隐藏以停止任何音频播放。这很容易通过加载一个简单的字符串来完成。

尽管有时我仍然会看到白色闪光,但它的发生率很小。

4

1 回答 1

1
private var webView : StageWebView;

 webView  = new StageWebView( true );
 webView.stage = this.stage;
 webView.viewPort = new Rectangle( 0, 0, 1024, 768 );
于 2018-01-08T01:03:21.103 回答