OSDN Git Service

バージョン表記、更新履歴更新。
[coroid/inqubus.git] / frontend / src / saccubus / MainFrame.java
index 5e7d5fb..f030853 100644 (file)
@@ -1,5 +1,6 @@
 package saccubus;
 
+import java.io.IOException;
 import saccubus.converter.Converter;
 import java.awt.BorderLayout;
 import java.awt.Dimension;
@@ -36,6 +37,7 @@ import javax.swing.JTabbedPane;
 import javax.swing.JTextField;
 import javax.swing.SwingUtilities;
 import nicobrowser.entity.NicoContent;
+import org.apache.commons.lang.StringUtils;
 import saccubus.ConvertStopFlag.State;
 import saccubus.converter.profile.FfmpegOption;
 import saccubus.converter.profile.NgSetting;
@@ -75,7 +77,7 @@ import yukihane.nicovideo.NicoDBFinder;
 public class MainFrame extends JFrame {
 
     private static final long serialVersionUID = 2564486741331062989L;
-    public static final String VERSION = "1.22r NicoBrowser\8ag\92£ 1.3.0";
+    public static final String VERSION = "1.22r NicoBrowser\8ag\92£ 1.3.5";
     public static final Image WinIcon = Toolkit.getDefaultToolkit().createImage(saccubus.MainFrame.class.getResource(
             "icon32.png"));
     JPanel contentPane;
@@ -805,63 +807,15 @@ public class MainFrame extends JFrame {
 
     public void DoButton_actionPerformed(ActionEvent e) {
         if (Converter == null || Converter.isConverted()) {
-            String url;
-
-            // NicoBrowser\83t\83@\83C\83\8b\82ð\97\98\97p\82·\82é\8fê\8d\87\82Í\81A\83t\83@\83C\83\8b\96¼\82©\82ç\83r\83f\83IID\82ð\93Á\92è.
-            if (videoSaveInfoPanel.getVideoUseNiBrButton().isSelected()) {
-                try {
-                    String fileName = videoSaveInfoPanel.getNibrFileField().getText();
-                    NicoDBFinder finder = NicoDBFinder.getInstance();
-                    NicoContent info = finder.findNicoContent(fileName);
-                    if (info != null) {
-                        url = info.getNicoId();
-                    } else {
-                        url = "";
-                    }
-                } catch (Exception ex) {
-                    JOptionPane.showMessageDialog(this, ex.getMessage(), "\83G\83\89\81[", JOptionPane.ERROR_MESSAGE);
-                    return;
+            try {
+                executeConvert();
+            } catch (Exception ex) {
+                String text = ex.getMessage();
+                if (StringUtils.isEmpty(text)) {
+                    text = "\97\\8aú\82µ\82È\82¢\83G\83\89\81[\82Ì\82½\82ß\92\86\92f\82µ\82Ü\82µ\82½\81B";
                 }
-            } else {
-                url = VideoID_TextField.getText();
+                statusBar.setText(text);
             }
-
-            TextProgressListener sl = new TextProgressListener() {
-
-                public void setText(final String text) {
-                    SwingUtilities.invokeLater(new Runnable() {
-
-                        public void run() {
-                            statusBar.setText(text);
-                        }
-                    });
-                }
-            };
-
-            ConvertStopFlag.StateChangeListener scl = new ConvertStopFlag.StateChangeListener() {
-
-                public void changeState(final State s) {
-                    SwingUtilities.invokeLater(new Runnable() {
-
-                        public void run() {
-                            switch (s) {
-                                case PROCESSING:
-                                    DoButton.setText(DoButtonStopString);
-                                    break;
-                                case STOPPING:
-                                    DoButton.setText(DoButtonWaitString);
-                                    break;
-                                case FINISHED:
-                                    DoButton.setText(DoButtonDefString);
-                            }
-                        }
-                    });
-                }
-            };
-
-            Converter = new Converter(url, WayBackField.getText(), getSetting().toProfile(), sl,
-                    new ConvertStopFlag(scl));
-            new Thread(Converter).start();
         } else { /* \8aJ\8en\82µ\82Ä\82¢\82é\82Ì\82Å\81A\83X\83g\83b\83v\82·\82é\81B */
             final ConvertStopFlag flag = Converter.getStopFlag();
             if (!flag.needStop()) { /* \82Ü\82¾\83X\83g\83b\83v\82µ\82Ä\82¢\82È\82¢\81B */
@@ -870,6 +824,65 @@ public class MainFrame extends JFrame {
         }
     }
 
+    private void executeConvert() throws IOException {
+        String url;
+
+        // NicoBrowser\83t\83@\83C\83\8b\82ð\97\98\97p\82·\82é\8fê\8d\87\82Í\81A\83t\83@\83C\83\8b\96¼\82©\82ç\83r\83f\83IID\82ð\93Á\92è.
+        if (videoSaveInfoPanel.getVideoUseNiBrButton().isSelected()) {
+            try {
+                String fileName = videoSaveInfoPanel.getNibrFileField().getText();
+                NicoDBFinder finder = NicoDBFinder.getInstance();
+                NicoContent info = finder.findNicoContent(fileName);
+                if (info != null) {
+                    url = info.getNicoId();
+                } else {
+                    url = "";
+                }
+            } catch (Exception ex) {
+                JOptionPane.showMessageDialog(this, ex.getMessage(), "\83G\83\89\81[", JOptionPane.ERROR_MESSAGE);
+                return;
+            }
+        } else {
+            url = VideoID_TextField.getText();
+        }
+
+        TextProgressListener sl = new TextProgressListener() {
+
+            public void setText(final String text) {
+                SwingUtilities.invokeLater(new Runnable() {
+
+                    public void run() {
+                        statusBar.setText(text);
+                    }
+                });
+            }
+        };
+
+        ConvertStopFlag.StateChangeListener scl = new ConvertStopFlag.StateChangeListener() {
+
+            public void changeState(final State s) {
+                SwingUtilities.invokeLater(new Runnable() {
+
+                    public void run() {
+                        switch (s) {
+                            case STOPPING:
+                                DoButton.setText(DoButtonWaitString);
+                                break;
+                            case FINISHED:
+                                DoButton.setText(DoButtonDefString);
+                        }
+                    }
+                });
+            }
+        };
+
+        Converter = new Converter(url, WayBackField.getText(), getSetting().toProfile(), sl,
+                new ConvertStopFlag(scl));
+        DoButton.setText(DoButtonStopString);
+        new Thread(Converter).start();
+
+    }
+
     /* FFmpeg\82Ö\82Ì\83p\83X */
     public void SettingFFmpegPathButton_actionPerformed(ActionEvent e) {
         showSaveDialog("FFmpeg\82Ö\82Ì\83p\83X", FFmpegPathField, false, false);