static async Task AiFinished(string aiName) { if (Interpolate.canceled) { return; } Program.mainForm.SetProgress(100); InterpolateUtils.UpdateInterpProgress(IOUtils.GetAmountOfFiles(Interpolate.current.interpFolder, false, "*.png"), InterpolateUtils.targetFrames); string logStr = $"Done running {aiName} - Interpolation took {FormatUtils.Time(processTime.Elapsed)}. Peak Output FPS: {InterpolateUtils.peakFpsOut.ToString("0.00")}"; if (Interpolate.currentlyUsingAutoEnc && AutoEncode.HasWorkToDo()) { logStr += " - Waiting for encoding to finish..."; } Logger.Log(logStr); processTime.Stop(); while (Interpolate.currentlyUsingAutoEnc && Program.busy) { if (AvProcess.lastAvProcess != null && !AvProcess.lastAvProcess.HasExited && AvProcess.lastTask == AvProcess.TaskType.Encode) { string lastLine = AvProcess.lastOutputFfmpeg.SplitIntoLines().Last(); Logger.Log(lastLine.Trim().TrimWhitespaces(), false, Logger.GetLastLine().Contains("frame")); } if (AvProcess.timeSinceLastOutput.IsRunning && AvProcess.timeSinceLastOutput.ElapsedMilliseconds > 2500) { break; } await Task.Delay(500); } if (!Interpolate.canceled && Interpolate.current.alpha) { Logger.Log("Processing alpha..."); string rgbInterpDir = Path.Combine(Interpolate.current.tempFolder, Paths.interpDir); string alphaInterpDir = Path.Combine(Interpolate.current.tempFolder, Paths.interpDir + Paths.alphaSuffix); if (!Directory.Exists(alphaInterpDir)) { return; } await FfmpegAlpha.MergeAlphaIntoRgb(rgbInterpDir, Padding.interpFrames, alphaInterpDir, Padding.interpFrames, false); } }
public static async Task PostProcessFrames(bool stepByStep) { if (canceled) { return; } int extractedFrames = IOUtils.GetAmountOfFiles(current.framesFolder, false, "*.png"); if (!Directory.Exists(current.framesFolder) || currentInputFrameCount <= 0 || extractedFrames < 2) { if (extractedFrames == 1) { Cancel("Only a single frame was extracted from your input file!\n\nPossibly your input is an image, not a video?"); } else { Cancel("Frame extraction failed!\n\nYour input file might be incompatible."); } } if (Config.GetInt("dedupMode") == 1) { await Dedupe.Run(current.framesFolder); } else { Dedupe.ClearCache(); } if (!Config.GetBool("enableLoop")) { await Utils.CopyLastFrame(currentInputFrameCount); } if (Config.GetInt("dedupMode") > 0) { await Dedupe.CreateDupesFile(current.framesFolder, currentInputFrameCount); } if (canceled) { return; } await FrameOrder.CreateFrameOrderFile(current.framesFolder, Config.GetBool("enableLoop"), current.interpFactor); if (canceled) { return; } try { Dictionary <string, string> renamedFilesDict = await IOUtils.RenameCounterDirReversibleAsync(current.framesFolder, "png", 1, Padding.inputFramesRenamed); if (stepByStep) { AiProcess.filenameMap = renamedFilesDict.ToDictionary(x => Path.GetFileName(x.Key), x => Path.GetFileName(x.Value)); // Save rel paths } } catch (Exception e) { Logger.Log($"Error renaming frame files: {e.Message}"); Cancel("Error renaming frame files. Check the log for details."); } if (current.alpha) { Program.mainForm.SetStatus("Extracting transparency..."); Logger.Log("Extracting transparency... (1/2)"); await FfmpegAlpha.ExtractAlphaDir(current.framesFolder, current.framesFolder + Paths.alphaSuffix); Logger.Log("Extracting transparency... (2/2)", false, true); await FfmpegAlpha.RemoveAlpha(current.framesFolder, current.framesFolder); } }