mirror of
https://github.com/revenz/FileFlowsPlugins.git
synced 2025-12-30 16:59:31 -06:00
67 lines
2.0 KiB
C#
67 lines
2.0 KiB
C#
namespace FileFlows.VideoNodes
|
|
{
|
|
using System.ComponentModel;
|
|
using FileFlows.Plugin;
|
|
using FileFlows.Plugin.Attributes;
|
|
|
|
public class VideoFile : VideoNode
|
|
{
|
|
public override int Outputs => 1;
|
|
public override FlowElementType Type => FlowElementType.Input;
|
|
|
|
private Dictionary<string, object> _Variables;
|
|
public override Dictionary<string, object> Variables => _Variables;
|
|
public VideoFile()
|
|
{
|
|
_Variables = new Dictionary<string, object>()
|
|
{
|
|
{ "viVideoCodec", "hevc" },
|
|
{ "viAudioCodec", "ac3" },
|
|
{ "viAudioCodecs", "ac3,aac"},
|
|
{ "viAudioLanguage", "eng" },
|
|
{ "viAudioLanguages", "eng, mao" },
|
|
{ "viResolution", "1080p" },
|
|
};
|
|
}
|
|
|
|
public override int Execute(NodeParameters args)
|
|
{
|
|
string ffmpegExe = GetFFMpegExe(args);
|
|
if (string.IsNullOrEmpty(ffmpegExe))
|
|
return -1;
|
|
|
|
try
|
|
{
|
|
|
|
var videoInfo = new VideoInfoHelper(ffmpegExe, args.Logger).Read(args.WorkingFile);
|
|
if (videoInfo.VideoStreams.Any() == false)
|
|
{
|
|
args.Logger.ILog("No video streams detected.");
|
|
return 0;
|
|
}
|
|
foreach (var vs in videoInfo.VideoStreams)
|
|
{
|
|
args.Logger.ILog($"Video stream '{vs.Codec}' '{vs.Index}'");
|
|
}
|
|
|
|
|
|
|
|
foreach (var vs in videoInfo.AudioStreams)
|
|
{
|
|
args.Logger.ILog($"Audio stream '{vs.Codec}' '{vs.Index}' '{vs.Language}");
|
|
}
|
|
|
|
SetVideoInfo(args, videoInfo, Variables);
|
|
|
|
return 1;
|
|
}
|
|
catch (Exception ex)
|
|
{
|
|
args.Logger.ELog("Failed processing VideoFile: " + ex.Message);
|
|
return -1;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
} |