OSDN Git Service

WinGui:
[handbrake-jp/handbrake-jp-git.git] / win / C# / Functions / QueryGenerator.cs
index e043d85..a6c59ee 100644 (file)
@@ -5,7 +5,6 @@
           It may be used under the terms of the GNU General Public License. */\r
 \r
 using System;\r
-using System.Text;\r
 using System.Windows.Forms;\r
 using System.Globalization;\r
 using System.IO;\r
@@ -20,13 +19,14 @@ namespace Handbrake.Functions
         /// </summary>\r
         /// <param name="mainWindow"></param>\r
         /// <returns>The CLI String</returns>\r
-        public string GenerateTheQuery(frmMain mainWindow)\r
+        public string generateTheQuery(frmMain mainWindow)\r
         {\r
             // Source tab\r
             string query = "";\r
 \r
-            if ((mainWindow.text_source.Text != "") && (mainWindow.text_source.Text.Trim() != "Click 'Source' to continue"))\r
-                query = " -i " + '"' + mainWindow.text_source.Text + '"';\r
+            if (!string.IsNullOrEmpty(mainWindow.sourcePath))\r
+                if (mainWindow.sourcePath.Trim() != "Select \"Source\" to continue")\r
+                    query = " -i " + '"' + mainWindow.sourcePath + '"';\r
 \r
             if (mainWindow.drp_dvdtitle.Text != "Automatic")\r
             {\r
@@ -34,7 +34,7 @@ namespace Handbrake.Functions
                 query += " -t " + titleInfo[0];\r
             }\r
 \r
-            if (Properties.Settings.Default.dvdnav == "Checked")\r
+            if (Properties.Settings.Default.dvdnav)\r
                 if (mainWindow.drop_angle.Items.Count != 0)\r
                     query += " --angle " + mainWindow.drop_angle.SelectedItem;\r
 \r
@@ -61,7 +61,7 @@ namespace Handbrake.Functions
         /// <param name="duration">Duration</param>\r
         /// <param name="preview">Start at preview</param>\r
         /// <returns>Returns a CLI query String.</returns>\r
-        public string GeneratePreviewQuery(frmMain mainWindow, string duration, string preview)\r
+        public string generatePreviewQuery(frmMain mainWindow, string duration, string preview)\r
         {\r
             int seconds;\r
             int.TryParse(duration, out seconds);\r
@@ -69,8 +69,9 @@ namespace Handbrake.Functions
             // Source tab\r
             string query = "";\r
 \r
-            if ((mainWindow.text_source.Text != "") && (mainWindow.text_source.Text.Trim() != "Click 'Source' to continue"))\r
-                query = " -i " + '"' + mainWindow.text_source.Text + '"';\r
+            if (!string.IsNullOrEmpty(mainWindow.sourcePath))\r
+                if (mainWindow.sourcePath.Trim() != "Select \"Source\" to continue")\r
+                    query = " -i " + '"' + mainWindow.sourcePath + '"';\r
 \r
             if (mainWindow.drp_dvdtitle.Text != "Automatic")\r
             {\r
@@ -118,65 +119,74 @@ namespace Handbrake.Functions
             #region Picture Settings Tab\r
 \r
             // Use MaxWidth for built-in presets and width for user settings.\r
-            if (mainWindow.maxWidth == 0)\r
+            if (mainWindow.PictureSettings.PresetMaximumResolution.Width == 0)\r
             {\r
-\r
-                if (mainWindow.text_width.Text != "")\r
-                    query += " -w " + mainWindow.text_width.Text;\r
+                if (mainWindow.PictureSettings.text_width.Value != 0)\r
+                    if (mainWindow.PictureSettings.drp_anamorphic.SelectedIndex != 1) // Prevent usage for strict anamorphic\r
+                        query += " -w " + mainWindow.PictureSettings.text_width.Text;\r
             }\r
             else\r
             {\r
-                if (mainWindow.text_width.Text != "")\r
-                    query += " -X " + mainWindow.text_width.Text;\r
+                if (mainWindow.PictureSettings.text_width.Value != 0)\r
+                    if (mainWindow.PictureSettings.drp_anamorphic.SelectedIndex != 1)\r
+                    query += " -X " + mainWindow.PictureSettings.text_width.Text;\r
             }\r
 \r
             // Use MaxHeight for built-in presets and height for user settings.\r
-            if (mainWindow.maxHeight == 0)\r
+            if (mainWindow.PictureSettings.PresetMaximumResolution.Height == 0)\r
             {\r
-                if (mainWindow.text_height.Text != "")\r
-                    query += " -l " + mainWindow.text_height.Text;\r
+                if (mainWindow.PictureSettings.text_height.Value != 0)\r
+                    if (mainWindow.PictureSettings.text_height.Text != "")\r
+                        if (mainWindow.PictureSettings.drp_anamorphic.SelectedIndex == 0 || mainWindow.PictureSettings.drp_anamorphic.SelectedIndex == 3) // Prevent usage for strict anamorphic\r
+                            query += " -l " + mainWindow.PictureSettings.text_height.Text;\r
             }\r
             else\r
             {\r
-                if (mainWindow.text_height.Text != "")\r
-                    query += " -Y " + mainWindow.text_height.Text;\r
+                if (mainWindow.PictureSettings.text_height.Value != 0)\r
+                    if (mainWindow.PictureSettings.drp_anamorphic.SelectedIndex == 0 || mainWindow.PictureSettings.drp_anamorphic.SelectedIndex == 3)\r
+                        query += " -Y " + mainWindow.PictureSettings.text_height.Text;\r
             }\r
 \r
-            string cropTop = mainWindow.text_top.Text;\r
-            string cropBottom = mainWindow.text_bottom.Text;\r
-            string cropLeft = mainWindow.text_left.Text;\r
-            string cropRight = mainWindow.text_right.Text;\r
+            string cropTop = mainWindow.PictureSettings.crop_top.Text;\r
+            string cropBottom = mainWindow.PictureSettings.crop_bottom.Text;\r
+            string cropLeft = mainWindow.PictureSettings.crop_left.Text;\r
+            string cropRight = mainWindow.PictureSettings.crop_right.Text;\r
 \r
-            if (mainWindow.check_customCrop.Checked)\r
+            if (mainWindow.PictureSettings.check_customCrop.Checked)\r
             {\r
-                if (mainWindow.text_top.Text == string.Empty)\r
+                if (mainWindow.PictureSettings.crop_top.Text == string.Empty)\r
                     cropTop = "0";\r
-                if (mainWindow.text_bottom.Text == string.Empty)\r
+                if (mainWindow.PictureSettings.crop_bottom.Text == string.Empty)\r
                     cropBottom = "0";\r
-                if (mainWindow.text_left.Text == string.Empty)\r
+                if (mainWindow.PictureSettings.crop_left.Text == string.Empty)\r
                     cropLeft = "0";\r
-                if (mainWindow.text_right.Text == string.Empty)\r
+                if (mainWindow.PictureSettings.crop_right.Text == string.Empty)\r
                     cropRight = "0";\r
 \r
                 query += " --crop " + cropTop + ":" + cropBottom + ":" + cropLeft + ":" + cropRight;\r
             }\r
 \r
-            if (mainWindow.drp_anamorphic.SelectedIndex == 1)\r
-                query += " -p ";\r
-            else if (mainWindow.drp_anamorphic.SelectedIndex == 2)\r
-                query += " -P ";\r
-\r
-            if (mainWindow.slider_deblock.Value != 4)\r
-                query += " --deblock=" + mainWindow.slider_deblock.Value;\r
-\r
-            \r
+            switch (mainWindow.PictureSettings.drp_anamorphic.SelectedIndex)\r
+            {\r
+                case 1:\r
+                    query += " --strict-anamorphic ";\r
+                    break;\r
+                case 2:\r
+                    query += " --loose-anamorphic ";\r
+                    break;\r
+                case 3:\r
+                    query += " --custom-anamorphic ";\r
+                    query += " --display-width " + mainWindow.PictureSettings.updownDisplayWidth.Text + " ";\r
+                    if (mainWindow.PictureSettings.check_KeepAR.Checked)\r
+                        query += " --keep-display-aspect ";\r
+                    if (mainWindow.PictureSettings.updownParWidth.Text != "" && mainWindow.PictureSettings.updownParHeight.Text != "")\r
+                        query += " --pixel-aspect " + mainWindow.PictureSettings.updownParWidth.Text + ":" + mainWindow.PictureSettings.updownParHeight.Text + " ";\r
+                    break;\r
+            }\r
             #endregion\r
 \r
             #region Filters\r
-            query += mainWindow.ctl_detelecine.getCLIQuery;\r
-            query += mainWindow.ctl_decomb.getCLIQuery;\r
-            query += mainWindow.ctl_deinterlace.getCLIQuery;\r
-            query += mainWindow.ctl_denoise.getCLIQuery;\r
+            query += mainWindow.Filters.getCLIQuery;\r
             #endregion\r
 \r
             #region Video Settings Tab\r
@@ -197,9 +207,6 @@ namespace Handbrake.Functions
                     break;\r
             }\r
 \r
-            if (mainWindow.check_grayscale.Checked)\r
-                query += " -g ";\r
-\r
             // Video Settings\r
             if (mainWindow.radio_avgBitrate.Checked)\r
                 query += " -b " + mainWindow.text_bitrate.Text;\r
@@ -214,26 +221,21 @@ namespace Handbrake.Functions
                 switch (mainWindow.drp_videoEncoder.Text)\r
                 {\r
                     case "MPEG-4 (FFmpeg)":\r
-                        value = 31 - (mainWindow.slider_videoQuality.Value -1);\r
+                        value = 31 - (mainWindow.slider_videoQuality.Value - 1);\r
                         query += " -q " + value.ToString(new CultureInfo("en-US"));\r
                         break;\r
                     case "H.264 (x264)":\r
-                        double divided;\r
                         CultureInfo culture = CultureInfo.CreateSpecificCulture("en-US");\r
-                        double.TryParse(Properties.Settings.Default.x264cqstep,\r
-                                        NumberStyles.Number,\r
-                                        culture,\r
-                                        out divided);\r
-                        value = 51 - mainWindow.slider_videoQuality.Value * divided;\r
+                        value = 51 - mainWindow.slider_videoQuality.Value * Properties.Settings.Default.x264cqstep;\r
                         value = Math.Round(value, 2);\r
-                        query += " -q " + value.ToString(new CultureInfo("en-US"));\r
+                        query += " -q " + value.ToString(culture);\r
                         break;\r
                     case "VP3 (Theora)":\r
                         value = mainWindow.slider_videoQuality.Value;\r
                         query += " -q " + value.ToString(new CultureInfo("en-US"));\r
                         break;\r
-                } \r
-            }     \r
+                }\r
+            }\r
 \r
             if (mainWindow.check_2PassEncode.Checked)\r
                 query += " -2 ";\r
