mirror of
https://github.com/rosenbjerg/FFMpegCore.git
synced 2025-12-14 10:05:44 +00:00
Merge 2b66841fd9 into a599c48511
This commit is contained in:
commit
a232f043ad
5 changed files with 17 additions and 1 deletions
|
|
@ -285,4 +285,13 @@ public class FFProbeTests
|
|||
var info = FFProbe.Analyse(TestResources.Mp4Video, customArguments: "-headers \"Hello: World\"");
|
||||
Assert.AreEqual(3, info.Duration.Seconds);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Probe_Success_Output_Data()
|
||||
{
|
||||
var info = FFProbe.Analyse(TestResources.Mp4Video);
|
||||
|
||||
Assert.AreNotEqual(0, info.OutputData.Count);
|
||||
CollectionAssert.Contains(info.OutputData.ToList(), " \"codec_long_name\": \"H.264 / AVC / MPEG-4 AVC / MPEG-4 part 10\",");
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -174,7 +174,9 @@ public static class FFProbe
|
|||
throw new FormatNullException();
|
||||
}
|
||||
|
||||
ffprobeAnalysis.OutputData = instance.OutputData;
|
||||
ffprobeAnalysis.ErrorData = instance.ErrorData;
|
||||
|
||||
return new MediaAnalysis(ffprobeAnalysis);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -11,6 +11,8 @@ public class FFProbeAnalysis
|
|||
|
||||
[JsonPropertyName("chapters")] public List<Chapter> Chapters { get; set; } = null!;
|
||||
|
||||
[JsonIgnore] public IReadOnlyList<string> OutputData { get; set; } = new List<string>();
|
||||
|
||||
[JsonIgnore] public IReadOnlyList<string> ErrorData { get; set; } = new List<string>();
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -13,5 +13,6 @@ public interface IMediaAnalysis
|
|||
List<VideoStream> VideoStreams { get; }
|
||||
List<AudioStream> AudioStreams { get; }
|
||||
List<SubtitleStream> SubtitleStreams { get; }
|
||||
IReadOnlyList<string> OutputData { get; }
|
||||
IReadOnlyList<string> ErrorData { get; }
|
||||
}
|
||||
|
|
|
|||
|
|
@ -9,10 +9,11 @@ internal class MediaAnalysis : IMediaAnalysis
|
|||
internal MediaAnalysis(FFProbeAnalysis analysis)
|
||||
{
|
||||
Format = ParseFormat(analysis.Format);
|
||||
Chapters = analysis.Chapters.Select(c => ParseChapter(c)).ToList();
|
||||
Chapters = analysis.Chapters.Select(ParseChapter).ToList();
|
||||
VideoStreams = analysis.Streams.Where(stream => stream.CodecType == "video").Select(ParseVideoStream).ToList();
|
||||
AudioStreams = analysis.Streams.Where(stream => stream.CodecType == "audio").Select(ParseAudioStream).ToList();
|
||||
SubtitleStreams = analysis.Streams.Where(stream => stream.CodecType == "subtitle").Select(ParseSubtitleStream).ToList();
|
||||
OutputData = analysis.OutputData;
|
||||
ErrorData = analysis.ErrorData;
|
||||
}
|
||||
|
||||
|
|
@ -29,6 +30,7 @@ internal class MediaAnalysis : IMediaAnalysis
|
|||
public List<VideoStream> VideoStreams { get; }
|
||||
public List<AudioStream> AudioStreams { get; }
|
||||
public List<SubtitleStream> SubtitleStreams { get; }
|
||||
public IReadOnlyList<string> OutputData { get; }
|
||||
public IReadOnlyList<string> ErrorData { get; }
|
||||
|
||||
private MediaFormat ParseFormat(Format analysisFormat)
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue