Загрузите файл, а также обновите JProgressBar

Я попробовал тональные сигналы разных методов, чтобы заставить это работать, но они либо не работают с индикатором выполнения, либо не работают так, как хотелось бы.

Я уже создал новое окно с индикатором выполнения и вам нужно создать метод, который позволит мне загрузить файл, а также обновить JProgressBar . Существует метод Apache Commons, который чрезвычайно прост в использовании для загрузки файлов, но он, похоже, не совместим с JProgressBar .

У меня также были проблемы при запуске этого в другом потоке, SwingUtilities.invokeLater , похоже, не обновляется до строки выполнения, но он работает, поскольку я могу заставить его печатать на консоли. Я даже попробовал метод progressBar.repaint() .

Так что я хотел бы это метод, который может загрузить файл, а также обновить JProgressBar , чтобы отразить статус загрузки.

Заранее спасибо! Кейр

4
nl ja de

2 ответы

На основе эта статья , я могу предложить вам написать Загрузить класс , который может легко обновить индикатор выполнения.

Это класс Загрузить :

import java.io.*;
import java.net.*;
import java.util.*;

// This class downloads a file from a URL.
class Download extends Observable implements Runnable {

// Max size of download buffer.
private static final int MAX_BUFFER_SIZE = 1024;

// These are the status names.
public static final String STATUSES[] = {"Downloading",
"Paused", "Complete", "Cancelled", "Error"};

// These are the status codes.
public static final int DOWNLOADING = 0;
public static final int PAUSED = 1;
public static final int COMPLETE = 2;
public static final int CANCELLED = 3;
public static final int ERROR = 4;

private URL url;//download URL
private int size;//size of download in bytes
private int downloaded;//number of bytes downloaded
private int status;//current status of download

// Constructor for Download.
public Download(URL url) {
    this.url = url;
    size = -1;
    downloaded = 0;
    status = DOWNLOADING;

   //Begin the download.
    download();
}

// Get this download's URL.
public String getUrl() {
    return url.toString();
}

// Get this download's size.
public int getSize() {
    return size;
}

// Get this download's progress.
public float getProgress() {
    return ((float) downloaded/size) * 100;
}

// Get this download's status.
public int getStatus() {
    return status;
}

// Pause this download.
public void pause() {
    status = PAUSED;
    stateChanged();
}

// Resume this download.
public void resume() {
    status = DOWNLOADING;
    stateChanged();
    download();
}

// Cancel this download.
public void cancel() {
    status = CANCELLED;
    stateChanged();
}

// Mark this download as having an error.
private void error() {
    status = ERROR;
    stateChanged();
}

// Start or resume downloading.
private void download() {
    Thread thread = new Thread(this);
    thread.start();
}

// Get file name portion of URL.
private String getFileName(URL url) {
    String fileName = url.getFile();
    return fileName.substring(fileName.lastIndexOf('/') + 1);
}

// Download file.
public void run() {
    RandomAccessFile file = null;
    InputStream stream = null;

    try {
       //Open connection to URL.
        HttpURLConnection connection =
                (HttpURLConnection) url.openConnection();

       //Specify what portion of file to download.
        connection.setRequestProperty("Range",
                "bytes=" + downloaded + "-");

       //Connect to server.
        connection.connect();

       //Make sure response code is in the 200 range.
        if (connection.getResponseCode()/100 != 2) {
            error();
        }

       //Check for valid content length.
        int contentLength = connection.getContentLength();
        if (contentLength < 1) {
            error();
        }

  /* Set the size for this download if it
     hasn't been already set. */
        if (size == -1) {
            size = contentLength;
            stateChanged();
        }

       //Open file and seek to the end of it.
        file = new RandomAccessFile(getFileName(url), "rw");
        file.seek(downloaded);

        stream = connection.getInputStream();
        while (status == DOWNLOADING) {
    /* Size buffer according to how much of the
       file is left to download. */
            byte buffer[];
            if (size - downloaded > MAX_BUFFER_SIZE) {
                buffer = new byte[MAX_BUFFER_SIZE];
            } else {
                buffer = new byte[size - downloaded];
            }

           //Read from server into buffer.
            int read = stream.read(buffer);
            if (read == -1)
                break;

           //Write buffer to file.
            file.write(buffer, 0, read);
            downloaded += read;
            stateChanged();
        }

  /* Change status to complete if this point was
     reached because downloading has finished. */
        if (status == DOWNLOADING) {
            status = COMPLETE;
            stateChanged();
        }
    } catch (Exception e) {
        error();
    } finally {
       //Close file.
        if (file != null) {
            try {
                file.close();
            } catch (Exception e) {}
        }

       //Close connection to server.
        if (stream != null) {
            try {
                stream.close();
            } catch (Exception e) {}
        }
    }
}

// Notify observers that this download's status has changed.
private void stateChanged() {
    setChanged();
    notifyObservers();
}
}