@@ -247,7 +249,7 @@ namespace Handbrake.Functions
 \r
             #region Audio Settings Tab\r
 \r
-            ListView audioTracks = mainWindow.lv_audioList;\r
+            ListView audioTracks = mainWindow.AudioSettings.getAudioPanel();\r
             List<string> tracks = new List<string>();\r
             List<string> codecs = new List<string>();\r
             List<string> mixdowns = new List<string>();\r
@@ -263,33 +265,33 @@ namespace Handbrake.Functions
             foreach (ListViewItem row in audioTracks.Items)\r
             {\r
                 // Audio Track (-a)\r
-                if (row.Text == "Automatic")\r
+                if (row.SubItems[1].Text == "Automatic")\r
                     tracks.Add("1");\r
                 else if (row.Text != "None")\r
                 {\r
-                    string[] tempSub = row.Text.Split(' ');\r
+                    string[] tempSub = row.SubItems[1].Text.Split(' ');\r
                     tracks.Add(tempSub[0]);\r
                 }\r
 \r
                 // Audio Codec (-E)\r
-                if (row.SubItems[1].Text != String.Empty)\r
-                    codecs.Add(getAudioEncoder(row.SubItems[1].Text));\r
+                if (row.SubItems[2].Text != String.Empty)\r
+                    codecs.Add(getAudioEncoder(row.SubItems[2].Text));\r
 \r
                 // Audio Mixdown (-6)\r
-                if (row.SubItems[2].Text != String.Empty)\r
-                    mixdowns.Add(getMixDown(row.SubItems[2].Text));\r
+                if (row.SubItems[3].Text != String.Empty)\r
+                    mixdowns.Add(getMixDown(row.SubItems[3].Text));\r
 \r
                 // Sample Rate (-R)\r
-                if (row.SubItems[3].Text != String.Empty)\r
-                    samplerates.Add(row.SubItems[3].Text.Replace("Auto", "Auto"));\r
+                if (row.SubItems[4].Text != String.Empty)\r
+                    samplerates.Add(row.SubItems[4].Text.Replace("Auto", "Auto"));\r
 \r
                 // Audio Bitrate (-B)\r
-                if (row.SubItems[4].Text != String.Empty)\r
-                    bitrates.Add(row.SubItems[4].Text.Replace("Auto", "auto"));\r
+                if (row.SubItems[5].Text != String.Empty)\r
+                    bitrates.Add(row.SubItems[5].Text.Replace("Auto", "auto"));\r
 \r
                 // DRC (-D)\r
-                if (row.SubItems[5].Text != String.Empty)\r
-                    drcs.Add(row.SubItems[5].Text);\r
+                if (row.SubItems[6].Text != String.Empty)\r
+                    drcs.Add(row.SubItems[6].Text);\r
             }\r
 \r
             // Audio Track (-a)\r
