OSDN Git Service

画面のプロファイル生成処理で共通化できる部分を共通化
authoryukihane <yukihane.feather@gmail.com>
Tue, 6 Sep 2011 05:10:40 +0000 (14:10 +0900)
committeryukihane <yukihane.feather@gmail.com>
Fri, 9 Sep 2011 11:43:21 +0000 (20:43 +0900)
frontend/src/yukihane/inqubus/config/ConfigConvertProfile.java
frontend/src/yukihane/inqubus/config/ConfigFfmpegProfile.java
frontend/src/yukihane/inqubus/config/ConfigGeneralProfile.java
frontend/src/yukihane/inqubus/config/ConfigLoginProfile.java
frontend/src/yukihane/inqubus/config/ConfigProxyProfile.java
frontend/src/yukihane/inqubus/gui/MainFrame.java

index b646b2d..d90580d 100644 (file)
@@ -1,7 +1,9 @@
 package yukihane.inqubus.config;
 
 import java.io.File;
+import java.io.IOException;
 import org.apache.commons.lang.StringUtils;
+import org.apache.commons.lang.builder.ToStringBuilder;
 import saccubus.worker.profile.ConvertProfile;
 import saccubus.worker.profile.FfmpegProfile;
 import saccubus.worker.profile.GeneralProfile;
