OSDN Git Service

WinGui:
[handbrake-jp/handbrake-jp-git.git] / win / C# / frmOptions.cs
index 606d9d7..aef7555 100644 (file)
@@ -4,18 +4,27 @@
           Homepage: <http://handbrake.fr>.\r
           It may be used under the terms of the GNU General Public License. */\r
 \r
-using System;\r
-using System.Globalization;\r
-using System.Windows.Forms;\r
-using Handbrake.Functions;\r
-\r
 namespace Handbrake\r
 {\r
+    using System;\r
+    using System.Collections.Generic;\r
+    using System.Diagnostics;\r
+    using System.Globalization;\r
+    using System.Windows.Forms;\r
+    using Functions;\r
+\r
     public partial class frmOptions : Form\r
     {\r
-        public frmOptions()\r
+        private frmMain mainWindow;\r
+\r
+        public frmOptions(frmMain mw)\r
         {\r
             InitializeComponent();\r
+            mainWindow = mw;\r
+\r
+            IDictionary<string, string> langList = Main.MapLanguages();\r
+            foreach (string item in langList.Keys)\r
+                drop_preferredLang.Items.Add(item);\r
 \r
             // #############################\r
             // General\r
@@ -28,17 +37,34 @@ namespace Handbrake
                 ToolTip.Active = true;\r
             }\r
 \r
-            // Setup Widgets to match settings.\r
+            // Update Check\r
             if (Properties.Settings.Default.updateStatus)\r
                 check_updateCheck.CheckState = CheckState.Checked;\r
 \r
-            // enable loading of default user settings.\r
-            if (Properties.Settings.Default.defaultSettings)\r
-                check_userDefaultSettings.CheckState = CheckState.Checked;\r
+            // Days between update checks\r
+            switch (Properties.Settings.Default.daysBetweenUpdateCheck)\r
+            {\r
+                case 1:\r
+                    drop_updateCheckDays.SelectedIndex = 0;\r
+                    break;\r
+                case 7:\r
+                    drop_updateCheckDays.SelectedIndex = 1;\r
+                    break;\r
+                case 30:\r
+                    drop_updateCheckDays.SelectedIndex = 2;\r
+                    break;\r
+            }\r
 \r
             // On Encode Completeion Action\r
             drp_completeOption.Text = Properties.Settings.Default.CompletionOption;\r
 \r
+            // Growl.\r
+            if (Properties.Settings.Default.growlEncode)\r
+                check_growlEncode.CheckState = CheckState.Checked;\r
+\r
+            if (Properties.Settings.Default.growlQueue)\r
+                check_GrowlQueue.CheckState = CheckState.Checked;\r
+\r
             // Enable auto naming feature.\r
             if (Properties.Settings.Default.autoNaming)\r
                 check_autoNaming.CheckState = CheckState.Checked;\r
@@ -63,6 +89,18 @@ namespace Handbrake
             txt_vlcPath.Text = Properties.Settings.Default.VLC_Path;\r
 \r
             // #############################\r
+            // Audio and Subtitles Tab\r
+            // #############################\r
+\r
+            drop_preferredLang.SelectedItem = Properties.Settings.Default.NativeLanguage;\r
+\r
+            if (Properties.Settings.Default.DubAudio)\r
+                radio_dub.Checked = true;\r
+            else\r
+                radio_foreignAndSubs.Checked = true;\r
+\r
+\r
+            // #############################\r
             // CLI\r
             // #############################\r
 \r
@@ -79,7 +117,6 @@ namespace Handbrake
             // Log Verbosity Level\r
             cb_logVerboseLvl.SelectedIndex = Properties.Settings.Default.verboseLevel;\r
 \r
-\r
             // Save logs in the same directory as encoded files\r
             if (Properties.Settings.Default.saveLogWithVideo)\r
                 check_saveLogWithVideo.CheckState = CheckState.Checked;\r
@@ -91,15 +128,12 @@ namespace Handbrake
             // The saved log path\r
             text_logPath.Text = Properties.Settings.Default.saveLogPath;\r
 \r
+            check_clearOldLogs.Checked = Properties.Settings.Default.clearOldLogs;\r
 \r
             // #############################\r
             // Advanced\r
             // #############################\r
 \r
-            // Enable GUI DVD Drive detection code\r
-            if (Properties.Settings.Default.drive_detection)\r
-                btn_drive_detect.CheckState = CheckState.Checked;\r
-\r
             // Minimise to Tray\r
             if (Properties.Settings.Default.trayIconAlerts)\r
                 check_trayStatusAlerts.CheckState = CheckState.Checked;\r
@@ -111,6 +145,10 @@ namespace Handbrake
             // Enable / Disable Query editor tab\r
             if (Properties.Settings.Default.QueryEditorTab)\r
                 check_queryEditorTab.CheckState = CheckState.Checked;\r
+            check_promptOnUnmatchingQueries.Enabled = check_queryEditorTab.Checked;\r
+\r
+            // Prompt on inconsistant queries\r
+            check_promptOnUnmatchingQueries.Checked = Properties.Settings.Default.PromptOnUnmatchingQueries;\r
 \r
             // Preset update notification\r
             if (Properties.Settings.Default.presetNotification)\r
@@ -120,49 +158,84 @@ namespace Handbrake
             if (Properties.Settings.Default.enocdeStatusInGui)\r
                 check_inGuiStatus.CheckState = CheckState.Checked;\r
 \r
-            // Days between update checks\r
-            switch (Properties.Settings.Default.daysBetweenUpdateCheck)\r
+            check_showCliForInGUIEncode.Checked = Properties.Settings.Default.showCliForInGuiEncodeStatus;\r
+            check_showCliForInGUIEncode.Enabled = check_inGuiStatus.Checked;\r
+\r
+            // Set the preview count\r
+            drop_previewScanCount.SelectedItem = Properties.Settings.Default.previewScanCount.ToString();\r
+\r
+            // x264 step\r
+            string step = Properties.Settings.Default.x264cqstep.ToString(new CultureInfo("en-US"));\r
+            switch (step)\r
             {\r
-                case 1:\r
-                    drop_updateCheckDays.SelectedIndex = 0;\r
+                case "1":\r
+                    drop_x264step.SelectedIndex = 0;\r
                     break;\r
-                case 7:\r
-                    drop_updateCheckDays.SelectedIndex = 1;\r
+                case "0.5":\r
+                    drop_x264step.SelectedIndex = 1;\r
                     break;\r
-                case 30:\r
-                    drop_updateCheckDays.SelectedIndex = 2;\r
+                case "0.25":\r
+                    drop_x264step.SelectedIndex = 2;\r
+                    break;\r
+                case "0.2":\r
+                    drop_x264step.SelectedIndex = 3;\r
                     break;\r
             }\r
 \r
-            // x264 step\r
-            CultureInfo culture = CultureInfo.CreateSpecificCulture("en-US");\r
-            drop_x264step.SelectedItem = Properties.Settings.Default.x264cqstep.ToString(culture);\r
-\r
             // Use Experimental dvdnav\r
-            if (Properties.Settings.Default.dvdnav)\r
+            if (Properties.Settings.Default.noDvdNav)\r
                 check_dvdnav.CheckState = CheckState.Checked;\r
+\r
+            // #############################\r
+            // Debug\r
+            // #############################\r
+            if (Properties.Settings.Default.disableResCalc)\r
+                check_disableResCalc.Checked = true;\r
         }\r
 \r
         #region General\r
+\r
         private void check_updateCheck_CheckedChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.updateStatus = check_updateCheck.Checked;\r
         }\r
 \r
