OSDN Git Service

WinGui:
[handbrake-jp/handbrake-jp-git.git] / win / C# / frmMain.cs
index 103c28e..4b2ddb7 100644 (file)
@@ -14,6 +14,7 @@ using System.Diagnostics;
 using System.Threading;\r
 using Handbrake.EncodeQueue;\r
 using Handbrake.Functions;\r
+using Handbrake.Model;\r
 using Handbrake.Presets;\r
 using Handbrake.Parsing;\r
 \r
@@ -92,7 +93,7 @@ namespace Handbrake
             // Setup the GUI components\r
             lblStatus.Text = "Setting up the GUI ...";\r
             Application.DoEvents();\r
-            loadPresetPanel();                       // Load the Preset Panel\r
+            LoadPresetPanel();                       // Load the Preset Panel\r
             treeView_presets.ExpandAll();\r
             lbl_encode.Text = "";\r
             drop_mode.SelectedIndex = 0;\r
@@ -221,7 +222,7 @@ namespace Handbrake
                 this.Resize += new EventHandler(frmMain_Resize);\r
 \r
             // Handle Encode Start / Finish / Pause\r
-            \r
+\r
             encodeQueue.QueuePauseRequested += new EventHandler(encodePaused);\r
             encodeQueue.EncodeStarted += new EventHandler(encodeStarted);\r
             encodeQueue.EncodeEnded += new EventHandler(encodeEnded);\r
@@ -320,22 +321,22 @@ namespace Handbrake
         private void encodeStarted(object sender, EventArgs e)\r
         {\r
             lastAction = "encode";\r
-            setEncodeStarted();\r
+            SetEncodeStarted();\r
 \r
             // Experimental HBProc Process Monitoring.\r
             if (Properties.Settings.Default.enocdeStatusInGui)\r
             {\r
-                Thread encodeMon = new Thread(encodeMonitorThread);\r
+                Thread encodeMon = new Thread(EncodeMonitorThread);\r
                 encodeMon.Start();\r
             }\r
         }\r
         private void encodeEnded(object sender, EventArgs e)\r
         {\r
-            setEncodeFinished();\r
+            SetEncodeFinished();\r
         }\r
         private void encodePaused(object sender, EventArgs e)\r
         {\r
-            setEncodeFinished();\r
+            SetEncodeFinished();\r
         }\r
         #endregion\r
 \r
@@ -373,7 +374,7 @@ namespace Handbrake
         private void mnu_presetReset_Click(object sender, EventArgs e)\r
         {\r
             presetHandler.UpdateBuiltInPresets();\r
-            loadPresetPanel();\r
+            LoadPresetPanel();\r
             if (treeView_presets.Nodes.Count == 0)\r
                 MessageBox.Show("Unable to load the presets.xml file. Please select \"Update Built-in Presets\" from the Presets Menu. \nMake sure you are running the program in Admin mode if running on Vista. See Windows FAQ for details!", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);\r
             else\r
@@ -384,7 +385,7 @@ namespace Handbrake
         private void mnu_delete_preset_Click(object sender, EventArgs e)\r
         {\r
             presetHandler.RemoveBuiltInPresets();\r
-            loadPresetPanel(); // Reload the preset panel\r
+            LoadPresetPanel(); // Reload the preset panel\r
         }\r
         private void mnu_SelectDefault_Click(object sender, EventArgs e)\r
         {\r
@@ -567,7 +568,7 @@ namespace Handbrake
                         nodeStatus.Add(node.IsExpanded);\r
 \r
                     // Now reload the preset panel\r
-                    loadPresetPanel();\r
+                    LoadPresetPanel();\r
 \r
                     // And finally, re-expand any of the nodes if required\r
                     int i = 0;\r
@@ -661,7 +662,7 @@ namespace Handbrake
         private void btn_source_Click(object sender, EventArgs e)\r
         {\r
             mnu_dvd_drive.Visible = true;\r
-            Thread driveInfoThread = new Thread(getDriveInfoThread);\r
+            Thread driveInfoThread = new Thread(SetDriveSelectionMenuItem);\r
             driveInfoThread.Start();\r
         }\r
         private void btn_start_Click(object sender, EventArgs e)\r
@@ -698,7 +699,7 @@ namespace Handbrake
                     }\r
 \r
                     // Update the GUI\r
-                    setEncodeFinished();\r
+                    SetEncodeFinished();\r
                 }\r
             }\r
             else\r