@@ -29,7 +31,7 @@ public abstract class ConfigConvertProfile implements ConvertProfile {
     private final int maxNumOfComment;
     private final HideCondition ngSetting;
 
-    public ConfigConvertProfile() {
+    public ConfigConvertProfile() throws IOException {
         final Config p = Config.INSTANCE;
         this.generalProfile = new ConfigGeneralProfile();
         this.ffmpegProfile = new ConfigFfmpegProfile();
@@ -131,6 +133,11 @@ public abstract class ConfigConvertProfile implements ConvertProfile {
     public HideCondition getNgSetting() {
         return ngSetting;
     }
+
+    @Override
+    public String toString() {
+        return ToStringBuilder.reflectionToString(this);
+    }
 }
 
 class ConfigHideCondition implements ConvertProfile.HideCondition {
@@ -153,4 +160,9 @@ class ConfigHideCondition implements ConvertProfile.HideCondition {
     public String getId() {
         return id;
     }
+
+    @Override
+    public String toString() {
+        return ToStringBuilder.reflectionToString(this);
+    }
 }
index e1ef96b..2accf35 100644 (file)
@@ -1,5 +1,9 @@
 package yukihane.inqubus.config;
 
+import java.io.File;
+import java.io.IOException;
+import org.apache.commons.lang.builder.ToStringBuilder;
+import saccubus.FfmpegOption;
 import saccubus.worker.profile.FfmpegProfile;
 
 /**
@@ -12,67 +16,87 @@ public class ConfigFfmpegProfile implements FfmpegProfile {
     private final String inOption;
     private final String mainOption;
     private final String outOption;
-    private final String avFilterOption;
+    private final String avOption;
     private final boolean resize;
     private final int resizeWidth;
     private final int resizeHeight;
     private final boolean adjustRatio;
 
-    public ConfigFfmpegProfile() {
+    public ConfigFfmpegProfile() throws IOException {
         final Config p = Config.INSTANCE;
-        this.extOption = p.getFfmpegExtension();
-        this.inOption = p.getFfmpegInOption();
-        this.mainOption = p.getFfmpegMainOption();
-        this.outOption = p.getFfmpegOutOption();
-        this.avFilterOption = p.getFfmpegAvOption();
-        this.resize = p.getFfmpegResizeEnable();
-        this.resizeWidth = Integer.parseInt(p.getFfmpegResizeWidth());
-        this.resizeHeight = Integer.parseInt(p.getFfmpegResizeHeight());
-        this.adjustRatio = p.getFfmpegKeepAspect();
+
+        if (p.getFfmpegOptionFile() != null) {
+            final File file = new File(p.getFfmpegOptionFile());
+            final FfmpegOption ffop = FfmpegOption.load(file);
+            this.extOption = ffop.getExtOption();
+            this.inOption = ffop.getInOption();
+            this.mainOption = ffop.getMainOption();
+            this.outOption = ffop.getMainOption();
+            this.avOption = ffop.getAvfilterOption();
+            this.resize = ffop.isResize();
+            this.resizeWidth = ffop.getResizeWidth();
+            this.resizeHeight = ffop.getResizeHeight();
+            this.adjustRatio = ffop.isAdjustRatio();
+        } else {
+            this.extOption = p.getFfmpegExtension();
+            this.inOption = p.getFfmpegInOption();
+            this.mainOption = p.getFfmpegMainOption();
+            this.outOption = p.getFfmpegOutOption();
+            this.avOption = p.getFfmpegAvOption();
+            this.resize = p.getFfmpegResizeEnable();
+            this.resizeWidth = Integer.parseInt(p.getFfmpegResizeWidth());
+            this.resizeHeight = Integer.parseInt(p.getFfmpegResizeHeight());
+            this.adjustRatio = p.getFfmpegKeepAspect();
+        }
     }
 
     @Override
     public String getExtOption() {
-        return extOption;
+        return this.extOption;
     }
 
     @Override
     public String getInOption() {
-        return inOption;
+        return this.inOption;
     }
 
     @Override
     public String getMainOption() {
-        return mainOption;
+        return this.mainOption;
     }
 
     @Override
     public String getOutOption() {
-        return outOption;
+        return this.outOption;
     }
 
     @Override
     public String getAvfilterOption() {
-        return avFilterOption;
+        return this.avOption;
     }
 
     @Override
     public boolean isResize() {
-        return resize;
+        return this.resize;
     }
 
     @Override
     public int getResizeWidth() {
-        return resizeWidth;
+        return this.resizeWidth;
     }
 
     @Override
     public int getResizeHeight() {
-        return resizeHeight;
+        return this.resizeHeight;
     }
 
     @Override
     public boolean isAdjustRatio() {
-        return adjustRatio;
+        return this.adjustRatio;
+    }
+
+    @Override
+    public String toString() {
+        return ToStringBuilder.reflectionToString(this);
     }
-}
+}
\ No newline at end of file
index e9cae1b..23484b5 100644 (file)
@@ -1,5 +1,6 @@
 package yukihane.inqubus.config;
 
+import org.apache.commons.lang.builder.ToStringBuilder;
 import saccubus.worker.profile.GeneralProfile;
 
 /**
@@ -19,11 +20,16 @@ public class ConfigGeneralProfile implements GeneralProfile {
 
     @Override
     public String getReplaceFrom() {
-        return replaceFrom;
+        return this.replaceFrom;
     }
 
     @Override
     public String getReplaceTo() {
-        return replaceTo;
+        return this.replaceTo;
+    }
+
+    @Override
+    public String toString() {
+        return ToStringBuilder.reflectionToString(this);
     }
 }
index d9e93de..9f5f7bb 100644 (file)
@@ -1,5 +1,6 @@
 package yukihane.inqubus.config;
 
+import org.apache.commons.lang.builder.ToStringBuilder;
 import saccubus.worker.profile.LoginProfile;
 
 /**
@@ -13,17 +14,22 @@ public class ConfigLoginProfile implements LoginProfile {
 
     public ConfigLoginProfile() {
         final Config p = Config.INSTANCE;
-        this.mail = p.getPassword();
+        this.mail = p.getId();
         this.password = p.getPassword();
     }
 
     @Override
     public String getMail() {
-        return mail;
+        return this.mail;
     }
 
     @Override
     public String getPassword() {
-        return password;
+        return this.password;
+    }
+
+    @Override
+    public String toString() {
+        return ToStringBuilder.reflectionToString(this);
     }
 }
index fbecdaf..cac447d 100644 (file)
@@ -1,5 +1,7 @@
 package yukihane.inqubus.config;
 
+import org.apache.commons.lang.StringUtils;
+import org.apache.commons.lang.builder.ToStringBuilder;
 import saccubus.worker.profile.ProxyProfile;
 
 /**
@@ -14,23 +16,29 @@ public class ConfigProxyProfile implements ProxyProfile {
 
     public ConfigProxyProfile() {
         final Config p = Config.INSTANCE;
-        use = p.getProxyUse();
-        host = p.getProxyHost();
-        port = Integer.parseInt(p.getProxyPort());
+        this.use = p.getProxyUse();
+        this.host = p.getProxyHost();
+        final String pp = p.getProxyPort();
+        this.port = StringUtils.isBlank(pp) ? -1 : Integer.parseInt(pp);
     }
 
     @Override
     public boolean use() {
-        return use;
+        return this.use;
     }
 
     @Override
     public String getHost() {
-        return host;
+        return this.host;
     }
 
     @Override
     public int getPort() {
-        return port;
+        return this.port;
+    }
+
+    @Override
+    public String toString() {
+        return ToStringBuilder.reflectionToString(this);
     }
 }
index c441f60..cd1d91f 100644 (file)
@@ -61,16 +61,9 @@ import javax.swing.TransferHandler;
 import javax.swing.WindowConstants;
 import javax.swing.border.BevelBorder;
 import org.apache.commons.configuration.ConfigurationException;
-import org.apache.commons.lang.StringUtils;
 import org.apache.commons.lang.builder.ToStringBuilder;
-import saccubus.FfmpegOption;
 import saccubus.MainFrame_AboutBox;
 import saccubus.util.WayBackTimeParser;
-import saccubus.worker.impl.convert.ConvertProgress;
-import saccubus.worker.impl.download.DownloadProgress;
-import saccubus.worker.WorkerListener;
-import saccubus.worker.impl.convert.ConvertResult;
-import saccubus.worker.impl.download.DownloadResult;
 import saccubus.worker.profile.CommentProfile;
 import saccubus.worker.profile.ConvertProfile;
 import saccubus.worker.profile.DownloadProfile;
@@ -82,6 +75,13 @@ import saccubus.worker.profile.ProxyProfile;
 import saccubus.worker.profile.VideoProfile;
 import yukihane.Util;
 import yukihane.inqubus.config.Config;
+import yukihane.inqubus.config.ConfigCommentProfile;
+import yukihane.inqubus.config.ConfigConvertProfile;
+import yukihane.inqubus.config.ConfigFfmpegProfile;
+import yukihane.inqubus.config.ConfigGeneralProfile;
+import yukihane.inqubus.config.ConfigLoginProfile;
+import yukihane.inqubus.config.ConfigOutputProfile;
+import yukihane.inqubus.config.ConfigProxyProfile;
 import yukihane.inqubus.filewatch.FileWatch;
 import yukihane.inqubus.filewatch.FileWatchUtil;
 import yukihane.inqubus.manager.RequestProcess;
@@ -870,11 +870,11 @@ public class MainFrame extends JFrame {
         private final GeneralProfile generalProfile;
 
         private InqubusDownloadProfile() {
-            this.loginProfile = new InqubusLoginProfile();
-            this.proxyProfile = new InqubusProxyProfile();
+            this.loginProfile = new ConfigLoginProfile();
+            this.proxyProfile = new ConfigProxyProfile();
             this.videoProfile = new InqubusVideoProfile();
             this.commentProfile = new InqubusCommentProfile();
-            this.generalProfile = new InqubusGeneralProfile();
+            this.generalProfile = new ConfigGeneralProfile();
         }
 
         @Override
@@ -908,66 +908,6 @@ public class MainFrame extends JFrame {
         }
     }
 
-    private class InqubusLoginProfile implements LoginProfile {
-        private final String mail;
-        private final String password;
-
-        private InqubusLoginProfile(){
-            final Config p = Config.INSTANCE;
-            this.mail = p.getId();
-            this.password = p.getPassword();
-        }
-
-        @Override
-        public String getMail() {
-            return this.mail;
-        }
-
-        @Override
-        public String getPassword() {
-            return this.password;
-        }
-
-        @Override
-        public String toString(){
-            return ToStringBuilder.reflectionToString(this);
-        }
-    }
-
-    private class InqubusProxyProfile implements ProxyProfile {
-        private final boolean use;
-        private final String host;
-        private final int port;
-
-        private InqubusProxyProfile(){
-            final Config p = Config.INSTANCE;
-            this.use = p.getProxyUse();
-            this.host = p.getProxyHost();
-            final String pp = p.getProxyPort();
-            this.port = StringUtils.isBlank(pp) ? -1 : Integer.parseInt(pp);
-        }
-
-        @Override
-        public boolean use() {
-            return this.use;
-        }
-
-        @Override
-        public String getHost() {
-            return this.host;
-        }
-
-        @Override
-        public int getPort() {
-            return this.port;
-        }
-
-        @Override
-        public String toString(){
-            return ToStringBuilder.reflectionToString(this);
-        }
-    }
-
     private class InqubusVideoProfile implements VideoProfile {
         private final boolean download;
         private final File dir;
@@ -1014,17 +954,17 @@ public class MainFrame extends JFrame {
         }
     }
 
-    private class InqubusCommentProfile implements CommentProfile {
+    private class InqubusCommentProfile extends ConfigCommentProfile {
         private final boolean download;
         private final File dir;
         private final String fileName;
         private final File localFile;
-        private final int lengthRelatedCommentSize;
         private final boolean disablePerMinComment;
-        private final int perMinCommentSize;
         private final long backLogPoint;
 
         private InqubusCommentProfile() {
+            super();
+
             final Config p = Config.INSTANCE;
             this.download = !cbCommentLocal.isSelected();
             if (this.download) {
@@ -1048,10 +988,6 @@ public class MainFrame extends JFrame {
             }
 
             this.disablePerMinComment = cbBackLogReduce.isSelected();
-            this.lengthRelatedCommentSize
-                    = (p.getCommentSizeAutosize()) ? -1 : Integer.parseInt(p.getCommentSizeManual());
-            this.perMinCommentSize
-                    = (p.getCommentMinSizeAutosize()) ? -1 : Integer.parseInt(p.getCommentMinSizeManual());
         }
 
         @Override
@@ -1075,21 +1011,11 @@ public class MainFrame extends JFrame {
         }
 
         @Override
-        public int getLengthRelatedCommentSize() {
-            return this.lengthRelatedCommentSize;
-        }
-
-        @Override
         public boolean isDisablePerMinComment() {
             return this.disablePerMinComment;
         }
 
         @Override
-        public int getPerMinCommentSize() {
-            return this.perMinCommentSize;
-        }
-
-        @Override
         public long getBackLogPoint() {
             return this.backLogPoint;
         }
@@ -1100,75 +1026,28 @@ public class MainFrame extends JFrame {
         }
     }
 
-    private class InqubusGeneralProfile implements GeneralProfile {
-        private final String replaceFrom;
-        private final String replaceTo;
-        private InqubusGeneralProfile() {
-            final Config p = Config.INSTANCE;
-            this.replaceFrom = p.getReplaceFrom();
-            this.replaceTo = p.getReplaceTo();
-        }
-
-        @Override
-        public String getReplaceFrom() {
-            return this.replaceFrom;
-        }
-
-        @Override
-        public String getReplaceTo() {
-            return this.replaceTo;
-        }
-
-        @Override
-        public String toString(){
-            return ToStringBuilder.reflectionToString(this);
-        }
-    }
-
     /*
      * ここからConvertProfile作成用クラスの定義
      */
-    private class InqubusConvertProfile implements ConvertProfile {
+    private class InqubusConvertProfile extends ConfigConvertProfile {
         private final OutputProfile outputProfile;
         private final GeneralProfile generalProfile;
         private final FfmpegProfile ffmpegProfile;
         private final boolean convert;
-        private final File ffmpeg;
-        private final boolean vhookDisabled;
-        private final boolean commentOverlay;
-        private final File vhook;
-        private final File tmpDir;
-        private final File font;
-        private final int fontIndex;
-        private final boolean commentOpaque;
-        private final boolean disableFontSizeArrange;
-        private final int shadowIndex;
-        private final boolean showConvrting;
-        private final int maxNumOfComment;
-        private final HideCondition ngSetting;
 
         private InqubusConvertProfile() throws IOException {
             final Config p = Config.INSTANCE;
             this.outputProfile = new InqubusOutputProfile();
-            this.generalProfile = new InqubusGeneralProfile();
-            this.ffmpegProfile = new InqubusFfmpegProfile();
+            this.generalProfile = new ConfigGeneralProfile();
+
+            final File file = pnlInputFfmpeg.mdlFfmpegOption.getSelectedFile();
+            if (file != null) {
+                this.ffmpegProfile = new ConfigFfmpegProfile();
+            } else {
+                this.ffmpegProfile = new InqubusFfmpegProfile();
+            }
+
             this.convert = cbOutputEnable.isSelected();
-            this.ffmpeg = new File(p.getFfmpegPath());
-            // TODO コンフィグに設定なし
-            this.vhookDisabled = false;
-            this.commentOverlay = p.getOutputCommentOverlay();
-            this.vhook = new File(p.getFfmpegDllPath());
-            this.tmpDir = new File(p.getSystemTempDir());
-            this.font = new File(p.getFontPath());
-            this.fontIndex = Integer.parseInt(p.getFontIndex());
-            this.commentOpaque = p.getCommentOpaque();
-            this.disableFontSizeArrange = p.getFontSizeArrangeDisable();
-            this.shadowIndex = p.getFontShadow();
-            // TODO コンフィグに設定なし
-            this.showConvrting = true;
-            this.maxNumOfComment = (p.getCommentDisplaySizeDefault()) ? -1 : Integer.parseInt(p.
-                    getCommentDisplaySizeManual());
-            this.ngSetting = new InqubusHideCondition();
         }
 
         @Override
@@ -1192,86 +1071,19 @@ public class MainFrame extends JFrame {
         }
 
         @Override
-        public File getFfmpeg() {
-            return this.ffmpeg;
-        }
-
-        @Override
-        public boolean isVhookDisabled() {
-            return this.vhookDisabled;
-        }
-
-        @Override
-        public boolean isCommentOverlay() {
-            return this.commentOverlay;
-        }
-
-        @Override
-        public File getVhook() {
-            return this.vhook;
-        }
-
-        @Override
-        public File getTempDir() {
-            return this.tmpDir;
-        }
-
-        @Override
-        public File getFont() {
-            return this.font;
-        }
-
-        @Override
-        public int getFontIndex() {
-            return this.fontIndex;
-        }
-
-        @Override
-        public boolean isCommentOpaque() {
-            return this.commentOpaque;
-        }
-
-        @Override
-        public boolean isDisableFontSizeArrange() {
-            return this.disableFontSizeArrange;
-        }
-
-        @Override
-        public int getShadowIndex() {
-            return this.shadowIndex;
-        }
-
-        @Override
-        public boolean isShowConverting() {
-            return this.showConvrting;
-        }
-
-        @Override
-        public int getMaxNumOfComment() {
-            return this.maxNumOfComment;
-        }
-
-        @Override
-        public HideCondition getNgSetting() {
-            return this.ngSetting;
-        }
-
-        @Override
         public String toString(){
             return ToStringBuilder.reflectionToString(this);
         }
     }
 
-    private class InqubusOutputProfile implements OutputProfile {
-        private final File dir;
+    private class InqubusOutputProfile extends ConfigOutputProfile {
         private final String fileName;
         private final String videoId;
         private final String title;
 
 
-        private InqubusOutputProfile(){
+        private InqubusOutputProfile() {
             final Config p = Config.INSTANCE;
-            this.dir = new File(p.getOutputDir());
             this.fileName = fldOutput.getText();
             // TODO この時点でのID/Titleはどうするか…
             this.videoId = "";
@@ -1279,11 +1091,6 @@ public class MainFrame extends JFrame {
         }
 
         @Override
-        public File getDir() {
-            return this.dir;
-        }
-
-        @Override
         public String getFileName() {
             return this.fileName;
         }
@@ -1316,29 +1123,15 @@ public class MainFrame extends JFrame {
         private final boolean adjustRatio;
 
         private InqubusFfmpegProfile() throws IOException {
-            final File file = pnlInputFfmpeg.mdlFfmpegOption.getSelectedFile();
-            if (file != null) {
-                final FfmpegOption ffop = FfmpegOption.load(file);
-                this.extOption = ffop.getExtOption();
-                this.inOption = ffop.getInOption();
-                this.mainOption = ffop.getMainOption();
-                this.outOption = ffop.getMainOption();
-                this.avOption = ffop.getAvfilterOption();
-                this.resize = ffop.isResize();
-                this.resizeWidth = ffop.getResizeWidth();
-                this.resizeHeight = ffop.getResizeHeight();
-                this.adjustRatio = ffop.isAdjustRatio();
-            } else {
-                this.extOption = pnlInputFfmpeg.fldFfmpegOptionExtension.getText();
-                this.inOption = pnlInputFfmpeg.fldFfmpegOptionIn.getText();
-                this.mainOption = pnlInputFfmpeg.fldFfmpegOptionMain.getText();
-                this.outOption = pnlInputFfmpeg.fldFfmpegOptionOut.getText();
-                this.avOption = pnlInputFfmpeg.fldFfmpegOptionAv.getText();
-                this.resize = pnlInputFfmpeg.cbFfmpegOptionResize.isSelected();
-                this.resizeWidth = Integer.parseInt(pnlInputFfmpeg.fldFfmpegOptionResizeWidth.getText());
-                this.resizeHeight = Integer.parseInt(pnlInputFfmpeg.fldFfmpegOptionResizeHeight.getText());
-                this.adjustRatio = pnlInputFfmpeg.cbFfmpegOptionKeepAspect.isSelected();
-            }
+            this.extOption = pnlInputFfmpeg.fldFfmpegOptionExtension.getText();
+            this.inOption = pnlInputFfmpeg.fldFfmpegOptionIn.getText();
+            this.mainOption = pnlInputFfmpeg.fldFfmpegOptionMain.getText();
+            this.outOption = pnlInputFfmpeg.fldFfmpegOptionOut.getText();
+            this.avOption = pnlInputFfmpeg.fldFfmpegOptionAv.getText();
+            this.resize = pnlInputFfmpeg.cbFfmpegOptionResize.isSelected();
+            this.resizeWidth = Integer.parseInt(pnlInputFfmpeg.fldFfmpegOptionResizeWidth.getText());
+            this.resizeHeight = Integer.parseInt(pnlInputFfmpeg.fldFfmpegOptionResizeHeight.getText());
+            this.adjustRatio = pnlInputFfmpeg.cbFfmpegOptionKeepAspect.isSelected();
         }
 
         @Override
@@ -1391,24 +1184,4 @@ public class MainFrame extends JFrame {
             return ToStringBuilder.reflectionToString(this);
         }
     }
-
-    private class InqubusHideCondition implements ConvertProfile.HideCondition{
-
-        @Override
-        public String getWord() {
-            // TODO
-            return "";
-        }
-
-        @Override
-        public String getId() {
-            // TODO
-            return "";
-        }
-
-        @Override
-        public String toString(){
-            return ToStringBuilder.reflectionToString(this);
-        }
-    }
 }