4

我正在尝试更新进度对话框以增加 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
4

1 回答 1

6

你有“错字”错误。您需要将publishProgress()方法中的变量替换为downloadTotal

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

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

于 2013-04-03T16:44:47.597 回答