@@ -756,7 +757,7 @@ namespace Handbrake
                         if (encodeQueue.Count > 1)\r
                             queueWindow.Show(false);\r
 \r
-                        setEncodeStarted(); // Encode is running, so setup the GUI appropriately\r
+                        SetEncodeStarted(); // Encode is running, so setup the GUI appropriately\r
                         encodeQueue.Start(); // Start The Queue Encoding Process\r
                         lastAction = "encode";   // Set the last action to encode - Used for activity window.\r
                     }\r
@@ -1698,17 +1699,17 @@ namespace Handbrake
         }\r
         #endregion\r
 \r
-        #region GUI\r
+        #region GUI Functions and Actions\r
         /// <summary>\r
         /// Set the GUI to it's finished encoding state.\r
         /// </summary>\r
-        private void setEncodeFinished()\r
+        private void SetEncodeFinished()\r
         {\r
             try\r
             {\r
                 if (InvokeRequired)\r
                 {\r
-                    BeginInvoke(new UpdateWindowHandler(setEncodeFinished));\r
+                    BeginInvoke(new UpdateWindowHandler(SetEncodeFinished));\r
                     return;\r
                 }\r
 \r
@@ -1734,13 +1735,13 @@ namespace Handbrake
         /// <summary>\r
         /// Set the GUI to it's started encoding state.\r
         /// </summary>\r
-        private void setEncodeStarted()\r
+        private void SetEncodeStarted()\r
         {\r
             try\r
             {\r
                 if (InvokeRequired)\r
                 {\r
-                    BeginInvoke(new UpdateWindowHandler(setEncodeStarted));\r
+                    BeginInvoke(new UpdateWindowHandler(SetEncodeStarted));\r
                     return;\r
                 }\r
 \r
@@ -1755,51 +1756,42 @@ namespace Handbrake
                 MessageBox.Show(exc.ToString());\r
             }\r
         }\r
-        #endregion\r
 \r
-        #region DVD Drive Detection\r
-        private void getDriveInfoThread()\r
+        /// <summary>\r
+        /// Set the DVD Drive selection in the "Source" Menu\r
+        /// </summary>\r
+        private void SetDriveSelectionMenuItem()\r
         {\r
             try\r
             {\r
                 if (InvokeRequired)\r
                 {\r
-                    BeginInvoke(new UpdateWindowHandler(getDriveInfoThread));\r
+                    BeginInvoke(new UpdateWindowHandler(SetDriveSelectionMenuItem));\r
                     return;\r
                 }\r
 \r
-                Boolean foundDrive = false;\r
-                DriveInfo[] theCollectionOfDrives = DriveInfo.GetDrives();\r
-                foreach (DriveInfo curDrive in theCollectionOfDrives)\r
+                List<DriveInformation> drives = Main.GetDrives();\r
+\r
+                if (drives.Count == 0)\r
                 {\r
-                    if (curDrive.DriveType == DriveType.CDRom && curDrive.IsReady)\r
-                    {\r
-                        if (File.Exists(curDrive.RootDirectory + "VIDEO_TS\\VIDEO_TS.IFO"))\r
-                        {\r
-                            this.dvdDrivePath = curDrive.RootDirectory + "VIDEO_TS";\r
-                            this.dvdDriveLabel = curDrive.VolumeLabel;\r
-                            mnu_dvd_drive.Text = this.dvdDrivePath + " (" + this.dvdDriveLabel + ")";\r
-                            foundDrive = true;\r
-                            break;\r
-                        }\r
-                    }\r
+                    mnu_dvd_drive.Text = "[No DVD Drive Ready]";\r
+                    return;\r
                 }\r
 \r
-                if (foundDrive == false)\r
-                    mnu_dvd_drive.Text = "[No DVD Drive Ready]";\r
+                this.dvdDrivePath = drives[0].RootDirectory + "VIDEO_TS";\r
+                this.dvdDriveLabel = drives[0].VolumeLabel;\r
+                mnu_dvd_drive.Text = this.dvdDrivePath + " (" + this.dvdDriveLabel + ")";\r
             }\r
             catch (Exception)\r
             {\r
                 mnu_dvd_drive.Text = "[No DVD Drive Ready / Found]";\r
             }\r
         }\r
-        #endregion\r
 \r
-        #region Public Methods\r
         /// <summary>\r
         /// Access the preset Handler and setup the preset panel.\r
         /// </summary>\r
-        public void loadPresetPanel()\r
+        private void LoadPresetPanel()\r
         {\r
             if (presetHandler.CheckIfPresetsAreOutOfDate())\r
                 if (!Properties.Settings.Default.presetNotification)\r
@@ -1855,12 +1847,15 @@ namespace Handbrake
         #endregion\r
 \r
         #region In-GUI Encode Status (Experimental)\r
-        private void encodeMonitorThread()\r
+        /// <summary>\r
+        /// Starts a new thread to monitor and process the CLI encode status\r
+        /// </summary>\r
+        private void EncodeMonitorThread()\r
         {\r
             try\r
             {\r
                 Parser encode = new Parser(encodeQueue.HbProcess.StandardOutput.BaseStream);\r
-                encode.OnEncodeProgress += encodeOnEncodeProgress;\r
+                encode.OnEncodeProgress += EncodeOnEncodeProgress;\r
                 while (!encode.EndOfStream)\r
                     encode.readEncodeStatus();\r
             }\r
@@ -1869,11 +1864,22 @@ namespace Handbrake
                 MessageBox.Show(exc.ToString(), "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);\r
             }\r
         }\r
-        private void encodeOnEncodeProgress(object Sender, int CurrentTask, int TaskCount, float PercentComplete, float CurrentFps, float AverageFps, TimeSpan TimeRemaining)\r
+        \r
+        /// <summary>\r
+        /// Displays the Encode status in the GUI\r
+        /// </summary>\r
+        /// <param name="Sender"></param>\r
+        /// <param name="CurrentTask"></param>\r
+        /// <param name="TaskCount"></param>\r
+        /// <param name="PercentComplete"></param>\r
+        /// <param name="CurrentFps"></param>\r
+        /// <param name="AverageFps"></param>\r
+        /// <param name="TimeRemaining"></param>\r
+        private void EncodeOnEncodeProgress(object Sender, int CurrentTask, int TaskCount, float PercentComplete, float CurrentFps, float AverageFps, TimeSpan TimeRemaining)\r
         {\r
             if (this.InvokeRequired)\r
             {\r
-                this.BeginInvoke(new EncodeProgressEventHandler(encodeOnEncodeProgress),\r
+                this.BeginInvoke(new EncodeProgressEventHandler(EncodeOnEncodeProgress),\r
                     new object[] { Sender, CurrentTask, TaskCount, PercentComplete, CurrentFps, AverageFps, TimeRemaining });\r
                 return;\r
             }\r
@@ -1881,16 +1887,6 @@ namespace Handbrake
         }\r
         #endregion\r
 \r
-        #region enum\r
-        private enum SourceType\r
-        {\r
-            None = 0,\r
-            Folder,\r
-            DvdDrive,\r
-            VideoFile\r
-        }\r
-        #endregion\r
-\r
         // This is the END of the road ****************************************\r
     }\r
 }
\ No newline at end of file