X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fgui%2FWebserviceInfo.java;h=b9b42dcfb2e1a3c638e7c9505c338f828fd47db6;hb=0751c58086542f9e0466201b624f84d1efd547bb;hp=2b85141b9052478d3af5bd20b84d7841597cf946;hpb=6da8d6719f9cce1221134697277c3cdc7d560d0b;p=jalview.git diff --git a/src/jalview/gui/WebserviceInfo.java b/src/jalview/gui/WebserviceInfo.java index 2b85141..b9b42dc 100644 --- a/src/jalview/gui/WebserviceInfo.java +++ b/src/jalview/gui/WebserviceInfo.java @@ -22,6 +22,7 @@ package jalview.gui; import jalview.jbgui.GWebserviceInfo; import jalview.util.MessageManager; +import jalview.util.Platform; import jalview.ws.WSClientI; import java.awt.BorderLayout; @@ -46,6 +47,8 @@ import javax.swing.JTabbedPane; import javax.swing.JTextArea; import javax.swing.event.HyperlinkEvent; import javax.swing.event.HyperlinkListener; +import javax.swing.event.InternalFrameAdapter; +import javax.swing.event.InternalFrameEvent; import javax.swing.text.html.HTMLEditorKit; import javax.swing.text.html.StyleSheet; @@ -82,7 +85,7 @@ public class WebserviceInfo extends GWebserviceInfo Image image; - int angle = 0; + float angle = 0f; String title = ""; @@ -99,7 +102,7 @@ public class WebserviceInfo extends GWebserviceInfo { super.setVisible(aFlag); frame.setVisible(aFlag); - }; + } JTabbedPane subjobs = null; @@ -257,6 +260,7 @@ public class WebserviceInfo extends GWebserviceInfo public WebserviceInfo(String title, String info, int width, int height, boolean makeVisible) { + // no references init(title, info, width, height, makeVisible); } @@ -320,7 +324,7 @@ public class WebserviceInfo extends GWebserviceInfo { frame = new JInternalFrame(); frame.setContentPane(this); - Desktop.addInternalFrame(frame, title, makeVisible, width, height); + Desktop.addInternalFrame(frame, title, makeVisible, width, height, Desktop.FRAME_ALLOW_RESIZE, Desktop.FRAME_SET_MIN_SIZE_300); frame.setClosable(false); progressBar = new ProgressBar(statusPanel, statusBar); @@ -347,16 +351,18 @@ public class WebserviceInfo extends GWebserviceInfo titlePanel.add(ap, BorderLayout.WEST); titlePanel.add(titleText, BorderLayout.CENTER); setStatus(currentStatus); - - Thread thread = new Thread(ap); - thread.start(); + if (!Platform.isJS()) + { + // No animation for the moment// + Thread thread = new Thread(ap); + thread.start(); + } final WebserviceInfo thisinfo = this; frame.addInternalFrameListener( - new javax.swing.event.InternalFrameAdapter() + new InternalFrameAdapter() { @Override - public void internalFrameClosed( - javax.swing.event.InternalFrameEvent evt) + public void internalFrameClosed(InternalFrameEvent evt) { // System.out.println("Shutting down webservice client"); WSClientI service = thisinfo.getthisService(); @@ -364,7 +370,7 @@ public class WebserviceInfo extends GWebserviceInfo { service.cancelJob(); } - }; + } }); frame.validate(); @@ -711,7 +717,7 @@ public class WebserviceInfo extends GWebserviceInfo * DOCUMENT ME! */ @Override -protected void cancel_actionPerformed(ActionEvent e) + protected void cancel_actionPerformed(ActionEvent e) { if (!serviceIsCancellable) { @@ -743,9 +749,9 @@ protected void cancel_actionPerformed(ActionEvent e) javax.swing.SwingUtilities.invokeLater(new Runnable() { @Override - public void run() + public void run() { - JvOptionPane.showInternalMessageDialog(Desktop.desktop, message, + JvOptionPane.showInternalMessageDialog(Desktop.getDesktopPane(), message, title, JvOptionPane.WARNING_MESSAGE); } @@ -797,24 +803,27 @@ protected void cancel_actionPerformed(ActionEvent e) { startTime = System.currentTimeMillis(); - float invSpeed = 30f; + float invSpeed = 15f; + float factor = 1f; while (currentStatus < STATE_STOPPED_OK) { if (currentStatus == STATE_QUEUING) { invSpeed = 25f; + factor = 1f; } else if (currentStatus == STATE_RUNNING) { invSpeed = 10f; + factor = (float) (0.5 + 1.5 + * (0.5 - (0.5 * Math.sin(3.14159 / 180 * (angle + 45))))); } try { Thread.sleep(50); - int units = (int) ((System.currentTimeMillis() - startTime) - / invSpeed); - angle += units; + float delta = (System.currentTimeMillis() - startTime) / invSpeed; + angle += delta * factor; angle %= 360; startTime = System.currentTimeMillis(); @@ -839,13 +848,14 @@ protected void cancel_actionPerformed(ActionEvent e) while (angle < 360) { + float invSpeed = 5f; + float factor = 1f; try { Thread.sleep(25); - int units = (int) ((System.currentTimeMillis() - startTime) - / 5f); - angle += units; + float delta = (System.currentTimeMillis() - startTime) / invSpeed; + angle += delta * factor; startTime = System.currentTimeMillis(); if (angle >= 360) @@ -885,9 +895,9 @@ protected void cancel_actionPerformed(ActionEvent e) if (image != null) { int x = image.getWidth(this) / 2, y = image.getHeight(this) / 2; - g.rotate(Math.toRadians(angle), x, y); + g.rotate(3.14159 / 180 * (angle), x, y); g.drawImage(image, 0, 0, this); - g.rotate(-Math.toRadians(angle), x, y); + g.rotate(-3.14159 / 180 * (angle), x, y); } } @@ -923,6 +933,12 @@ public void hyperlinkUpdate(HyperlinkEvent e) { progressBar.setProgressBar(message, id); } + + @Override + public void removeProgressBar(long id) + { + progressBar.removeProgressBar(id); + } @Override public void registerHandler(final long id,