@@ -312,7 +314,7 @@ namespace Handbrake.Functions
             // Audio Codec (-E)\r
             foreach (String item in codecs)\r
             {\r
-                \r
+\r
                 if (firstLoop)\r
                 {\r
                     audioItems = item; firstLoop = false;\r
@@ -379,26 +381,121 @@ namespace Handbrake.Functions
             if (audioItems.Trim() != String.Empty)\r
                 query += " -D " + audioItems;\r
 \r
-            // Subtitles\r
-            string subtitles = mainWindow.drp_subtitle.Text;\r
-            if (subtitles == "Autoselect")\r
-                query += " -U ";\r
-            else if (subtitles != "" && subtitles != "None")\r
+            #endregion\r
+\r
+            #region Subtitles Tab\r
+            if (mainWindow.Subtitles.lv_subList.Items.Count != 0) // If we have subtitle tracks\r
             {\r
-                string[] tempSub = subtitles.Split(' ');\r
-                query += " -s " + tempSub[0];\r
-            }\r
+                IDictionary<string, string> langMap = Main.mapLanguages();\r
 \r
-            if (mainWindow.check_forced.Checked)\r
-                query += " -F ";\r
+                // BitMap and CC's\r
+                string subtitleTracks = String.Empty;\r
+                string subtitleForced = String.Empty;\r
+                string subtitleBurn = String.Empty;\r
+                string subtitleDefault = String.Empty;\r
 \r
+                // SRT\r
+                string srtFile = String.Empty; \r
+                string srtCodeset = String.Empty;\r
+                string srtOffset = String.Empty; \r
+                string srtLang = String.Empty; \r
+\r
+                foreach (ListViewItem item in mainWindow.Subtitles.lv_subList.Items)\r
+                {\r
+                    string itemToAdd, trackID;\r
+\r
+                    if (item.SubItems.Count != 5) // We have an SRT file\r
+                    {\r
+                        string[] trackData = item.SubItems[1].Text.Split(',');\r
+                        if (trackData != null)\r
+                        {\r
+                            string charCode = trackData[1].Replace("(", "").Replace(")", "").Trim();\r
+                            string realLangCode = langMap[trackData[0].Trim()];\r
+\r
+                            srtLang += srtLang == "" ? realLangCode : "," + realLangCode;\r
+                            srtCodeset += srtCodeset == "" ? charCode : "," + charCode;\r
+                        }\r
+\r
+                        itemToAdd = item.SubItems[5].Text;\r
+                        srtFile += srtFile == "" ? itemToAdd : "," + itemToAdd;\r
+\r
+                        itemToAdd = item.SubItems[6].Text;\r
+                        srtOffset += srtOffset == "" ? itemToAdd : "," + itemToAdd;\r
+                    }\r
+                    else // We have Bitmap or CC\r
+                    {\r
+                        string[] tempSub;\r
+        \r
+                        // Find --subtitle <string>\r
+                        if (item.SubItems[1].Text.Contains("Foreign Audio Search"))\r
+                            itemToAdd = "scan";\r
+                        else\r
+                        {\r
+                            tempSub = item.SubItems[1].Text.Split(' ');\r
+                            itemToAdd = tempSub[0];\r
+                        }\r
+\r
+                        subtitleTracks += subtitleTracks == "" ? itemToAdd : "," + itemToAdd;\r
+\r
+                        // Find --subtitle-forced\r
+                        itemToAdd = "";\r
+                        tempSub = item.SubItems[1].Text.Split(' ');\r
+                        trackID = tempSub[0];\r
+\r
+                        if (item.SubItems[2].Text == "Yes")\r
+                            itemToAdd = trackID;\r
+\r
+                        if (itemToAdd != "")\r
+                            subtitleForced += subtitleForced == "" ? itemToAdd : "," + itemToAdd;\r
+\r
+                        // Find --subtitle-burn and --subtitle-default\r
+                        tempSub = item.SubItems[1].Text.Split(' ');\r
+                        trackID = tempSub[0];\r
+\r
+                        if (trackID.Trim() == "Foreign")\r
+                            trackID = "scan";\r
+\r
+                        if (item.SubItems[3].Text == "Yes") // burn\r
+                            subtitleBurn = trackID;\r
+\r
+                        if (item.SubItems[4].Text == "Yes") // default\r
+                            subtitleDefault = trackID;\r
+                    }\r
+                }\r
+\r
+                // Build The CLI Subtitles Query\r
+                if (subtitleTracks != "")\r
+                {\r
+                    query += " --subtitle " + subtitleTracks;\r
+\r
+                    if (subtitleForced != "")\r
+                        query += " --subtitle-forced " + subtitleForced;\r
+                    if (subtitleBurn != "")\r
+                        query += " --subtitle-burn " + subtitleBurn;\r
+                    if (subtitleDefault != "")\r
+                        query += " --subtitle-default " + subtitleDefault;\r
+                }\r
+\r
+                if (srtFile != "") // SRTs\r
+                {\r
+                    query += " --srt-file " + srtFile;\r
+\r
+                    if (srtCodeset != "")\r
+                        query += " --srt-codeset " + srtCodeset;\r
+                    if (srtOffset != "")\r
+                        query += " --srt-offset " + srtOffset;\r
+                    if (srtLang != "")\r
+                        query += " --srt-lang " + srtLang;\r
+                }\r
+\r
+            }\r
             #endregion\r
 \r
             #region Chapter Markers\r
 \r
             // Attach Source name and dvd title to the start of the chapters.csv filename.\r
             // This is for the queue. It allows different chapter name files for each title.\r
-            string[] destName =  mainWindow.text_destination.Text.Split('\\');\r
+            string[] destName = mainWindow.text_destination.Text.Split('\\');\r
             string dest_name = destName[destName.Length - 1];\r
             dest_name = dest_name.Replace("\"", "");\r
             dest_name = dest_name.Replace(".mp4", "").Replace(".m4v", "").Replace(".mkv", "");\r
@@ -411,8 +508,8 @@ namespace Handbrake.Functions
             {\r
                 if (dest_name.Trim() != String.Empty)\r
                 {\r
-                    string path = source_title != "Automatic" \r
-                                      ? Path.Combine(Path.GetTempPath(), dest_name + "-" + source_title + "-chapters.csv") \r
+                    string path = source_title != "Automatic"\r
+                                      ? Path.Combine(Path.GetTempPath(), dest_name + "-" + source_title + "-chapters.csv")\r
                                       : Path.Combine(Path.GetTempPath(), dest_name + "-chapters.csv");\r
 \r
                     if (chapterCSVSave(mainWindow, path) == false)\r
@@ -437,19 +534,13 @@ namespace Handbrake.Functions
 \r
             query += " -v " + Properties.Settings.Default.verboseLevel;\r
 \r
-            if (Properties.Settings.Default.dvdnav =="Checked")\r
+            if (Properties.Settings.Default.dvdnav)\r
                 query += " --dvdnav";\r
             #endregion\r
 \r
             return query;\r
         }\r
 \r
-        /// <summary>\r
-        /// Get the CLI equive of the audio mixdown from the widget name.\r
-        /// </summary>\r
-        /// <param name="selectedAudio"></param>\r
-        /// <returns></returns>\r
-        /// \r
         private static string getMixDown(string selectedAudio)\r
         {\r
             switch (selectedAudio)\r
@@ -470,13 +561,6 @@ namespace Handbrake.Functions
                     return "auto";\r
             }\r
         }\r
-\r
-        /// <summary>\r
-        /// Get the CLI equiv of the audio encoder from the widget name.\r
-        /// </summary>\r
-        /// <param name="selectedEncoder"></param>\r
-        /// <returns></returns>\r
-        /// \r
         private static string getAudioEncoder(string selectedEncoder)\r
         {\r
             switch (selectedEncoder)\r
@@ -495,29 +579,21 @@ namespace Handbrake.Functions
                     return "";\r
             }\r
         }\r
