2020-11-23 16:51:05 +01:00
using Flowframes.Forms ;
using Flowframes.IO ;
using Flowframes.Magick ;
using Flowframes.Main ;
using Flowframes.OS ;
using Flowframes.UI ;
using Microsoft.WindowsAPICodePack.Dialogs ;
using System ;
using System.Diagnostics ;
using System.Drawing ;
using System.IO ;
using System.Linq ;
using System.Windows.Forms ;
using HTAlt.WinForms ;
using Flowframes.Data ;
2020-11-26 20:17:18 +01:00
using Microsoft.WindowsAPICodePack.Taskbar ;
2020-11-27 14:35:32 +01:00
using System.Threading.Tasks ;
2020-11-23 16:51:05 +01:00
namespace Flowframes
{
public partial class Form1 : Form
{
public bool initialized = false ;
public Form1 ( )
{
InitializeComponent ( ) ;
}
private void Form1_Load ( object sender , EventArgs e )
{
CheckForIllegalCrossThreadCalls = false ;
2021-01-15 16:20:25 +01:00
AutoScaleMode = AutoScaleMode . None ;
2020-12-08 20:41:50 +01:00
Text = $"Flowframes {Updater.GetInstalledVer()}" ;
2020-11-23 16:51:05 +01:00
// Main Tab
UIUtils . InitCombox ( interpFactorCombox , 0 ) ;
UIUtils . InitCombox ( outModeCombox , 0 ) ;
2021-01-13 23:05:23 +01:00
UIUtils . InitCombox ( aiModel , 2 ) ;
2020-11-23 16:51:05 +01:00
// Video Utils
UIUtils . InitCombox ( utilsLoopTimesCombox , 0 ) ;
UIUtils . InitCombox ( utilsSpeedCombox , 0 ) ;
UIUtils . InitCombox ( utilsConvCrf , 0 ) ;
Program . mainForm = this ;
Logger . textbox = logBox ;
InitAis ( ) ;
InterpolateUtils . preview = previewPicturebox ;
ConfigParser . LoadComboxIndex ( aiCombox ) ;
2020-12-03 01:20:33 +01:00
UpdateStepByStepControls ( true ) ;
2020-11-29 16:10:31 +01:00
2020-11-23 16:51:05 +01:00
Initialized ( ) ;
2020-11-26 20:17:18 +01:00
Checks ( ) ;
}
2020-11-23 16:51:05 +01:00
2020-12-03 22:06:58 +01:00
void Checks ( )
2020-11-26 20:17:18 +01:00
{
2020-12-07 22:10:58 +01:00
try
{
GetWebInfo . LoadNews ( newsLabel ) ;
GetWebInfo . LoadPatronListCsv ( patronsLabel ) ;
Updater . AsyncUpdateCheck ( ) ;
2021-01-04 14:27:34 +01:00
Python . CheckCompression ( ) ;
2020-12-07 22:10:58 +01:00
}
catch ( Exception e )
{
Logger . Log ( "Non-critical error while performing online checks. See logs for details." ) ;
Logger . Log ( e . Message + "\n" + e . StackTrace , true ) ;
}
2020-11-23 16:51:05 +01:00
}
public HTTabControl GetMainTabControl ( ) { return mainTabControl ; }
public bool IsInFocus ( ) { return ( ActiveForm = = this ) ; }
2020-12-03 22:06:58 +01:00
public void SetTab ( string tabName )
2020-11-25 20:31:21 +01:00
{
2020-12-03 22:06:58 +01:00
foreach ( TabPage tab in mainTabControl . TabPages )
2020-11-25 20:31:21 +01:00
{
if ( tab . Text . ToLower ( ) = = tabName . ToLower ( ) )
mainTabControl . SelectedTab = tab ;
}
mainTabControl . Refresh ( ) ;
mainTabControl . Update ( ) ;
}
2020-12-17 11:32:45 +01:00
public InterpSettings GetCurrentSettings ( )
2020-11-23 16:51:05 +01:00
{
2020-12-02 01:09:41 +01:00
SetTab ( "interpolate" ) ;
2021-01-13 23:05:23 +01:00
return new InterpSettings ( inputTbox . Text . Trim ( ) , outputTbox . Text . Trim ( ) , GetAi ( ) , fpsInTbox . GetFloat ( ) , interpFactorCombox . GetInt ( ) , GetOutMode ( ) , GetModel ( ) ) ;
2020-11-23 16:51:05 +01:00
}
2020-12-17 11:32:45 +01:00
public void LoadBatchEntry ( InterpSettings entry )
2020-11-23 16:51:05 +01:00
{
inputTbox . Text = entry . inPath ;
outputTbox . Text = entry . outPath ;
interpFactorCombox . Text = entry . interpFactor . ToString ( ) ;
aiCombox . SelectedIndex = Networks . networks . IndexOf ( entry . ai ) ;
SetOutMode ( entry . outMode ) ;
}
public void SetStatus ( string str )
{
Logger . Log ( str , true ) ;
statusLabel . Text = str ;
}
public void SetProgress ( int percent )
{
2021-01-28 11:38:45 +01:00
percent = percent . Clamp ( 0 , 100 ) ;
TaskbarManager . Instance . SetProgressValue ( percent , 100 ) ;
longProgBar . Value = percent ;
2020-11-23 16:51:05 +01:00
longProgBar . Refresh ( ) ;
}
2021-01-18 12:32:01 +01:00
public Size currInRes ;
public float currInFps ;
public int currInFrames ;
public void UpdateInputInfo ( )
{
string str = $"Resolution: {(!currInRes.IsEmpty ? $" { currInRes . Width } x { currInRes . Height } " : " Unknown ")} - " ;
str + = $"Framerate: {(currInFps > 0f ? $" { currInFps . ToStringDot ( ) } FPS " : " Unknown ")} - " ;
str + = $"Frame Count: {(currInFrames > 0 ? $" { currInFrames } Frames " : " Unknown ")}" ;
inputInfo . Text = str ;
}
2020-11-23 16:51:05 +01:00
void InitAis ( )
{
foreach ( AI ai in Networks . networks )
aiCombox . Items . Add ( ai . friendlyName + " - " + ai . description ) ;
aiCombox . SelectedIndex = 0 ;
}
public void Initialized ( )
{
initialized = true ;
runBtn . Enabled = true ;
}
private void browseInputBtn_Click ( object sender , EventArgs e )
{
CommonOpenFileDialog dialog = new CommonOpenFileDialog ( ) ;
dialog . InitialDirectory = inputTbox . Text . Trim ( ) ;
dialog . IsFolderPicker = true ;
if ( dialog . ShowDialog ( ) = = CommonFileDialogResult . Ok )
2020-12-08 16:49:47 +01:00
DragDropHandler ( new string [ ] { dialog . FileName } ) ;
2020-11-23 16:51:05 +01:00
}
private void browseInputFileBtn_Click ( object sender , EventArgs e )
{
CommonOpenFileDialog dialog = new CommonOpenFileDialog ( ) ;
dialog . InitialDirectory = inputTbox . Text . Trim ( ) ;
dialog . IsFolderPicker = false ;
if ( dialog . ShowDialog ( ) = = CommonFileDialogResult . Ok )
2020-12-08 16:49:47 +01:00
DragDropHandler ( new string [ ] { dialog . FileName } ) ;
2020-11-23 16:51:05 +01:00
}
private void browseOutBtn_Click ( object sender , EventArgs e )
{
CommonOpenFileDialog dialog = new CommonOpenFileDialog ( ) ;
dialog . InitialDirectory = inputTbox . Text . Trim ( ) ;
dialog . IsFolderPicker = true ;
if ( dialog . ShowDialog ( ) = = CommonFileDialogResult . Ok )
outputTbox . Text = dialog . FileName ;
}
public void runBtn_Click ( object sender , EventArgs e )
{
2020-12-03 22:06:58 +01:00
if ( ! BatchProcessing . busy ) // Don't load values from gui if batch processing is used
2020-12-17 11:32:45 +01:00
Interpolate . current = GetCurrentSettings ( ) ;
2021-01-13 23:05:23 +01:00
2020-12-17 11:32:45 +01:00
Interpolate . Start ( ) ;
2020-12-02 23:11:27 +01:00
}
2021-01-13 23:05:23 +01:00
public string GetModel ( )
2020-12-02 23:11:27 +01:00
{
2021-01-13 23:05:23 +01:00
return aiModel . Text . Split ( '-' ) [ 0 ] . Remove ( " " ) . Remove ( "." ) ;
2020-11-23 16:51:05 +01:00
}
Interpolate . OutMode GetOutMode ( )
{
Interpolate . OutMode outMode = Interpolate . OutMode . VidMp4 ;
2021-01-16 01:19:07 +01:00
if ( outModeCombox . Text . ToLower ( ) . Contains ( "mkv" ) ) outMode = Interpolate . OutMode . VidMkv ;
2020-12-23 16:13:04 +01:00
if ( outModeCombox . Text . ToLower ( ) . Contains ( "webm" ) ) outMode = Interpolate . OutMode . VidWebm ;
if ( outModeCombox . Text . ToLower ( ) . Contains ( "prores" ) ) outMode = Interpolate . OutMode . VidProRes ;
2021-01-16 01:19:07 +01:00
if ( outModeCombox . Text . ToLower ( ) . Contains ( "avi" ) ) outMode = Interpolate . OutMode . VidAvi ;
2020-11-23 16:51:05 +01:00
if ( outModeCombox . Text . ToLower ( ) . Contains ( "gif" ) ) outMode = Interpolate . OutMode . VidGif ;
2020-12-02 15:34:59 +01:00
if ( outModeCombox . Text . ToLower ( ) . Contains ( "image" ) ) outMode = Interpolate . OutMode . ImgPng ;
2020-11-23 16:51:05 +01:00
return outMode ;
}
public void SetOutMode ( Interpolate . OutMode mode )
{
2021-01-16 01:19:07 +01:00
int theIndex = 0 ;
for ( int i = 0 ; i < outModeCombox . Items . Count ; i + + )
{
string currentItem = outModeCombox . Items [ i ] . ToString ( ) . ToLower ( ) ;
if ( mode = = Interpolate . OutMode . VidMkv & & currentItem . Contains ( "mkv" ) ) theIndex = i ;
if ( mode = = Interpolate . OutMode . VidWebm & & currentItem . Contains ( "webm" ) ) theIndex = i ;
if ( mode = = Interpolate . OutMode . VidProRes & & currentItem . Contains ( "prores" ) ) theIndex = i ;
if ( mode = = Interpolate . OutMode . VidAvi & & currentItem . Contains ( "avi" ) ) theIndex = i ;
if ( mode = = Interpolate . OutMode . VidGif & & currentItem . Contains ( "gif" ) ) theIndex = i ;
if ( mode = = Interpolate . OutMode . ImgPng & & currentItem . Contains ( "image" ) ) theIndex = i ;
}
outModeCombox . SelectedIndex = theIndex ;
2020-11-23 16:51:05 +01:00
}
AI GetAi ( )
{
return Networks . networks [ aiCombox . SelectedIndex ] ;
}
void inputTbox_DragEnter ( object sender , DragEventArgs e ) { e . Effect = DragDropEffects . Copy ; }
private void inputTbox_DragDrop ( object sender , DragEventArgs e )
{
2020-12-03 22:21:44 +01:00
DragDropHandler ( ( string [ ] ) e . Data . GetData ( DataFormats . FileDrop ) ) ;
2020-11-23 16:51:05 +01:00
}
void outputTbox_DragEnter ( object sender , DragEventArgs e ) { e . Effect = DragDropEffects . Copy ; }
private void outputTbox_DragDrop ( object sender , DragEventArgs e )
{
if ( Program . busy ) return ;
string [ ] files = ( string [ ] ) e . Data . GetData ( DataFormats . FileDrop ) ;
outputTbox . Text = files [ 0 ] ;
}
private void fpsInTbox_TextChanged ( object sender , EventArgs e )
{
fpsInTbox . Text = fpsInTbox . Text . TrimNumbers ( true ) ;
2020-12-17 11:32:45 +01:00
//Interpolate.SetFps(fpsInTbox.GetFloat());
2020-11-23 16:51:05 +01:00
UpdateOutputFPS ( ) ;
}
public void UpdateOutputFPS ( )
{
float fpsOut = fpsInTbox . GetFloat ( ) * interpFactorCombox . GetFloat ( ) ;
fpsOutTbox . Text = fpsOut . ToString ( ) ;
2020-12-17 11:32:45 +01:00
//Interpolate.interpFactor = interpFactorCombox.GetInt();
2020-11-23 16:51:05 +01:00
}
private void interpFactorCombox_SelectedIndexChanged ( object sender , EventArgs e )
{
UpdateOutputFPS ( ) ;
2020-12-17 11:32:45 +01:00
int guiInterpFactor = interpFactorCombox . GetInt ( ) ;
2021-01-13 15:47:05 +01:00
if ( ! initialized )
return ;
string aiName = GetAi ( ) . aiName . Replace ( "_" , "-" ) ;
if ( ! Program . busy & & guiInterpFactor > 2 & & ! GetAi ( ) . supportsAnyExp & & Config . GetInt ( "autoEncMode" ) > 0 & & ! Logger . GetLastLine ( ) . Contains ( aiName ) )
Logger . Log ( $"Warning: {aiName} doesn't natively support 4x/8x and will run multiple times for {guiInterpFactor}x. Auto-Encode will only work on the last run." ) ;
2020-11-23 16:51:05 +01:00
}
2021-01-04 14:27:34 +01:00
public void SetWorking ( bool state , bool allowCancel = true )
2020-11-23 16:51:05 +01:00
{
2021-01-05 23:55:16 +01:00
Logger . Log ( $"SetWorking({state})" , true ) ;
2021-01-06 21:44:09 +01:00
SetProgress ( - 1 ) ;
2021-01-15 19:28:42 +01:00
Control [ ] controlsToDisable = new Control [ ] { runBtn , runStepBtn , stepSelector , settingsBtn } ;
2020-12-02 23:11:27 +01:00
Control [ ] controlsToHide = new Control [ ] { runBtn , runStepBtn , stepSelector } ;
progressCircle . Visible = state ;
cancelBtn . Visible = state ;
2020-11-23 16:51:05 +01:00
foreach ( Control c in controlsToDisable )
c . Enabled = ! state ;
2020-12-02 23:11:27 +01:00
foreach ( Control c in controlsToHide )
c . Visible = ! state ;
2021-01-05 23:13:29 +01:00
cancelBtn . Enabled = allowCancel ;
2020-12-02 23:11:27 +01:00
Program . busy = state ;
2020-12-03 01:20:33 +01:00
Program . mainForm . UpdateStepByStepControls ( false ) ;
2020-11-23 16:51:05 +01:00
}
2021-01-14 00:39:49 +01:00
string lastAiComboxStr = "" ;
2020-11-23 16:51:05 +01:00
private void aiCombox_SelectedIndexChanged ( object sender , EventArgs e )
{
2021-01-14 00:39:49 +01:00
if ( string . IsNullOrWhiteSpace ( aiCombox . Text ) | | aiCombox . Text = = lastAiComboxStr ) return ;
lastAiComboxStr = aiCombox . Text ;
2021-01-13 23:27:46 +01:00
aiModel = UIUtils . FillAiModelsCombox ( aiModel , GetAi ( ) ) ;
2020-11-23 16:51:05 +01:00
interpFactorCombox_SelectedIndexChanged ( null , null ) ;
}
private void Form1_FormClosing ( object sender , FormClosingEventArgs e )
{
ConfigParser . SaveComboxIndex ( aiCombox ) ;
}
private async void debugExtractFramesBtn_Click ( object sender , EventArgs e )
{
await UtilsTab . ExtractVideo ( inputTbox . Text . Trim ( ) , utilsExtractAudioCbox . Checked ) ;
}
private void licenseBtn_Click ( object sender , EventArgs e )
{
Process . Start ( "explorer.exe" , Path . Combine ( Paths . GetPkgPath ( ) , Path . GetFileNameWithoutExtension ( Packages . licenses . fileName ) ) ) ;
}
private async void utilsLoopVidBtn_Click ( object sender , EventArgs e )
{
await UtilsTab . LoopVideo ( inputTbox . Text . Trim ( ) , utilsLoopTimesCombox ) ;
}
private async void utilsChangeSpeedBtn_Click ( object sender , EventArgs e )
{
await UtilsTab . ChangeSpeed ( inputTbox . Text . Trim ( ) , utilsSpeedCombox ) ;
}
private void Form1_DragEnter ( object sender , DragEventArgs e ) { e . Effect = DragDropEffects . Copy ; }
private void Form1_DragDrop ( object sender , DragEventArgs e )
2020-12-03 22:21:44 +01:00
{
DragDropHandler ( ( string [ ] ) e . Data . GetData ( DataFormats . FileDrop ) ) ;
}
public void DragDropHandler ( string [ ] files )
2020-11-23 16:51:05 +01:00
{
if ( Program . busy ) return ;
2020-12-03 22:21:44 +01:00
if ( files . Length > 1 )
{
queueBtn_Click ( null , null ) ;
if ( BatchProcessing . currentBatchForm ! = null )
BatchProcessing . currentBatchForm . LoadDroppedPaths ( files ) ;
}
else
{
SetTab ( "interpolation" ) ;
Logger . Log ( "Selected video/directory: " + Path . GetFileName ( files [ 0 ] ) ) ;
inputTbox . Text = files [ 0 ] ;
MainUiFunctions . InitInput ( outputTbox , inputTbox , fpsInTbox ) ;
}
2020-11-23 16:51:05 +01:00
}
private async void utilsConvertMp4Btn_Click ( object sender , EventArgs e )
{
await UtilsTab . Convert ( inputTbox . Text . Trim ( ) , utilsConvCrf ) ;
}
private void utilsDedupBtn_Click ( object sender , EventArgs e )
{
UtilsTab . Dedupe ( inputTbox . Text . Trim ( ) , false ) ;
}
private void utilsDedupTestBtn_Click ( object sender , EventArgs e )
{
UtilsTab . Dedupe ( inputTbox . Text . Trim ( ) , true ) ;
}
private void cancelBtn_Click ( object sender , EventArgs e )
{
2020-11-25 20:31:21 +01:00
SetTab ( "interpolation" ) ;
2020-11-23 16:51:05 +01:00
Interpolate . Cancel ( ) ;
}
private void discordBtn_Click ( object sender , EventArgs e )
{
Process . Start ( "https://discord.gg/eJHD2NSJRe" ) ;
}
private void paypalBtn_Click ( object sender , EventArgs e )
{
Process . Start ( "https://www.paypal.com/paypalme/nmkd/10" ) ;
}
private void patreonBtn_Click ( object sender , EventArgs e )
{
Process . Start ( "https://patreon.com/n00mkrad" ) ;
}
private void settingsBtn_Click ( object sender , EventArgs e )
{
new SettingsForm ( ) . ShowDialog ( ) ;
}
private void queueBtn_Click ( object sender , EventArgs e )
{
if ( BatchProcessing . currentBatchForm ! = null )
{
BatchProcessing . currentBatchForm . WindowState = FormWindowState . Normal ;
BatchProcessing . currentBatchForm . BringToFront ( ) ;
}
else
{
new BatchForm ( ) . Show ( ) ;
}
}
private void previewPicturebox_MouseClick ( object sender , MouseEventArgs e )
{
if ( InterpolateUtils . bigPreviewForm = = null )
{
InterpolateUtils . bigPreviewForm = new BigPreviewForm ( ) ;
InterpolateUtils . bigPreviewForm . Show ( ) ;
InterpolateUtils . bigPreviewForm . SetImage ( previewPicturebox . Image ) ;
}
}
private async void updateBtn_Click ( object sender , EventArgs e )
{
new UpdaterForm ( ) . ShowDialog ( ) ;
}
2020-11-25 17:27:15 +01:00
2020-11-27 14:35:32 +01:00
private void welcomeLabel2_Click ( object sender , EventArgs e )
{
SetTab ( "interpolation" ) ;
}
2020-11-29 16:10:31 +01:00
2020-12-03 22:06:58 +01:00
public void UpdateStepByStepControls ( bool settingsMayHaveChanged )
2020-11-29 16:10:31 +01:00
{
2020-12-03 01:20:33 +01:00
if ( settingsMayHaveChanged )
{
stepSelector . Items . Clear ( ) ;
if ( Config . GetBool ( "scnDetect" ) )
stepSelector . Items . AddRange ( new string [ ] { "1) Extract Scene Changes" , "2) Import/Extract Frames" , "3) Run Interpolation" , "4) Export" , "5) Cleanup & Reset" } ) ;
else
stepSelector . Items . AddRange ( new string [ ] { "1) Import/Extract Frames" , "2) Run Interpolation" , "3) Export" , "4) Cleanup & Reset" } ) ;
stepSelector . SelectedIndex = 0 ;
}
2020-11-29 16:10:31 +01:00
bool stepByStep = Config . GetInt ( "processingMode" ) = = 1 ;
2020-12-03 01:20:33 +01:00
runBtn . Visible = ! stepByStep & & ! Program . busy ;
2020-11-29 16:10:31 +01:00
}
private async void runStepBtn_Click ( object sender , EventArgs e )
{
2020-12-02 01:09:41 +01:00
SetTab ( "interpolate" ) ;
2020-11-29 16:10:31 +01:00
await InterpolateSteps . Run ( stepSelector . Text ) ;
}
private void mainTabControl_SelectedIndexChanged ( object sender , EventArgs e )
{
if ( ! initialized ) return ;
aiCombox_SelectedIndexChanged ( null , null ) ;
}
2020-11-23 16:51:05 +01:00
}
}