OSDN Git Service

WinGui: Fix subtitle forced for foreign scan. Set it to "scan" instead of "Forced"
[handbrake-jp/handbrake-jp-git.git] / win / C# / Functions / QueryGenerator.cs
index 0394df6..2d2bd2a 100644 (file)
@@ -15,79 +15,55 @@ namespace Handbrake.Functions
     class QueryGenerator\r
     {\r
         /// <summary>\r
-        /// Generates a CLI query based on the GUI widgets.\r
+        /// Generates a full CLI query for either encoding or previe encoeds if duration and preview are defined.\r
         /// </summary>\r
         /// <param name="mainWindow"></param>\r
-        /// <returns>The CLI String</returns>\r
-        public string generateTheQuery(frmMain mainWindow)\r
+        /// <param name="duration"></param>\r
+        /// <param name="preview"></param>\r
+        /// <returns></returns>\r
+        public string GenerateCLIQuery(frmMain mainWindow, int duration, string preview)\r
         {\r
-            // Source tab\r
             string query = "";\r
 \r
-            if ((mainWindow.sourcePath != "") && (mainWindow.sourcePath.Trim() != "Click 'Source' to continue"))\r
-                query = " -i " + '"' + mainWindow.sourcePath + '"';\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
+            if (mainWindow.drp_dvdtitle.Text != "")\r
             {\r
                 string[] titleInfo = mainWindow.drp_dvdtitle.Text.Split(' ');\r
                 query += " -t " + titleInfo[0];\r
             }\r
 \r
-            if (Properties.Settings.Default.dvdnav)\r
+            if (!Properties.Settings.Default.noDvdNav)\r
                 if (mainWindow.drop_angle.Items.Count != 0)\r
                     query += " --angle " + mainWindow.drop_angle.SelectedItem;\r
 \r
-            if (mainWindow.drop_chapterFinish.Text == mainWindow.drop_chapterStart.Text && mainWindow.drop_chapterStart.Text != "Auto")\r
-                query += " -c " + mainWindow.drop_chapterStart.Text;\r
-            else if (mainWindow.drop_chapterStart.Text == "Auto" && mainWindow.drop_chapterFinish.Text != "Auto")\r
-                query += " -c " + "0-" + mainWindow.drop_chapterFinish.Text;\r
-            else if (mainWindow.drop_chapterStart.Text != "Auto" && mainWindow.drop_chapterFinish.Text != "Auto")\r
-                query += " -c " + mainWindow.drop_chapterStart.Text + "-" + mainWindow.drop_chapterFinish.Text;\r
-\r
-            // Destination tab\r
-            if (mainWindow.text_destination.Text != "")\r
-                query += " -o " + '"' + mainWindow.text_destination.Text + '"';\r
-\r
-            query += generateTabbedComponentsQuery(mainWindow);\r
-            return query;\r
-        }\r
-\r
-        /// <summary>\r
-        /// Generates a CLI query for the preview function.\r
-        /// This basically forces a shortened version of the encdode.\r
-        /// </summary>\r
-        /// <param name="mainWindow"></param>\r
-        /// <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
-        {\r
-            int seconds;\r
-            int.TryParse(duration, out seconds);\r
-\r
-            // Source tab\r
-            string query = "";\r
 \r
-            if ((mainWindow.sourcePath != "") && (mainWindow.sourcePath.Trim() != "Click 'Source' to continue"))\r
-                query = " -i " + '"' + mainWindow.sourcePath + '"';\r
+            if (duration != 0 && preview != null) // Preivew Query\r
+            {\r
+                query += " --previews " + Properties.Settings.Default.previewScanCount + " ";\r
+                query += " --start-at-preview " + preview;\r
+                query += " --stop-at duration:" + duration + " ";\r
 \r
-            if (mainWindow.drp_dvdtitle.Text != "Automatic")\r
+                if (mainWindow.text_destination.Text != "")\r
+                    query += " -o " + '"' + mainWindow.text_destination.Text.Replace(".m", "_sample.m") + '"';\r
+            }\r
+            else // Non Preview Query\r
             {\r
-                string[] titleInfo = mainWindow.drp_dvdtitle.Text.Split(' ');\r
-                query += " -t " + titleInfo[0];\r
+                if (mainWindow.drop_chapterFinish.Text == mainWindow.drop_chapterStart.Text && mainWindow.drop_chapterStart.Text != "")\r
+                    query += " -c " + mainWindow.drop_chapterStart.Text;\r
+                else if (mainWindow.drop_chapterStart.Text == "Auto" && mainWindow.drop_chapterFinish.Text != "Auto")\r
+                    query += " -c " + "0-" + mainWindow.drop_chapterFinish.Text;\r
+                else if (mainWindow.drop_chapterStart.Text != "Auto" && mainWindow.drop_chapterFinish.Text != "Auto" && mainWindow.drop_chapterStart.Text != "")\r
+                    query += " -c " + mainWindow.drop_chapterStart.Text + "-" + mainWindow.drop_chapterFinish.Text;\r
+\r
+                if (mainWindow.text_destination.Text != "")\r
+                    query += " -o " + '"' + mainWindow.text_destination.Text + '"';\r
             }\r
 \r
-            if (mainWindow.drop_angle.SelectedIndex != 0)\r
-                query += " --angle " + mainWindow.drop_angle.SelectedItem;\r
-\r
-            query += " --start-at-preview " + preview;\r
-            query += " --stop-at duration:" + duration + " ";\r
-\r
-            // Destination tab\r
-            if (mainWindow.text_destination.Text != "")\r
-                query += " -o " + '"' + mainWindow.text_destination.Text.Replace(".m", "_sample.m") + '"';\r
+            query += GenerateTabbedComponentsQuery(mainWindow);\r
 \r
-            query += generateTabbedComponentsQuery(mainWindow);\r
             return query;\r
         }\r
 \r
@@ -96,7 +72,7 @@ namespace Handbrake.Functions
         /// </summary>\r
         /// <param name="mainWindow"></param>\r
         /// <returns></returns>\r
-        public static string generateTabbedComponentsQuery(frmMain mainWindow)\r
+        public static string GenerateTabbedComponentsQuery(frmMain mainWindow)\r
         {\r
             string query = "";\r
 \r
@@ -117,31 +93,32 @@ namespace Handbrake.Functions
             #region Picture Settings Tab\r
 \r
             // Use MaxWidth for built-in presets and width for user settings.\r
-            if (mainWindow.PictureSettings.maxWidth == 0)\r
+            if (mainWindow.PictureSettings.PresetMaximumResolution.Width == 0)\r
             {\r
-\r
-                if (mainWindow.PictureSettings.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.PictureSettings.text_width.Text != "")\r
-                    query += " -X " + mainWindow.PictureSettings.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.PictureSettings.maxHeight == 0)\r
+            if (mainWindow.PictureSettings.PresetMaximumResolution.Height == 0)\r
             {\r
-                if (mainWindow.PictureSettings.text_height.Text != "0")\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.PictureSettings.text_height.Text != "")\r
-                    query += " -Y " + mainWindow.PictureSettings.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.PictureSettings.crop_top.Text;\r
@@ -173,17 +150,25 @@ namespace Handbrake.Functions
                     break;\r
                 case 3:\r
                     query += " --custom-anamorphic ";\r
-                    query += " --display-width " + mainWindow.PictureSettings.txt_displayWidth.Text + " ";\r
+\r
+                    if (mainWindow.PictureSettings.drp_modulus.SelectedIndex != 0)\r
+                        query += " --modulus " + mainWindow.PictureSettings.drp_modulus.SelectedItem;\r
+\r
+                    if (mainWindow.PictureSettings.check_KeepAR.Checked)\r
+                        query += " --display-width " + mainWindow.PictureSettings.updownDisplayWidth.Text + " ";\r
+\r
                     if (mainWindow.PictureSettings.check_KeepAR.Checked)\r
                         query += " --keep-display-aspect ";\r
-                    if (mainWindow.PictureSettings.txt_parWidth.Text != "" && mainWindow.PictureSettings.txt_parHeight.Text != "")\r
-                        query += " --pixel-aspect " + mainWindow.PictureSettings.txt_parWidth.Text + ":" + mainWindow.PictureSettings.txt_parHeight.Text + " ";\r
+\r
+                    if (!mainWindow.PictureSettings.check_KeepAR.Checked)\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.Filters.getCLIQuery;           \r
+            query += mainWindow.Filters.getCLIQuery;\r
             #endregion\r
 \r
             #region Video Settings Tab\r
@@ -214,6 +199,7 @@ namespace Handbrake.Functions
             // Video Quality Setting\r
             if (mainWindow.radio_cq.Checked)\r
             {\r
+                double cqStep = Properties.Settings.Default.x264cqstep;\r
                 double value;\r
                 switch (mainWindow.drp_videoEncoder.Text)\r
                 {\r
@@ -222,15 +208,10 @@ namespace Handbrake.Functions
                         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 * cqStep;\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
@@ -251,7 +232,7 @@ namespace Handbrake.Functions
 \r
             #region Audio Settings Tab\r
 \r
-            ListView audioTracks = mainWindow.AudioSettings.getAudioPanel();\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
@@ -285,7 +266,7 @@ namespace Handbrake.Functions
 \r
                 // Sample Rate (-R)\r
                 if (row.SubItems[4].Text != String.Empty)\r
-                    samplerates.Add(row.SubItems[4].Text.Replace("Auto", "Auto"));\r
+                    samplerates.Add(row.SubItems[4].Text);\r
 \r
                 // Audio Bitrate (-B)\r
                 if (row.SubItems[5].Text != String.Empty)\r
@@ -371,8 +352,9 @@ namespace Handbrake.Functions
             firstLoop = true; audioItems = ""; // Reset for another pass.\r
 \r
             // DRC (-D)\r
-            foreach (String item in drcs)\r
+            foreach (var itm in drcs)\r
             {\r
+                string item = itm.ToString(new CultureInfo("en-US"));\r
                 if (firstLoop)\r
                 {\r
                     audioItems = item; firstLoop = false;\r
@@ -386,72 +368,114 @@ namespace Handbrake.Functions
             #endregion\r
 \r
             #region Subtitles Tab\r
-\r
             if (mainWindow.Subtitles.lv_subList.Items.Count != 0) // If we have subtitle tracks\r
             {\r
-                // Find --subtitle <string>\r
-                query += " --subtitle ";\r
-                String subtitleTracks = "";\r
-                String itemToAdd;\r
-                foreach (ListViewItem item in mainWindow.Subtitles.lv_subList.Items)\r
+                IDictionary<string, string> langMap = Main.mapLanguages();\r
+\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
+                string srtDefault = String.Empty;\r
+                int srtCount = 0;\r
+\r
+                List<Controls.SubtitleInfo> SubList = mainWindow.Subtitles.GetSubtitleInfoList();\r
+\r
+                foreach (var item in SubList)\r
                 {\r
-                    if (item.SubItems[1].Text.Contains("Foreign Audio Search"))\r
-                        itemToAdd = "scan";\r
-                    else\r
+                    string itemToAdd, trackID;\r
+\r
+                    if (item.SrtPath != "-") // We have an SRT file\r
                     {\r
-                        string[] tempSub = item.SubItems[1].Text.Split(' ');\r
-                        itemToAdd = tempSub[0];\r
-                    }\r
+                        srtCount++; // SRT track id.\r
 \r
-                    subtitleTracks += subtitleTracks == "" ? itemToAdd : "," + itemToAdd;\r
-                }\r
-                query += subtitleTracks;\r
+                        srtLang += srtLang == "" ? langMap[item.SrtLang] : "," + langMap[item.SrtLang];\r
+                        srtCodeset += srtCodeset == "" ? item.SrtCharCode : "," + item.SrtCharCode;\r
 \r
+                        if (item.Default == "Yes") // default\r
+                            srtDefault = srtCount.ToString();\r
 \r
-                // Find --subtitle-forced\r
-                String forcedTrack = "";\r
-                foreach (ListViewItem item in mainWindow.Subtitles.lv_subList.Items)\r
-                {\r
-                    itemToAdd = "";\r
-                    string[] tempSub = item.SubItems[1].Text.Split(' ');\r
-                    string trackID = tempSub[0];\r
+                        itemToAdd = item.SrtPath;\r
+                        srtFile += srtFile == "" ? itemToAdd : "," + itemToAdd;\r
 \r
-                    if (item.SubItems[2].Text == "Yes")\r
-                        itemToAdd = trackID;\r
+                        itemToAdd = item.SrtOffset.ToString();\r
+                        srtOffset += srtOffset == "" ? itemToAdd : "," + itemToAdd;\r
+                    }\r
+                    else // We have Bitmap or CC\r
+                    {\r
+                        string[] tempSub;\r
 \r
-                    if (itemToAdd != "")\r
-                        forcedTrack += forcedTrack == "" ? itemToAdd : "," + itemToAdd;\r
-                }\r
-                if (forcedTrack != "")\r
-                    query += " --subtitle-forced " + forcedTrack;\r
+                        // Find --subtitle <string>\r
+                        if (item.Track.Contains("Foreign Audio Search"))\r
+                            itemToAdd = "scan";\r
+                        else\r
+                        {\r
+                            tempSub = item.Track.Split(' ');\r
+                            itemToAdd = tempSub[0];\r
+                        }\r
 \r
+                        subtitleTracks += subtitleTracks == "" ? itemToAdd : "," + itemToAdd;\r
 \r
-                // Find --subtitle-burn and --subtitle-default\r
-                String burned = "";\r
-                String defaultTrack = "";\r
-                foreach (ListViewItem item in mainWindow.Subtitles.lv_subList.Items)\r
-                {\r
-                    string[] tempSub = item.SubItems[1].Text.Split(' ');\r
-                    string trackID = tempSub[0];\r
+                        // Find --subtitle-forced\r
+                        itemToAdd = "";\r
+                        tempSub = item.Track.Split(' ');\r
+                        trackID = tempSub[0];\r
+\r
+                        if (item.Forced == "Yes")\r
+                            itemToAdd = "scan";\r
+\r
+                        if (itemToAdd != "")\r
+                            subtitleForced += subtitleForced == "" ? itemToAdd : "," + itemToAdd;\r
 \r
-                    if (trackID.Trim() == "Foreign")\r
-                        trackID = "scan";\r
+                        // Find --subtitle-burn and --subtitle-default\r
+                        trackID = tempSub[0];\r
 \r
-                    if (item.SubItems[3].Text == "Yes") // Burned\r
-                        burned = trackID;\r
+                        if (trackID.Trim() == "Foreign")\r
+                            trackID = "scan";\r
 \r
-                    if (item.SubItems[4].Text == "Yes") // Burned\r
-                        defaultTrack = trackID;\r
+                        if (item.Burned == "Yes") // burn\r
+                            subtitleBurn = trackID;\r
 \r
+                        if (item.Default == "Yes") // default\r
+                            subtitleDefault = trackID;\r
+                    }\r
                 }\r
-                if (burned != "")\r
-                    query += " --subtitle-burn " + burned;\r
 \r
-                if (defaultTrack != "")\r
-                    query += " --subtitle-default " + defaultTrack;\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
-            }\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
+                    if (srtDefault != "")\r
+                        query += " --srt-default=" + srtDefault;\r
+                }\r
 \r
+            }\r
             #endregion\r
 \r
             #region Chapter Markers\r
@@ -467,7 +491,7 @@ namespace Handbrake.Functions
             string[] titlesplit = source_title.Split(' ');\r
             source_title = titlesplit[0];\r
 \r
-            if (mainWindow.Check_ChapterMarkers.Checked)\r
+            if (mainWindow.Check_ChapterMarkers.Checked && mainWindow.Check_ChapterMarkers.Enabled)\r
             {\r
                 if (dest_name.Trim() != String.Empty)\r
                 {\r
@@ -497,8 +521,8 @@ namespace Handbrake.Functions
 \r
             query += " -v " + Properties.Settings.Default.verboseLevel;\r
 \r
-            if (Properties.Settings.Default.dvdnav)\r
-                query += " --dvdnav";\r
+            if (Properties.Settings.Default.noDvdNav)\r
+                query += " --no-dvdnav";\r
             #endregion\r
 \r
             return query;\r
@@ -560,7 +584,6 @@ namespace Handbrake.Functions
                 file.Close();\r
                 file.Dispose();\r
                 return true;\r
-\r
             }\r
             catch (Exception exc)\r
             {\r