mirror of
git://source.winehq.org/git/wine.git
synced 2024-11-01 09:50:52 +00:00
ir50_32: Let video_decoder flip the video instead of doing it manually.
Fixes upside-down videos in multiple games (e.g. Hard Truck 2, Firestarter).
This commit is contained in:
parent
c73e8b8551
commit
79ce998e79
1 changed files with 10 additions and 7 deletions
|
@ -145,6 +145,7 @@ static LRESULT IV50_DecompressBegin( IMFTransform *decoder, LPBITMAPINFO in, LPB
|
||||||
IMFMediaType *input_type, *output_type;
|
IMFMediaType *input_type, *output_type;
|
||||||
const GUID *output_subtype;
|
const GUID *output_subtype;
|
||||||
LRESULT r = ICERR_INTERNAL;
|
LRESULT r = ICERR_INTERNAL;
|
||||||
|
unsigned int stride;
|
||||||
|
|
||||||
TRACE("ICM_DECOMPRESS_BEGIN %p %p %p\n", decoder, in, out);
|
TRACE("ICM_DECOMPRESS_BEGIN %p %p %p\n", decoder, in, out);
|
||||||
|
|
||||||
|
@ -160,6 +161,10 @@ static LRESULT IV50_DecompressBegin( IMFTransform *decoder, LPBITMAPINFO in, LPB
|
||||||
else
|
else
|
||||||
return ICERR_BADFORMAT;
|
return ICERR_BADFORMAT;
|
||||||
|
|
||||||
|
stride = (out->bmiHeader.biWidth + 3) & ~3;
|
||||||
|
if (out->bmiHeader.biHeight >= 0)
|
||||||
|
stride = -stride;
|
||||||
|
|
||||||
if ( FAILED(MFCreateMediaType( &input_type )) )
|
if ( FAILED(MFCreateMediaType( &input_type )) )
|
||||||
return ICERR_INTERNAL;
|
return ICERR_INTERNAL;
|
||||||
|
|
||||||
|
@ -184,6 +189,8 @@ static LRESULT IV50_DecompressBegin( IMFTransform *decoder, LPBITMAPINFO in, LPB
|
||||||
output_type, &MF_MT_FRAME_SIZE,
|
output_type, &MF_MT_FRAME_SIZE,
|
||||||
make_uint64( out->bmiHeader.biWidth, abs(out->bmiHeader.biHeight) ) )) )
|
make_uint64( out->bmiHeader.biWidth, abs(out->bmiHeader.biHeight) ) )) )
|
||||||
goto done;
|
goto done;
|
||||||
|
if ( FAILED(IMFMediaType_SetUINT32( output_type, &MF_MT_DEFAULT_STRIDE, stride)) )
|
||||||
|
goto done;
|
||||||
|
|
||||||
if ( FAILED(IMFTransform_SetInputType( decoder, 0, input_type, 0 )) ||
|
if ( FAILED(IMFTransform_SetInputType( decoder, 0, input_type, 0 )) ||
|
||||||
FAILED(IMFTransform_SetOutputType( decoder, 0, output_type, 0 )) )
|
FAILED(IMFTransform_SetOutputType( decoder, 0, output_type, 0 )) )
|
||||||
|
@ -252,17 +259,13 @@ static LRESULT IV50_Decompress( IMFTransform *decoder, ICDECOMPRESS *icd, DWORD
|
||||||
{
|
{
|
||||||
LONG width = icd->lpbiOutput->biWidth * (icd->lpbiOutput->biBitCount / 8);
|
LONG width = icd->lpbiOutput->biWidth * (icd->lpbiOutput->biBitCount / 8);
|
||||||
LONG height = abs( icd->lpbiOutput->biHeight );
|
LONG height = abs( icd->lpbiOutput->biHeight );
|
||||||
LONG data_stride = (width + 3) & ~3;
|
LONG stride = (width + 3) & ~3;
|
||||||
LONG out_stride = icd->lpbiOutput->biHeight >= 0 ? -data_stride : data_stride;
|
BYTE *output = (BYTE *)icd->lpOutput;
|
||||||
BYTE *output_start = (BYTE *)icd->lpOutput;
|
|
||||||
|
|
||||||
if (out_stride < 0)
|
|
||||||
output_start += (height - 1) * abs(out_stride);
|
|
||||||
|
|
||||||
if ( FAILED(IMFMediaBuffer_Lock( out_buf, &data, NULL, NULL )))
|
if ( FAILED(IMFMediaBuffer_Lock( out_buf, &data, NULL, NULL )))
|
||||||
goto done;
|
goto done;
|
||||||
|
|
||||||
MFCopyImage( output_start, out_stride, data, data_stride, width, height );
|
MFCopyImage( output, stride, data, stride, width, height );
|
||||||
|
|
||||||
IMFMediaBuffer_Unlock( out_buf );
|
IMFMediaBuffer_Unlock( out_buf );
|
||||||
r = ICERR_OK;
|
r = ICERR_OK;
|
||||||
|
|
Loading…
Reference in a new issue