Как вы можете видеть, в этом классе Download есть определенные поля, такие как size и загруженные .

В другом методе вы можете написать:

JProgressBar j = new JProgressBar(0,download.getSize());

После этого вы можете запустить новый Thread , который обновляет ваш индикатор выполнения на определенном интервале, например каждые 10 мс, с

j.setValue(download.getDownloaded());

Надеюсь, это может вам помочь.

13
добавлено

загрузка файла в новый поток отлично работает:

import java.awt.BorderLayout;
import java.awt.Container;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.locks.LockSupport;

import javax.swing.BorderFactory;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JProgressBar;

/**
 * 
 * @author adyliu([email protected])
 * @since 2012-12-28
 */
public class JProgressBarDemo {

    public static void main(String[] args) {
        final JProgressBar pbFile = new JProgressBar();
        pbFile.setValue(0);
        pbFile.setMaximum(100);
        pbFile.setStringPainted(true);
        pbFile.setBorder(BorderFactory.createTitledBorder("Download file"));

        JFrame theFrame = new JFrame("ProgressBar Demo");
        theFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);

        Container contentPane = theFrame.getContentPane();
        contentPane.add(pbFile, BorderLayout.SOUTH);
        final JButton btnDownload = new JButton("Download");
        contentPane.add(btnDownload);
        final AtomicBoolean running = new AtomicBoolean(false);
        btnDownload.addActionListener(new ActionListener() {
            public void actionPerformed(ActionEvent e) {
                running.set(!running.get());
                btnDownload.setText(running.get() ? "Pause" : "Continue");
                if (running.get()) {
                    new Thread() {
                        public void run() {
                            //download file in a thread
                            int v = 0;
                            while (running.get() && v < pbFile.getMaximum()) {
                                pbFile.setValue(++v);
                                LockSupport.parkNanos(TimeUnit.MILLISECONDS.toNanos(200));
                            }
                        }
                    }.start();
                }
            }
        });
        theFrame.setSize(300, 150);
        theFrame.setLocationRelativeTo(null);
        theFrame.setVisible(true);
    }

}
4
добавлено
pro.jvm
pro.jvm
3 503 участник(ов)

Сообщество разработчиков Java Scala Kotlin Groovy Clojure Чат для нач-их: @javastart Наш сайт: projvm.com projvm.ru Наш канал: @proJVM Вакансии: @jvmjobs Конфы: @jvmconf

Java & Co
Java & Co
2 370 участник(ов)

Можно обсуждать с матом и без всё, что касается жабы, вплоть до холиваров. НЕ ИМЕЕТ ОТНОШЕНИЯ К САЙТУ JAVARUSH.RU ПРАВИЛА - https://t.me/javarush/75723 Вакансии сюда - https://telegram.me/joinchat/B7IzvUCnfo6d8t3yIxKguQ По вопросам - @thedude

learn.java
learn.java
1 888 участник(ов)

Чат для начинающих и не только Статистика: https://combot.org/chat/-1001083535868 Основной чат - @jvmchat

Java Underground
Java Underground
169 участник(ов)

https://vk.com/javatutorial

Javanese Questions
Javanese Questions
109 участник(ов)

Чат предназначен для обмена знаниями строго в формате в вопрос-ответ. Тема — Java, Kotlin и Android. Вопрос должен быть предварительно прогуглен, понятно и грамотно сформулирован, помечен хэштегами. Ответ — тем более. Куски кода размером в несколько строк можно писать прямо здесь, для больших кусков кода стоит использовать http://gist.github.com/, http://pastebin.com/, https://codeshare.io/ или любой аналогичный сервис. В некоторых случаях можно прикреплять скриншоты. Стикеры и гифки запрещены. Дополнять и уточнять вопросы и ответы — редактированием исходного сообщения. Обсуждения должны приводить к редактированию вопроса/ответа и удаляться. По хештегам можно искать существующие вопросы и овтеты: #вопрос #ответ #git #generics #java #server #awt #javafx #swing #kotlin #anko #tornadofx #ktor #android #recyclerView #performance #arch #network #permissions #storage #async