-\r
-        /// <summary>\r
-        /// This function saves the data in the chapters tab, dataGridView into a CSV file called chapters.csv\r
-        /// in a directory specified by file_path_name\r
-        /// </summary>\r
-        /// <param name="mainWindow"></param>\r
-        /// <param name="file_path_name"></param>\r
-        /// <returns></returns>\r
-        private static Boolean chapterCSVSave(frmMain mainWindow, string file_path_name)\r
+        private static Boolean chapterCSVSave(frmMain mainWindow, string filePathName)\r
         {\r
             try\r
             {\r
-                StringBuilder csv = new StringBuilder();\r
+                string csv = "";\r
 \r
                 foreach (DataGridViewRow row in mainWindow.data_chpt.Rows)\r
                 {\r
-                    csv.Append(row.Cells[0].Value.ToString());\r
-                    csv.Append(",");\r
-                    csv.Append(row.Cells[1].Value.ToString());\r
-                    csv.Append(Environment.NewLine);\r
+                    csv += row.Cells[0].Value.ToString();\r
+                    csv += ",";\r
+                    csv += row.Cells[1].Value.ToString();\r
+                    csv += Environment.NewLine;\r
                 }\r
-                StreamWriter file = new StreamWriter(file_path_name);\r
-                file.Write(csv.ToString());\r
+                StreamWriter file = new StreamWriter(filePathName);\r
+                file.Write(csv);\r
                 file.Close();\r
                 file.Dispose();\r
                 return true;\r