-        private void check_userDefaultSettings_CheckedChanged(object sender, EventArgs e)\r
+        private void drop_updateCheckDays_SelectedIndexChanged(object sender, EventArgs e)\r
         {\r
-            Properties.Settings.Default.defaultSettings = check_userDefaultSettings.Checked;\r
+            switch (drop_updateCheckDays.SelectedIndex)\r
+            {\r
+                case 0:\r
+                    Properties.Settings.Default.daysBetweenUpdateCheck = 1;\r
+                    break;\r
+                case 1:\r
+                    Properties.Settings.Default.daysBetweenUpdateCheck = 7;\r
+                    break;\r
+                case 2:\r
+                    Properties.Settings.Default.daysBetweenUpdateCheck = 30;\r
+                    break;\r
+            }\r
         }\r
 \r
         private void check_tooltip_CheckedChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.tooltipEnable = check_tooltip.Checked;\r
         }\r
+\r
         private void drp_completeOption_SelectedIndexChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.CompletionOption = drp_completeOption.Text;\r
         }\r
 \r
+        private void check_GrowlQueue_CheckedChanged(object sender, EventArgs e)\r
+        {\r
+            Properties.Settings.Default.growlQueue = check_GrowlQueue.Checked;\r
+        }\r
+\r
+        private void check_growlEncode_CheckedChanged(object sender, EventArgs e)\r
+        {\r
+            Properties.Settings.Default.growlEncode = check_growlEncode.Checked;\r
+        }\r
+\r
         private void check_autoNaming_CheckedChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.autoNaming = check_autoNaming.Checked;\r
