summaryrefslogtreecommitdiffstats
path: root/dozentenmodul/src/main/java/gui/image/FTPEditDownloader_GUI.java
diff options
context:
space:
mode:
Diffstat (limited to 'dozentenmodul/src/main/java/gui/image/FTPEditDownloader_GUI.java')
-rw-r--r--dozentenmodul/src/main/java/gui/image/FTPEditDownloader_GUI.java180
1 files changed, 118 insertions, 62 deletions
diff --git a/dozentenmodul/src/main/java/gui/image/FTPEditDownloader_GUI.java b/dozentenmodul/src/main/java/gui/image/FTPEditDownloader_GUI.java
index 42a2c20c..295c3bcc 100644
--- a/dozentenmodul/src/main/java/gui/image/FTPEditDownloader_GUI.java
+++ b/dozentenmodul/src/main/java/gui/image/FTPEditDownloader_GUI.java
@@ -62,13 +62,14 @@ public class FTPEditDownloader_GUI extends JFrame implements
/**
* Logger instance for this class.
*/
- private final static Logger LOGGER = Logger.getLogger(FTPEditDownloader_GUI.class);
-
+ private final static Logger LOGGER = Logger
+ .getLogger(FTPEditDownloader_GUI.class);
+
@SuppressWarnings("unused")
private JPanel contentPane;
private final JPanel contentPanel = new JPanel();
JLabel lblPath;
- JLabel downspeed;
+ JLabel lblDownSpeed;
User user;
JProgressBar progressBar;
String host = SessionData.session.getServerAdress();
@@ -76,23 +77,25 @@ public class FTPEditDownloader_GUI extends JFrame implements
String downloadFile = "";
static String arg = "";
DownloadTask task;
- JLabel lblBytesread;
- JLabel lblNewLabel_3;
- JLabel labelVerbleibend;
+ JLabel lblFertig;
+ JLabel lblFilesize;
+ JLabel lblVerbleibend;
JFileChooser fc;
long filesize;
double speed;
int progress = 0; // progress of download
long bytesread;
- JLabel labelZeit;
+ JLabel lblZeit;
boolean taskrun = false;
ThriftConnection con = new ThriftConnection();
Client client = models.Client.clientcon.getClient();
JButton btnZurck = new JButton("Zurück");
JButton btnDownloadStarten = new JButton("Download starten");
+ JButton btnDownloadStoppen = new JButton("Download abbrechen");
private JLabel lblAnleitung;
private boolean isCurrentlyLoading = false; // currently up or downloading
// file
+ private boolean isAborted = false; // down- or upload was manually aborted
/**
* Create the frame.
@@ -169,7 +172,8 @@ public class FTPEditDownloader_GUI extends JFrame implements
if (dir != null) {
// is selected
// create dir if it does not exists.
- if (!dir.exists()) dir.mkdirs();
+ if (!dir.exists())
+ dir.mkdirs();
lblPath.setText(dir.getAbsolutePath());
} else {
// no directory selected
@@ -223,42 +227,42 @@ public class FTPEditDownloader_GUI extends JFrame implements
lblDownloadgeschwindigkeit.setBounds(102, 275, 141, 14);
contentPanel.add(lblDownloadgeschwindigkeit);
- downspeed = new JLabel("0");
- downspeed.setBounds(374, 275, 117, 14);
- contentPanel.add(downspeed);
+ lblDownSpeed = new JLabel("0");
+ lblDownSpeed.setBounds(374, 275, 117, 14);
+ contentPanel.add(lblDownSpeed);
- JLabel lblFertig = new JLabel("Fertig:");
- lblFertig.setBounds(102, 325, 46, 14);
- contentPanel.add(lblFertig);
+ JLabel lblFertig_1 = new JLabel("Fertig:");
+ lblFertig_1.setBounds(102, 325, 46, 14);
+ contentPanel.add(lblFertig_1);
- lblBytesread = new JLabel("0");
- lblBytesread.setBounds(183, 325, 108, 14);
- contentPanel.add(lblBytesread);
+ lblFertig = new JLabel("0");
+ lblFertig.setBounds(183, 325, 108, 14);
+ contentPanel.add(lblFertig);
JLabel lblVon = new JLabel("von:");
lblVon.setBounds(318, 325, 46, 14);
contentPanel.add(lblVon);
- lblNewLabel_3 = new JLabel("0");
- lblNewLabel_3.setBounds(374, 325, 117, 14);
- contentPanel.add(lblNewLabel_3);
+ lblFilesize = new JLabel("0");
+ lblFilesize.setBounds(374, 325, 117, 14);
+ contentPanel.add(lblFilesize);
JLabel lblMbVerbleibend = new JLabel("Verbleibend:");
lblMbVerbleibend.setBounds(102, 350, 71, 14);
contentPanel.add(lblMbVerbleibend);
- labelVerbleibend = new JLabel("0");
- labelVerbleibend.setBounds(183, 350, 108, 14);
- contentPanel.add(labelVerbleibend);
+ lblVerbleibend = new JLabel("0");
+ lblVerbleibend.setBounds(183, 350, 108, 14);
+ contentPanel.add(lblVerbleibend);
JLabel lblGeschtzteVerbleibendeZeit = new JLabel(
"Geschätzte Verbleibende Zeit:");
lblGeschtzteVerbleibendeZeit.setBounds(102, 300, 150, 14);
contentPanel.add(lblGeschtzteVerbleibendeZeit);
- labelZeit = new JLabel("0");
- labelZeit.setBounds(374, 300, 117, 14);
- contentPanel.add(labelZeit);
+ lblZeit = new JLabel("0");
+ lblZeit.setBounds(374, 300, 117, 14);
+ contentPanel.add(lblZeit);
JPanel panel = new JPanel();
panel.setLayout(null);
@@ -398,6 +402,28 @@ public class FTPEditDownloader_GUI extends JFrame implements
});
lblAnleitung.setBounds(102, 448, 311, 14);
contentPanel.add(lblAnleitung);
+ btnDownloadStoppen.addActionListener(new ActionListener() {
+ public void actionPerformed(ActionEvent e) {
+
+ isAborted = true; // set flag
+ try {
+ client.DeleteFtpUser(user.userName);
+ LOGGER.info("Deleted FTP user.");
+ } catch (TException e1) {
+ // TODO Auto-generated catch block
+ e1.printStackTrace();
+ }
+ task.cancel(true);
+ resetValues();
+
+ // reset buttons
+ resetButtons();
+ }
+ });
+
+ btnDownloadStoppen.setEnabled(false);
+ btnDownloadStoppen.setBounds(305, 200, 173, 23);
+ contentPanel.add(btnDownloadStoppen);
{
JPanel buttonPane = new JPanel();
buttonPane.setBackground(UIManager.getColor("Button.background"));
@@ -440,12 +466,13 @@ public class FTPEditDownloader_GUI extends JFrame implements
dispose();
}// end else
- // always save download path
+ // always save download path
File f = new File(lblPath.getText());
if (f.isDirectory()) {
Config.setLastDownloadPath(f.toString());
} else if (f.getParentFile().isDirectory()) {
- Config.setLastDownloadPath(f.getParentFile().toString());
+ Config.setLastDownloadPath(f.getParentFile()
+ .toString());
}
Config.store();
@@ -461,6 +488,7 @@ public class FTPEditDownloader_GUI extends JFrame implements
private void buttonDownloadActionPerformed(ActionEvent event) {
+ isAborted = false;
progressBar.setValue(0);
btnDownloadStarten.setEnabled(false); // verhindert schnellen zweiten
// Klick
@@ -491,51 +519,62 @@ public class FTPEditDownloader_GUI extends JFrame implements
public void propertyChange(PropertyChangeEvent arg0) {
- progress = 0;
- if ("progress" == arg0.getPropertyName()) {
- progress = (Integer) arg0.getNewValue();
- progressBar.setValue(progress);
- }
+ if (isAborted == false) {
+ progress = 0;
+ if ("progress" == arg0.getPropertyName()) {
+ progress = (Integer) arg0.getNewValue();
+ progressBar.setValue(progress);
+ }
- if ("speed" == arg0.getPropertyName()) {
- speed = (double) arg0.getNewValue();
+ if ("speed" == arg0.getPropertyName()) {
+ speed = (double) arg0.getNewValue();
- downspeed.setText(String.valueOf(speed).substring(0,
- String.valueOf(speed).lastIndexOf(".") + 3)
- + " MB/s");
+ lblDownSpeed.setText(String.valueOf(speed).substring(0,
+ String.valueOf(speed).lastIndexOf(".") + 3)
+ + " MB/s");
+ }
- }
- if ("bytesread" == arg0.getPropertyName()) {
- bytesread = (long) arg0.getNewValue();
- lblBytesread.setText((bytesread / 1024 / 1024) + " MB");
- labelVerbleibend
- .setText(((filesize / 1024 / 1024) - (bytesread / 1024 / 1024))
- + " MB");
-
- labelZeit
- .setText(String
- .valueOf(
- ((((filesize / 1024 / 1024) - (bytesread / 1024 / 1024)) / speed) / 60) + 1)
- .substring(
- 0,
- String.valueOf(
- (((filesize / 1024 / 1024) - (bytesread / 1024 / 1024)) / speed) / 60)
- .lastIndexOf("."))
- + " Minuten");
+ // Button zum Fertigstellen freischalten, wenn 100% erreicht sind
+ if (isCurrentlyLoading() == false) {
+ // not uploading currently
+ btnDownloadStoppen.setEnabled(false);
+ } else {
+ // currently uploading, don't let user interact
+ btnDownloadStoppen.setEnabled(true);
+ }
- }
- if ("filesize" == arg0.getPropertyName()) {
- filesize = (long) arg0.getNewValue();
- lblNewLabel_3.setText((filesize / 1024 / 1024) + " MB");
+ if ("bytesread" == arg0.getPropertyName()) {
+ bytesread = (long) arg0.getNewValue();
+ lblFertig.setText((bytesread / 1024 / 1024) + " MB");
+ lblVerbleibend
+ .setText(((filesize / 1024 / 1024) - (bytesread / 1024 / 1024))
+ + " MB");
+
+ lblZeit.setText(String
+ .valueOf(
+ ((((filesize / 1024 / 1024) - (bytesread / 1024 / 1024)) / speed) / 60) + 1)
+ .substring(
+ 0,
+ String.valueOf(
+ (((filesize / 1024 / 1024) - (bytesread / 1024 / 1024)) / speed) / 60)
+ .lastIndexOf("."))
+ + " Minuten");
- }
+ }
+ if ("filesize" == arg0.getPropertyName()) {
+ filesize = (long) arg0.getNewValue();
+ lblFilesize.setText((filesize / 1024 / 1024) + " MB");
+
+ }
+ }// end if
}// end PropertyChange()
public boolean isCurrentlyLoading() {
isCurrentlyLoading = false;
- if (labelVerbleibend.getText().equals("0 MB") || labelVerbleibend.getText().equals("0")) {
+ if (lblVerbleibend.getText().equals("0 MB")
+ || lblVerbleibend.getText().equals("0")) {
isCurrentlyLoading = false;
} else {
isCurrentlyLoading = true;
@@ -543,4 +582,21 @@ public class FTPEditDownloader_GUI extends JFrame implements
return isCurrentlyLoading;
}// end isCurrentlyLoading()
+ public void resetValues() {
+ lblDownSpeed.setText("0");
+ lblZeit.setText("0");
+ lblFertig.setText("0");
+ lblFilesize.setText("0");
+ lblVerbleibend.setText("0");
+ progressBar.setValue(0);
+ }// end resetValues
+
+ public void resetButtons() {
+ // btnFinish.setEnabled(false);
+ btnDownloadStarten.setEnabled(true);
+ btnDownloadStarten.setText("Download starten");
+ btnDownloadStoppen.setEnabled(false);
+
+ }// end resetButtons
+
}// end class