android - Cordova 插件的输出延迟

标签 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);
     }
  }

我的 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);
}

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

最佳答案

你在用吗

   cordova.getThreadPool().execute(new Runnable() {
            public void run() {
                // while loop goes here
            }
        });

在下载代码的开头?

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

我认为问题在于 JavaScript 和 Java 代码 run in the same WebCore thread所以发生的事情是下载会阻止 Java 和 UI 之间的通信(例如,发送结果),直到下载完成。

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

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

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

关于android - Cordova 插件的输出延迟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15505959/

相关文章:

java - TACO Java 依赖项

ios - Worklight-如何在Objective-C中的适配器过程调用中传递参数?

ibm-mobilefirst - 对同一个集合多次调用 JSONStore.init 是否有任何负面影响

java - Android Studio - TextView 在数据库中进行更改后不更新

android - 更改样式中的单选按钮文本颜色

android - 无法在 nexus 5 marshmallow 中从 Google 照片应用中选择照片和视频

javascript - 带有 Phonegap Build 的 Childbrowser 插件 - 错误或不一致?

android - 如何重新启动 Android Activity?

javascript - 从 inAppBrowser 设置的 localStorage 值未显示在外部 - Cordova

push-notification - 工作灯 : Push notification without User ID