@@ -183,7 +256,7 @@ namespace Handbrake
         {\r
             if (text_an_path.Text == string.Empty)\r
             {\r
-                Properties.Settings.Default.autoNamePath = "";\r
+                Properties.Settings.Default.autoNamePath = string.Empty;\r
                 text_an_path.Text = "Click 'Browse' to set the default location";\r
             }\r
             else\r
@@ -194,22 +267,48 @@ namespace Handbrake
         {\r
             Properties.Settings.Default.useM4v = check_m4v.Checked;\r
         }\r
+\r
         #endregion\r
 \r
         #region Picture\r
+\r
         private void btn_vlcPath_Click(object sender, EventArgs e)\r
         {\r
             openFile_vlc.ShowDialog();\r
             if (openFile_vlc.FileName != string.Empty)\r
                 txt_vlcPath.Text = openFile_vlc.FileName;\r
         }\r
+\r
         private void txt_vlcPath_TextChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.VLC_Path = txt_vlcPath.Text;\r
         }\r
+\r
+        #endregion\r
+\r
+        #region Audio and Subtitles\r
+\r
+        private void drop_preferredLang_SelectedIndexChanged(object sender, EventArgs e)\r
+        {\r
+            Properties.Settings.Default.NativeLanguage = drop_preferredLang.SelectedItem.ToString();\r
+        }\r
+\r
+        private void radio_dub_CheckedChanged(object sender, EventArgs e)\r
+        {\r
+            if (radio_dub.Checked)\r
+                Properties.Settings.Default.DubAudio = true;\r
+        }\r
+\r
+        private void radio_foreignAndSubs_CheckedChanged(object sender, EventArgs e)\r
+        {\r
+            if (radio_foreignAndSubs.Checked)\r
+                Properties.Settings.Default.DubAudio = false;\r
+        }\r
+\r
         #endregion\r
 \r
         #region CLI\r
+\r
         private void check_cli_minimized_CheckedChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.cli_minimized = check_cli_minimized.Checked;\r
@@ -257,7 +356,7 @@ namespace Handbrake
         {\r
             string logDir = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData) + "\\HandBrake\\logs";\r
             string windir = Environment.GetEnvironmentVariable("WINDIR");\r
-            System.Diagnostics.Process prc = new System.Diagnostics.Process();\r
+            Process prc = new Process();\r
             prc.StartInfo.FileName = windir + @"\explorer.exe";\r
             prc.StartInfo.Arguments = logDir;\r
             prc.Start();\r
@@ -265,25 +364,29 @@ namespace Handbrake
 \r
         private void btn_clearLogs_Click(object sender, EventArgs e)\r
         {\r
-            DialogResult result = MessageBox.Show("Are you sure you wish to clear the log file directory?", "Clear Logs", MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question);\r
+            DialogResult result = MessageBox.Show("Are you sure you wish to clear the log file directory?", "Clear Logs", \r
+                                                  MessageBoxButtons.YesNoCancel, MessageBoxIcon.Question);\r
             if (result == DialogResult.Yes)\r
             {\r
-                Main.clearLogs();\r
-                MessageBox.Show(this, "HandBrake's Log file directory has been cleared!", "Notice", MessageBoxButtons.OK,\r
+                Main.ClearLogs();\r
+                MessageBox.Show(this, "HandBrake's Log file directory has been cleared!", "Notice", MessageBoxButtons.OK, \r
                                 MessageBoxIcon.Information);\r
             }\r
         }\r
-        #endregion\r
 \r
-        #region Advanced\r
-        private void btn_drive_detect_CheckedChanged(object sender, EventArgs e)\r
+        private void check_clearOldLogs_CheckedChanged(object sender, EventArgs e)\r
         {\r
-            Properties.Settings.Default.drive_detection = btn_drive_detect.Checked;\r
+            Properties.Settings.Default.clearOldLogs = check_clearOldLogs.Checked;\r
         }\r
 \r
+        #endregion\r
+\r
+        #region Advanced\r
+\r
         private void check_mainMinimize_CheckedChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.MainWindowMinimize = check_mainMinimize.Checked;\r
+            check_trayStatusAlerts.Enabled = check_mainMinimize.Checked;\r
         }\r
 \r
         private void check_trayStatusAlerts_CheckedChanged(object sender, EventArgs e)\r
