输出延迟了Cordova插件

Ren*_*ené 6 android cordova ibm-mobilefirst

我写了一个Cordova插件来下载文件并将其保存在数据文件夹中.除了返回值之外,一切正常.我想显示一个进度条,需要获取当前进度.这是我的代码中的相关部分:

 while ((readed = is.read(buffer)) > 0) {
     fos.write(buffer, 0, readed);
     totalReaded += readed;

     int newProgress = (int) (totalReaded*100/fileSize);
     if (newProgress != progress) {
         progress = newProgress;
         PluginResult res = new PluginResult(PluginResult.Status.OK, progress);
         res.setKeepCallback(true);
         callbackContext.sendPluginResult(res);
     }
  }
Run Code Online (Sandbox Code Playgroud)

我的JavaScript:

downloader.prototype.writeFile = function (downloaderSuccess, downloaderFailure, options) {
    cordova.exec(downloaderSuccess, downloaderFailure, "downloader", "writeFile", options);
};

function downloaderSuccess(progress) {
    WL.Logger.debug("Result: "+progress)
}

function downloaderFailure(error) {
    WL.Logger.error("Error: "+error);
}
Run Code Online (Sandbox Code Playgroud)

发生的情况是只有在下载文件才会输出进度.如果我将PluginResult.Status设置为NO_RESULT,它将不会输出任何内容.

MBi*_*lau 6

你正在用吗

   cordova.getThreadPool().execute(new Runnable() {
            public void run() {
                // while loop goes here
            }
        });
Run Code Online (Sandbox Code Playgroud)

在你的下载代码的开头?

看看src/org/apache/cordova/FileTransfer.java。这些文件几乎可以完成您正在做的事情,您可以看到它们如何发送实时进度更新,因为它们位于单独的线程中。

我认为问题在于 JavaScript 和 Java 代码都在同一个 WebCore 线程中运行,因此发生的情况是下载阻止了 Java 和 UI 之间的通信(例如,发送结果),直到下载完成。

如果您遵循该指南中关于不阻塞 WebCore 线程的建议(因此,请使用: cordova.getThreadPool().execute()),您将能够获得进度更新。

为了测试这一点,我使用了这个插件:https : //github.com/phonegap/phonegap-plugins/blob/master/Android/Downloader/Downloader.java 进行文件下载。就目前而言,此代码的行为与您的相同 - 只有在下载文件后才会发送进度更新。但是,一旦我将 downloadUrl() 方法包装在 runnable 中,它就可以正常工作,在发生时发送进度更新,而不是等到结束。

如果这有帮助,或者您是否希望我提出更好的解释,请告诉我。