/// <summary> /// FFprobe Detect Metadata (Method) /// </summary> public static void Metadata(MainWindow mainwindow) { // -------------------------------------------------------------------- // Section: FFprobe // -------------------------------------------------------------------- // Log Console Message ///////// Log.WriteAction = () => { Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("FFprobe")) { Foreground = Log.ConsoleTitle }); }; Log.LogActions.Add(Log.WriteAction); // Only Run FFprobe if Input File is Not Null // Strange FFprobe Class problem - methods halting after InputFileInfo() // unless Null Check is put here instead of inside the Class. if (!string.IsNullOrWhiteSpace(mainwindow.tbxInput.Text) //&& !string.IsNullOrEmpty(MainWindow.inputDir) && !string.IsNullOrEmpty(FFprobe.ffprobe)) { // ------------------------- // FFprobe Video Entry Type Containers // ------------------------- FFprobe.VideoEntryType(mainwindow); // ------------------------- // FFprobe Audio Entry Type Containers // ------------------------- FFprobe.AudioEntryType(mainwindow); // ------------------------- // FFprobe File Info // ------------------------- argsFrameRate = " -i " + "\"" + mainwindow.tbxInput.Text + "\"" + " -select_streams v:0 -show_entries stream=r_frame_rate -v quiet -of csv=\"p=0\""; argsSize = " -i " + "\"" + mainwindow.tbxInput.Text + "\"" + " -select_streams v:0 -show_entries format=size -v quiet -of csv=\"p=0\""; argsDuration = " -i " + "\"" + mainwindow.tbxInput.Text + "\"" + " -select_streams v:0 -show_entries format=duration -v quiet -of csv=\"p=0\""; argsVideoCodec = " -i " + "\"" + mainwindow.tbxInput.Text + "\"" + " -select_streams v:0 -show_entries stream=codec_name -v quiet -of csv=\"p=0\""; argsVideoBitrate = " -i " + "\"" + mainwindow.tbxInput.Text + "\"" + " -select_streams v:0 -show_entries " + vEntryType + " -v quiet -of csv=\"p=0\""; argsAudioCodec = " -i " + "\"" + mainwindow.tbxInput.Text + "\"" + " -select_streams a:0 -show_entries stream=codec_name -v quiet -of csv=\"p=0\""; argsAudioBitrate = " -i" + " " + "\"" + mainwindow.tbxInput.Text + "\"" + " -select_streams a:0 -show_entries " + aEntryType + " -v quiet -of csv=\"p=0\""; inputFrameRate = InputFileInfo(mainwindow, argsFrameRate); inputSize = InputFileInfo(mainwindow, argsSize); inputDuration = InputFileInfo(mainwindow, argsDuration); inputVideoCodec = InputFileInfo(mainwindow, argsVideoCodec); inputVideoBitrate = InputFileInfo(mainwindow, argsVideoBitrate); inputAudioCodec = InputFileInfo(mainwindow, argsAudioCodec); inputAudioBitrate = InputFileInfo(mainwindow, argsAudioBitrate); // Log won't write the input data unless we pass it to a new string string logInputFrameRate = inputFrameRate; string logInputSize = inputSize; string logInputDuration = inputDuration; string logInputVideoCodec = inputVideoCodec; string logInputVideoBitrate = inputVideoBitrate; string logInputAudioCodec = inputAudioCodec; string logInputAudioBitrate = inputAudioBitrate; // -------------------------------------------------------------------- // Section: Input // -------------------------------------------------------------------- Log.WriteAction = () => { // Log Console Message ///////// Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Input File Details")) { Foreground = Log.ConsoleTitle }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Directory: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(MainWindow.inputDir) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("General")) { Foreground = Log.ConsoleAction }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Container: ")) { Foreground = Log.ConsoleDefault }); // Single File if (!string.IsNullOrEmpty(MainWindow.inputExt)) { Log.logParagraph.Inlines.Add(new Run(MainWindow.inputExt) { Foreground = Log.ConsoleDefault }); } // Batch if (!string.IsNullOrEmpty(MainWindow.batchExt) && MainWindow.batchExt != "extension") { Log.logParagraph.Inlines.Add(new Run(MainWindow.batchExt) { Foreground = Log.ConsoleDefault }); } Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Size: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(logInputSize) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Duration: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(logInputDuration) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Video")) { Foreground = Log.ConsoleAction }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Codec: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(logInputVideoCodec) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Bitrate: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(logInputVideoBitrate) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("FPS: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(logInputFrameRate) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Audio")) { Foreground = Log.ConsoleAction }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Codec: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(logInputAudioCodec) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Bitrate: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(Convert.ToString(logInputAudioBitrate)) { Foreground = Log.ConsoleDefault }); }; Log.LogActions.Add(Log.WriteAction); } else { // Log Console Message ///////// Log.WriteAction = () => { Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Input File Not Found")) { Foreground = Log.ConsoleWarning }); }; Log.LogActions.Add(Log.WriteAction); } // -------------------------------------------------------------------- // Section: Output // -------------------------------------------------------------------- // Log Console Message ///////// Log.WriteAction = () => { Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Output File Settings")) { Foreground = Log.ConsoleTitle }); }; Log.LogActions.Add(Log.WriteAction); // Log Console Message ///////// Log.WriteAction = () => { Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Directory: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(MainWindow.outputDir) { Foreground = Log.ConsoleDefault }); }; Log.LogActions.Add(Log.WriteAction); // -------------------------------------------------- // Category: General // -------------------------------------------------- // Log Console Message ///////// Log.WriteAction = () => { Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("General")) { Foreground = Log.ConsoleAction }); }; Log.LogActions.Add(Log.WriteAction); // ------------------------- // Format // ------------------------- // OutputFormat() is not called because it is instead used in Controls // Use a Message for Log Console // Log Console Message ///////// Log.WriteAction = () => { Log.logParagraph.Inlines.Add(new LineBreak()); Log.logParagraph.Inlines.Add(new Bold(new Run("Format: ")) { Foreground = Log.ConsoleDefault }); Log.logParagraph.Inlines.Add(new Run(MainWindow.outputExt) { Foreground = Log.ConsoleDefault }); }; Log.LogActions.Add(Log.WriteAction); }
/// <summary> /// Debug Test Button /// </summary> private void btnDebugTest_Click(object sender, RoutedEventArgs e) { // ------------------------- // Keep FFmpeg Window Toggle // ------------------------- //MainWindow.KeepWindow(mainwindow); // ------------------------- // Batch Extention Period Check // ------------------------- MainWindow.BatchExtCheck(mainwindow); // ------------------------- // Set FFprobe Path // ------------------------- MainWindow.FFprobePath(mainwindow); // ------------------------- // Ready Halts // ------------------------- MainWindow.ReadyHalts(mainwindow); // ------------------------- // Background Thread Worker // ------------------------- BackgroundWorker fileprocess = new BackgroundWorker(); fileprocess.WorkerSupportsCancellation = true; fileprocess.WorkerReportsProgress = true; fileprocess.DoWork += new DoWorkEventHandler(delegate(object o, DoWorkEventArgs args) { BackgroundWorker b = o as BackgroundWorker; // Cross-Thread Communication this.Dispatcher.Invoke(() => { // ------------------------- // Single // ------------------------- if (mainwindow.tglBatch.IsChecked == false) { // ------------------------- // FFprobe Detect Metadata // ------------------------- FFprobe.Metadata(mainwindow); // ------------------------- // FFmpeg Generate Arguments (Single) // ------------------------- //disabled if batch FFmpeg.FFmpegSingleGenerateArgs(mainwindow); } // ------------------------- // Batch // ------------------------- else if (mainwindow.tglBatch.IsChecked == true) { // ------------------------- // FFprobe Video Entry Type Containers // ------------------------- //FFprobe.VideoEntryTypeBatch(this); FFprobe.VideoEntryType(mainwindow); // ------------------------- // FFprobe Video Entry Type Containers // ------------------------- //FFprobe.AudioEntryTypeBatch(this); FFprobe.AudioEntryType(mainwindow); // ------------------------- // FFmpeg Generate Arguments (Batch) // ------------------------- //disabled if single file FFmpeg.FFmpegBatchGenerateArgs(mainwindow); } }); //end dispatcher }); //end thread // When background worker completes task fileprocess.RunWorkerCompleted += new RunWorkerCompletedEventHandler(delegate(object o, RunWorkerCompletedEventArgs args) { // ------------------------- // Write Variables to Debug Window // ------------------------- DebugWrite(this, mainwindow); // ------------------------- // Close the Background Worker // ------------------------- fileprocess.CancelAsync(); fileprocess.Dispose(); // ------------------------- // Clear Variables for next Run // ------------------------- MainWindow.ClearVariables(mainwindow); GC.Collect(); }); //end worker completed task // ------------------------- // Background Worker Run Async // ------------------------- fileprocess.RunWorkerAsync(); }
/// <summary> /// Debug Test Button /// </summary> private void btnDebugTest_Click(object sender, RoutedEventArgs e) { MainWindow mainwindow = (MainWindow)System.Windows.Application.Current.MainWindow; ViewModel vm = mainwindow.DataContext as ViewModel; // ------------------------- // Clear Variables before Run // ------------------------- MainWindow.ClearGlobalVariables(vm); // ------------------------- // Batch Extention Period Check // ------------------------- MainWindow.BatchExtCheck(vm); // ------------------------- // Set FFprobe Path // ------------------------- MainWindow.FFprobePath(vm); // ------------------------- // Set youtube-dl Path // ------------------------- MainWindow.youtubedlPath(vm); // ------------------------- // Ready Halts // ------------------------- if (MainWindow.ReadyHalts(vm) == true) { // ------------------------- // Single // ------------------------- if (vm.Batch_IsChecked == false) { // ------------------------- // FFprobe Detect Metadata // ------------------------- FFprobe.Metadata(vm); // ------------------------- // FFmpeg Generate Arguments (Single) // ------------------------- //disabled if batch FFmpeg.FFmpegSingleGenerateArgs(vm); } // ------------------------- // Batch // ------------------------- else if (vm.Batch_IsChecked == true) { // ------------------------- // FFprobe Video Entry Type Containers // ------------------------- FFprobe.VideoEntryType(vm); // ------------------------- // FFprobe Video Entry Type Containers // ------------------------- FFprobe.AudioEntryType(vm); // ------------------------- // FFmpeg Generate Arguments (Batch) // ------------------------- //disabled if single file FFmpeg.FFmpegBatchGenerateArgs(vm); } // ------------------------- // Write Variables to Debug Window // ------------------------- DebugWrite(this, vm); // ------------------------- // Clear Variables for next Run // ------------------------- MainWindow.ClearGlobalVariables(vm); GC.Collect(); } }