@@ -294,6 +397,12 @@ namespace Handbrake
         private void check_queryEditorTab_CheckedChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.QueryEditorTab = check_queryEditorTab.Checked;\r
+            check_promptOnUnmatchingQueries.Enabled = check_queryEditorTab.Checked;\r
+        }\r
+\r
+        private void check_promptOnUnmatchingQueries_CheckedChanged(object sender, EventArgs e)\r
+        {\r
+            Properties.Settings.Default.PromptOnUnmatchingQueries = check_promptOnUnmatchingQueries.Checked;\r
         }\r
 \r
         private void check_disablePresetNotification_CheckedChanged(object sender, EventArgs e)\r
@@ -304,22 +413,29 @@ namespace Handbrake
         private void check_inGuiStatus_CheckedChanged(object sender, EventArgs e)\r
         {\r
             Properties.Settings.Default.enocdeStatusInGui = check_inGuiStatus.Checked;\r
+\r
+            check_showCliForInGUIEncode.Enabled = check_inGuiStatus.Checked;\r
+\r
+            if (this.IsHandleCreated)\r
+                if (check_inGuiStatus.Checked)\r
+                {\r
+                    MessageBox.Show(\r
+                        "This feature is experimental!\n\n You will not be able to \91Stop\92 an encode mid-process.\n"\r
+                        + "Doing so will render the file unplayable.\n" +\r
+                        "If you enable 'Show CLI Window', you'll be ablt to hit ctrl-c in the encode window to cleanly exit the CLI. This will give you a playable file.\n\n" +\r
+                        "You are also limited to 1 instance of HandBrakeCLI on your system.", \r
+                        "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning);\r
+                }\r
         }\r
 \r
-        private void drop_updateCheckDays_SelectedIndexChanged(object sender, EventArgs e)\r
+        private void check_showCliForInGUIEncode_CheckedChanged(object sender, EventArgs e)\r
         {\r
-            switch (drop_updateCheckDays.SelectedIndex)\r
-            {\r
-                case 0:\r
-                    Properties.Settings.Default.daysBetweenUpdateCheck = 1;\r
-                    break;\r
-                case 1:\r
-                    Properties.Settings.Default.daysBetweenUpdateCheck = 7;\r
-                    break;\r
-                case 2:\r
-                    Properties.Settings.Default.daysBetweenUpdateCheck = 30;\r
-                    break;\r
-            }\r
+            Properties.Settings.Default.showCliForInGuiEncodeStatus = check_showCliForInGUIEncode.Checked;\r
+        }\r
+\r
+        private void drop_previewScanCount_SelectedIndexChanged(object sender, EventArgs e)\r
+        {\r
+            Properties.Settings.Default.previewScanCount = int.Parse(drop_previewScanCount.SelectedItem.ToString());\r
         }\r
 \r
         private void x264step_SelectedIndexChanged(object sender, EventArgs e)\r
@@ -339,12 +455,23 @@ namespace Handbrake
                     Properties.Settings.Default.x264cqstep = 0.20;\r
                     break;\r
             }\r
+            mainWindow.setQualityFromSlider();\r
         }\r
 \r
         private void check_dvdnav_CheckedChanged(object sender, EventArgs e)\r
         {\r
-            Properties.Settings.Default.dvdnav = check_dvdnav.Checked;\r
+            Properties.Settings.Default.noDvdNav = check_dvdnav.Checked;\r
         }\r
+\r
+        #endregion\r
+\r
+        #region Debug\r
+\r
+        private void check_disableResCalc_CheckedChanged(object sender, EventArgs e)\r
+        {\r
+            Properties.Settings.Default.disableResCalc = check_disableResCalc.Checked;\r
+        }\r
+\r
         #endregion\r
 \r
         private void btn_close_Click(object sender, EventArgs e)\r
@@ -352,8 +479,5 @@ namespace Handbrake
             Properties.Settings.Default.Save(); // Small hack for Vista. Seems to work fine on XP without this\r
             this.Close();\r
         }\r
-\r
-        \r
-\r
     }\r
 }
\ No newline at end of file