Android AsyncTask publishProgress不更新Dialog

时间:2013-04-03 16:42:22

标签: android

我正在尝试更新进度对话框以增加1-100%的内容。但是,没有任何增加。它总是只写0。虽然,我能够看到我的Log Cat中的数字打印出来,一切都在100之后结束。

有人看到我错过的东西吗?提前感谢您的任何帮助。

 private class DownLoadSigTask extends AsyncTask<String, Integer, String> {
    private final ProgressDialog dialog = new ProgressDialog(NasStorageNasList.this);
    // Set the fileName and filesize to be used later
    String fileName = (String) recordItem.get(mPresentDown).get("name");
    String filesize = (String) recordItem.get(mPresentDown).get("filesize");

    // can use UI thread here
    @Override
    protected void onPreExecute() {
        this.dialog.setMessage("Downloading " + fileName + " from the server. Please wait.");
        this.dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
        this.dialog.setCancelable(false); 
        this.dialog.setCanceledOnTouchOutside(false);
        this.dialog.show();
    }

    // automatically done on worker thread (separate from UI thread)
    @Override
    protected String doInBackground(final String... args) {
        // Here is where we need to do the downloading of the 


        try {
            File destDir = new File(LOCALDOWNROOT);
            if (!destDir.exists()) {
                destDir.mkdirs();
            }

            File outputFile = new File(destDir, fileName);
            Log.e("What is the filename path to download? ", REMOTEDOWNROOT + DATADIRECTORY + fileName);
            InputStream fis = sardine.get(REMOTEDOWNROOT + DATADIRECTORY + "/"
                    + fileName.replace(" ", "%20"));

            FileOutputStream fos = new FileOutputStream(outputFile);
            byte[] buffer = new byte[1444];
            Log.e("What is the length of the File Size? ", filesize);


            long total = 0;
            int byteread = 0;
            while ((byteread = fis.read(buffer)) != -1) {
                downloadTotal += byteread;
                // Here is the WHILE LOOP that we will want to give the user 

                publishProgress((int)(total*100/Long.parseLong(filesize)));
                Log.e("CurrentAmount Downloaded: ", String.valueOf((int)(downloadTotal*100/Long.parseLong(filesize))));
                // How can I tell the UI the downloaded percentage?
                // So, far I am updating the log cat...but nothing for the user.


                fos.write(buffer, 0, byteread);
            }
            fis.close();
            fos.close();


        } catch (IOException e) {
            e.printStackTrace();
        }


        // Just Return null because the void task
        return null;
    }
    // add in a progress bar update
    @Override
    protected void onProgressUpdate(Integer...progress) {
        this.dialog.setProgress(progress[0]);
    }

    // can use UI thread here
    @Override
    protected void onPostExecute(final String errMsg) {
        if (this.dialog.isShowing()) {
            this.dialog.dismiss();
        }

            Toast.makeText(NasStorageNasList.this, "File Download Done!",
                    Toast.LENGTH_SHORT).show();

    }
}// end DownloadSigTask

1 个答案:

答案 0 :(得分:6)

你有“拼写错误”。您需要使用 downloadTotal 替换publishProgress()方法总计变量。

publishProgress((int) (downloadTotal * 100 / Long.parseLong(filesize)));

您的变量仅在循环前分配为零,并且永远不会更改为其他值。因此,您执行的分区0 / filesize始终为0。