mp3dmod: Implement SetOutputType().

Signed-off-by: Zebediah Figura <z.figura12@gmail.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Zebediah Figura 2018-05-11 10:18:11 -05:00 committed by Alexandre Julliard
parent 4f868310a6
commit 0c14a85d98
3 changed files with 48 additions and 3 deletions

View File

@ -1,5 +1,5 @@
MODULE = mp3dmod.dll MODULE = mp3dmod.dll
IMPORTS = dmoguids uuid wmcodecdspuuid IMPORTS = dmoguids msdmo uuid wmcodecdspuuid
EXTRAINCL = $(MPG123_CFLAGS) EXTRAINCL = $(MPG123_CFLAGS)
EXTRALIBS = $(MPG123_LIBS) EXTRALIBS = $(MPG123_LIBS)

View File

@ -22,8 +22,11 @@
#include <mpg123.h> #include <mpg123.h>
#include "windef.h" #include "windef.h"
#include "winbase.h" #include "winbase.h"
#include "wingdi.h"
#include "mmreg.h"
#define COBJMACROS #define COBJMACROS
#include "objbase.h" #include "objbase.h"
#include "dmo.h"
#include "rpcproxy.h" #include "rpcproxy.h"
#include "wmcodecdsp.h" #include "wmcodecdsp.h"
#include "wine/debug.h" #include "wine/debug.h"
@ -37,6 +40,7 @@ struct mp3_decoder {
IMediaObject IMediaObject_iface; IMediaObject IMediaObject_iface;
LONG ref; LONG ref;
mpg123_handle *mh; mpg123_handle *mh;
DMO_MEDIA_TYPE outtype;
}; };
static inline struct mp3_decoder *impl_from_IMediaObject(IMediaObject *iface) static inline struct mp3_decoder *impl_from_IMediaObject(IMediaObject *iface)
@ -132,9 +136,44 @@ static HRESULT WINAPI MediaObject_SetInputType(IMediaObject *iface, DWORD index,
static HRESULT WINAPI MediaObject_SetOutputType(IMediaObject *iface, DWORD index, const DMO_MEDIA_TYPE *type, DWORD flags) static HRESULT WINAPI MediaObject_SetOutputType(IMediaObject *iface, DWORD index, const DMO_MEDIA_TYPE *type, DWORD flags)
{ {
FIXME("(%p)->(%d, %p, %#x) stub!\n", iface, index, type, flags); struct mp3_decoder *This = impl_from_IMediaObject(iface);
WAVEFORMATEX *format;
long enc;
int err;
return E_NOTIMPL; TRACE("(%p)->(%d, %p, %#x)\n", iface, index, type, flags);
if (flags & DMO_SET_TYPEF_CLEAR)
{
MoFreeMediaType(&This->outtype);
return S_OK;
}
format = (WAVEFORMATEX *)type->pbFormat;
if (format->wBitsPerSample == 8)
enc = MPG123_ENC_UNSIGNED_8;
else if (format->wBitsPerSample == 16)
enc = MPG123_ENC_SIGNED_16;
else
{
ERR("Cannot decode to bit depth %u.\n", format->wBitsPerSample);
return DMO_E_TYPE_NOT_ACCEPTED;
}
if (!(flags & DMO_SET_TYPEF_TEST_ONLY))
{
err = mpg123_format(This->mh, format->nSamplesPerSec, format->nChannels, enc);
if (err != MPG123_OK)
{
ERR("Failed to set format: %u channels, %u samples/sec, %u bits/sample.\n",
format->nChannels, format->nSamplesPerSec, format->wBitsPerSample);
return DMO_E_TYPE_NOT_ACCEPTED;
}
MoCopyMediaType(&This->outtype, type);
}
return S_OK;
} }
static HRESULT WINAPI MediaObject_GetInputCurrentType(IMediaObject *iface, DWORD index, DMO_MEDIA_TYPE *type) static HRESULT WINAPI MediaObject_GetInputCurrentType(IMediaObject *iface, DWORD index, DMO_MEDIA_TYPE *type)
@ -277,6 +316,7 @@ static HRESULT create_mp3_decoder(REFIID iid, void **obj)
mpg123_init(); mpg123_init();
This->mh = mpg123_new(NULL, &err); This->mh = mpg123_new(NULL, &err);
mpg123_format_none(This->mh);
return IMediaObject_QueryInterface(&This->IMediaObject_iface, iid, obj); return IMediaObject_QueryInterface(&This->IMediaObject_iface, iid, obj);
} }

View File

@ -102,6 +102,11 @@ enum _DMO_INPLACE_PROCESS_FLAGS {
DMO_INPLACE_ZERO = 0x00000001 DMO_INPLACE_ZERO = 0x00000001
}; };
enum _DMO_SET_TYPE_FLAGS {
DMO_SET_TYPEF_TEST_ONLY = 0x00000001,
DMO_SET_TYPEF_CLEAR = 0x00000002,
};
/***************************************************************************** /*****************************************************************************
* IMediaObject interface * IMediaObject interface
*/ */