X-Git-Url: http://git.osdn.jp/view?a=blobdiff_plain;f=win%2FC%23%2FfrmPreview.cs;h=59e6c2520a3fc574164f9fb10034ef1494032eae;hb=31e8e90017a38e8b35b8297eb338d6f4f79de6f4;hp=dabde2bb1a4f997c6ebb5a357a0f32023d4684ff;hpb=17cdef8b0d5e5c68011a23e69cb43487cd14ba9d;p=handbrake-jp%2Fhandbrake-jp-git.git diff --git a/win/C#/frmPreview.cs b/win/C#/frmPreview.cs index dabde2bb..59e6c252 100644 --- a/win/C#/frmPreview.cs +++ b/win/C#/frmPreview.cs @@ -4,6 +4,9 @@ using System.Threading; using System.Diagnostics; using System.Runtime.InteropServices; using System.IO; +using Handbrake.EncodeQueue; +using Handbrake.Functions; +using QTOControlLib; using QTOLibrary; namespace Handbrake @@ -12,48 +15,98 @@ namespace Handbrake { QueryGenerator hb_common_func = new QueryGenerator(); - Functions.Encode process = new Functions.Encode(); + EncodeAndQueueHandler process = new EncodeAndQueueHandler(); private delegate void UpdateUIHandler(); String currently_playing = ""; readonly frmMain mainWindow; - private Process hbProc; private Thread player; + private Boolean noQT; public frmPreview(frmMain mw) { - InitializeComponent(); + try + { + InitializeComponent(); + } + catch (Exception exc) + { + MessageBox.Show(mw, "It would appear QuickTime 7 is not installed or not accessible. QuickTime preview functionality will be disabled! \n\n Debug Info:\n" + exc, "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning); + btn_playQT.Enabled = false; + noQT = true; + } this.mainWindow = mw; cb_preview.SelectedIndex = 0; cb_duration.SelectedIndex = 1; } - + #region Encode Sample private void btn_playVLC_Click(object sender, EventArgs e) { + lbl_status.Visible = true; + try + { + QTControl.URL = ""; + if (File.Exists(currently_playing)) + File.Delete(currently_playing); + } + catch (Exception) + { + MessageBox.Show(this, "Unable to delete previous preview file. You may need to restart the application.", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); + } + btn_playQT.Enabled = false; btn_playVLC.Enabled = false; lbl_status.Text = "Encoding Sample for (VLC) ..."; - String query = hb_common_func.GeneratePreviewQuery(mainWindow, cb_duration.Text, cb_preview.Text); - ThreadPool.QueueUserWorkItem(procMonitor, query); + int duration; + int.TryParse(cb_duration.Text, out duration); + String query = hb_common_func.GenerateCLIQuery(mainWindow, duration, cb_preview.Text); + ThreadPool.QueueUserWorkItem(procMonitor, query); } private void btn_playQT_Click(object sender, EventArgs e) { - btn_playQT.Enabled = false; - btn_playVLC.Enabled = false; - lbl_status.Text = "Encoding Sample for (QT) ..."; - String query = hb_common_func.GeneratePreviewQuery(mainWindow, cb_duration.Text, cb_preview.Text); - ThreadPool.QueueUserWorkItem(procMonitor, query); + if (mainWindow.text_destination.Text.Contains(".mkv")) + { + MessageBox.Show(this, + "The QuickTime Control does not support MKV files, It is recommended you use VLC option instead.", + "Warning", MessageBoxButtons.OK, MessageBoxIcon.Warning); + } + else + { + lbl_status.Visible = true; + try + { + QTControl.URL = ""; + if (File.Exists(currently_playing)) + File.Delete(currently_playing); + } + catch (Exception) + { + MessageBox.Show(this, "Unable to delete previous preview file. You may need to restart the application.", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); + } + + btn_playQT.Enabled = false; + btn_playVLC.Enabled = false; + lbl_status.Text = "Encoding Sample for (QT) ..."; + int duration; + int.TryParse(cb_duration.Text, out duration); + String query = hb_common_func.GenerateCLIQuery(mainWindow, duration, cb_preview.Text); + + ThreadPool.QueueUserWorkItem(procMonitor, query); + } } private void procMonitor(object state) { // Make sure we are not already encoding and if we are then display an error. - if (hbProc != null) - MessageBox.Show("Handbrake is already encoding a video!", "Status", MessageBoxButtons.OK, MessageBoxIcon.Warning); + if (process.hbProcess != null) + MessageBox.Show(this, "Handbrake is already encoding a video!", "Status", MessageBoxButtons.OK, MessageBoxIcon.Warning); else { - hbProc = process.runCli(this, (string)state); - hbProc.WaitForExit(); - hbProc = null; + process.RunCli((string)state); + if (process.hbProcess != null) + { + process.hbProcess.WaitForExit(); + process.hbProcess = null; + } encodeCompleted(); } } @@ -66,7 +119,8 @@ namespace Handbrake BeginInvoke(new UpdateUIHandler(encodeCompleted)); return; } - btn_playQT.Enabled = true; + if (!noQT) + btn_playQT.Enabled = true; btn_playVLC.Enabled = true; // Decide which player to use. @@ -76,19 +130,19 @@ namespace Handbrake // Get the sample filename if (mainWindow.text_destination.Text != "") - currently_playing = mainWindow.text_destination.Text.Replace(".mp4", "_sample.mp4").Replace(".m4v", "_sample.m4v").Replace(".avi", "_sample.avi").Replace(".ogm", "_sample.ogm"); + currently_playing = mainWindow.text_destination.Text.Replace(".mp4", "_sample.mp4").Replace(".m4v", "_sample.m4v").Replace(".mkv", "_sample.mkv"); ; // Play back in QT or VLC if (playerSelection == "QT") play(); - else + else playVLC(); - + lbl_status.Text = ""; } catch (Exception exc) { - MessageBox.Show("frmPreview.cs encodeCompleted " + exc, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); + MessageBox.Show(this, "frmPreview.cs encodeCompleted " + exc, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error); } } #endregion @@ -102,6 +156,7 @@ namespace Handbrake { player = new Thread(OpenMovie) { IsBackground = true }; player.Start(); + lbl_status.Visible = false; } /// @@ -122,11 +177,12 @@ namespace Handbrake lbl_status.Text = "VLC will now launch."; } else - MessageBox.Show("Unable to detect VLC Player. \nPlease make sure VLC is installed and the directory specified in the program options is correct.", "VLC", MessageBoxButtons.OK, MessageBoxIcon.Warning); + MessageBox.Show(this, "Unable to detect VLC Player. \nPlease make sure VLC is installed and the directory specified in HandBrake's options is correct. (See: \"Tools Menu > Options > Picture Tab\") ", "VLC", MessageBoxButtons.OK, MessageBoxIcon.Warning); } else - MessageBox.Show("Unable to find the preview file. Either the file was deleted or the encode failed. Check the activity log for details.", "VLC", MessageBoxButtons.OK, MessageBoxIcon.Warning); + MessageBox.Show(this, "Unable to find the preview file. Either the file was deleted or the encode failed. Check the activity log for details.", "VLC", MessageBoxButtons.OK, MessageBoxIcon.Warning); } + lbl_status.Visible = false; } /// @@ -143,28 +199,23 @@ namespace Handbrake return; } QTControl.URL = currently_playing; - QTControl.Width = QTControl.Movie.Width; - QTControl.Height = QTControl.Movie.Height; - // The initial control size is 64,64. If we do not reload the clip here - // it'll scale the video from 64,64. - // Unsure why as it correctly resizes the control to the movies actual size. + QTControl.SetSizing(QTSizingModeEnum.qtControlFitsMovie, true); QTControl.URL = currently_playing; - QTControl.SetScale(0); QTControl.Show(); - this.Width = QTControl.Width + 5; - this.Height = QTControl.Height + 90; + this.ClientSize = QTControl.Size; + this.Height += 25; } catch (COMException ex) { QTUtils qtu = new QTUtils(); - MessageBox.Show("Unable to open movie:\n\nError Code: " + ex.ErrorCode.ToString("X") + "\nQT Error code : " + qtu.QTErrorFromErrorCode(ex.ErrorCode)); + MessageBox.Show(this, "Unable to open movie:\n\nError Code: " + ex.ErrorCode.ToString("X") + "\nQT Error code : " + qtu.QTErrorFromErrorCode(ex.ErrorCode), "QT", MessageBoxButtons.OK, MessageBoxIcon.Warning); } catch (Exception ex) { - MessageBox.Show("Unable to open movie:\n\n" + ex); + MessageBox.Show(this, "Unable to open movie:\n\n" + ex, "QT", MessageBoxButtons.OK, MessageBoxIcon.Warning); } } #endregion } -} \ No newline at end of file +}