Commit 6107b36e authored by Andrew Eikum's avatar Andrew Eikum Committed by Alexandre Julliard

winegstreamer: Flip video output.

Gstreamer handles video top-down, but Windows's dshow handles it bottom-up. So let's insert a videoflip filter to fix the discrepancy instead of relying on videorenderer to flip it like we did before. Signed-off-by: 's avatarAndrew Eikum <aeikum@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent 008e4d3e
...@@ -704,8 +704,6 @@ static HRESULT WINAPI Gstreamer_YUV2RGB_SetMediaType(TransformFilter *tf, PIN_DI ...@@ -704,8 +704,6 @@ static HRESULT WINAPI Gstreamer_YUV2RGB_SetMediaType(TransformFilter *tf, PIN_DI
avgtime = vih->AvgTimePerFrame; avgtime = vih->AvgTimePerFrame;
width = vih->bmiHeader.biWidth; width = vih->bmiHeader.biWidth;
height = vih->bmiHeader.biHeight; height = vih->bmiHeader.biHeight;
if (vih->bmiHeader.biHeight > 0)
vih->bmiHeader.biHeight = -vih->bmiHeader.biHeight;
vih->bmiHeader.biBitCount = 24; vih->bmiHeader.biBitCount = 24;
vih->bmiHeader.biCompression = BI_RGB; vih->bmiHeader.biCompression = BI_RGB;
vih->bmiHeader.biSizeImage = width * abs(height) * 3; vih->bmiHeader.biSizeImage = width * abs(height) * 3;
...@@ -714,8 +712,6 @@ static HRESULT WINAPI Gstreamer_YUV2RGB_SetMediaType(TransformFilter *tf, PIN_DI ...@@ -714,8 +712,6 @@ static HRESULT WINAPI Gstreamer_YUV2RGB_SetMediaType(TransformFilter *tf, PIN_DI
avgtime = vih->AvgTimePerFrame; avgtime = vih->AvgTimePerFrame;
width = vih->bmiHeader.biWidth; width = vih->bmiHeader.biWidth;
height = vih->bmiHeader.biHeight; height = vih->bmiHeader.biHeight;
if (vih->bmiHeader.biHeight > 0)
vih->bmiHeader.biHeight = -vih->bmiHeader.biHeight;
vih->bmiHeader.biBitCount = 24; vih->bmiHeader.biBitCount = 24;
vih->bmiHeader.biCompression = BI_RGB; vih->bmiHeader.biCompression = BI_RGB;
vih->bmiHeader.biSizeImage = width * abs(height) * 3; vih->bmiHeader.biSizeImage = width * abs(height) * 3;
...@@ -810,8 +806,6 @@ static HRESULT WINAPI Gstreamer_YUV2ARGB_SetMediaType(TransformFilter *tf, PIN_D ...@@ -810,8 +806,6 @@ static HRESULT WINAPI Gstreamer_YUV2ARGB_SetMediaType(TransformFilter *tf, PIN_D
avgtime = vih->AvgTimePerFrame; avgtime = vih->AvgTimePerFrame;
width = vih->bmiHeader.biWidth; width = vih->bmiHeader.biWidth;
height = vih->bmiHeader.biHeight; height = vih->bmiHeader.biHeight;
if (vih->bmiHeader.biHeight > 0)
vih->bmiHeader.biHeight = -vih->bmiHeader.biHeight;
vih->bmiHeader.biBitCount = 32; vih->bmiHeader.biBitCount = 32;
vih->bmiHeader.biCompression = BI_RGB; vih->bmiHeader.biCompression = BI_RGB;
vih->bmiHeader.biSizeImage = width * abs(height) * 3; vih->bmiHeader.biSizeImage = width * abs(height) * 3;
...@@ -820,8 +814,6 @@ static HRESULT WINAPI Gstreamer_YUV2ARGB_SetMediaType(TransformFilter *tf, PIN_D ...@@ -820,8 +814,6 @@ static HRESULT WINAPI Gstreamer_YUV2ARGB_SetMediaType(TransformFilter *tf, PIN_D
avgtime = vih->AvgTimePerFrame; avgtime = vih->AvgTimePerFrame;
width = vih->bmiHeader.biWidth; width = vih->bmiHeader.biWidth;
height = vih->bmiHeader.biHeight; height = vih->bmiHeader.biHeight;
if (vih->bmiHeader.biHeight > 0)
vih->bmiHeader.biHeight = -vih->bmiHeader.biHeight;
vih->bmiHeader.biBitCount = 32; vih->bmiHeader.biBitCount = 32;
vih->bmiHeader.biCompression = BI_RGB; vih->bmiHeader.biCompression = BI_RGB;
vih->bmiHeader.biSizeImage = width * abs(height) * 3; vih->bmiHeader.biSizeImage = width * abs(height) * 3;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment