mirror of
https://github.com/rosenbjerg/FFMpegCore.git
synced 2025-01-18 04:26:44 +00:00
Merge pull request #510 from Hagfjall/hagfjall/fix-509-snapshot-rotation
fix: Snapshots from rotated videos should have correct width/height
This commit is contained in:
commit
0a3be1e78c
6 changed files with 33 additions and 1 deletions
|
@ -51,6 +51,9 @@
|
|||
<None Update="Resources\input_3sec_rotation_90deg.mp4">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</None>
|
||||
<None Update="Resources\input_3sec_rotation_negative_90deg.mp4">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</None>
|
||||
<None Update="Resources\input_audio_only_10sec.mp4">
|
||||
<CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
|
||||
</None>
|
||||
|
|
|
@ -146,6 +146,13 @@ public void Probe_Rotation()
|
|||
Assert.AreEqual(90, info.PrimaryVideoStream.Rotation);
|
||||
}
|
||||
|
||||
[TestMethod]
|
||||
public void Probe_Rotation_Negative_Value()
|
||||
{
|
||||
var info = FFProbe.Analyse(TestResources.Mp4VideoRotationNegative);
|
||||
Assert.AreEqual(-90, info.PrimaryVideoStream.Rotation);
|
||||
}
|
||||
|
||||
[TestMethod, Timeout(10000)]
|
||||
public async Task Probe_Async_Success()
|
||||
{
|
||||
|
|
|
@ -4,6 +4,7 @@ public static class TestResources
|
|||
{
|
||||
public static readonly string Mp4Video = "./Resources/input_3sec.mp4";
|
||||
public static readonly string Mp4VideoRotation = "./Resources/input_3sec_rotation_90deg.mp4";
|
||||
public static readonly string Mp4VideoRotationNegative = "./Resources/input_3sec_rotation_negative_90deg.mp4";
|
||||
public static readonly string WebmVideo = "./Resources/input_3sec.webm";
|
||||
public static readonly string HdrVideo = "./Resources/input_hdr.mov";
|
||||
public static readonly string Mp4WithoutVideo = "./Resources/input_audio_only_10sec.mp4";
|
||||
|
|
BIN
FFMpegCore.Test/Resources/input_3sec_rotation_negative_90deg.mp4
Normal file
BIN
FFMpegCore.Test/Resources/input_3sec_rotation_negative_90deg.mp4
Normal file
Binary file not shown.
|
@ -480,6 +480,21 @@ public void Video_Snapshot_PersistSnapshot()
|
|||
Assert.AreEqual("png", analysis.PrimaryVideoStream!.CodecName);
|
||||
}
|
||||
|
||||
[TestMethod, Timeout(BaseTimeoutMilliseconds)]
|
||||
public void Video_Snapshot_Rotated_PersistSnapshot()
|
||||
{
|
||||
using var outputPath = new TemporaryFile("out.png");
|
||||
|
||||
var size = new Size(360, 0); // half the size of original video, keeping height 0 for keeping aspect ratio
|
||||
FFMpeg.Snapshot(TestResources.Mp4VideoRotationNegative, outputPath, size);
|
||||
|
||||
var analysis = FFProbe.Analyse(outputPath);
|
||||
Assert.AreEqual(size.Width, analysis.PrimaryVideoStream!.Width);
|
||||
Assert.AreEqual(1280 / 2, analysis.PrimaryVideoStream!.Height);
|
||||
Assert.AreEqual(0, analysis.PrimaryVideoStream!.Rotation);
|
||||
Assert.AreEqual("png", analysis.PrimaryVideoStream!.CodecName);
|
||||
}
|
||||
|
||||
[TestMethod, Timeout(BaseTimeoutMilliseconds)]
|
||||
public void Video_GifSnapshot_PersistSnapshot()
|
||||
{
|
||||
|
|
|
@ -64,7 +64,7 @@ public static (FFMpegArguments, Action<FFMpegArgumentOptions> outputOptions) Bui
|
|||
}
|
||||
|
||||
var currentSize = new Size(source.PrimaryVideoStream.Width, source.PrimaryVideoStream.Height);
|
||||
if (source.PrimaryVideoStream.Rotation == 90 || source.PrimaryVideoStream.Rotation == 180)
|
||||
if (IsRotated(source.PrimaryVideoStream.Rotation))
|
||||
{
|
||||
currentSize = new Size(source.PrimaryVideoStream.Height, source.PrimaryVideoStream.Width);
|
||||
}
|
||||
|
@ -88,4 +88,10 @@ public static (FFMpegArguments, Action<FFMpegArgumentOptions> outputOptions) Bui
|
|||
|
||||
return null;
|
||||
}
|
||||
|
||||
private static bool IsRotated(int rotation)
|
||||
{
|
||||
var absRotation = Math.Abs(rotation);
|
||||
return absRotation == 90 || absRotation == 180;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue