windowscodecs: Add IWICWineDecoder stub for DDS decoder.
Initializing cube map and uncompressed DDS is not supported in WIC. But we would like to use them in other part of wine. So we introduce a Wine-specific interface to initialize them. Signed-off-by: Ziqing Hui <zhui@codeweavers.com> Signed-off-by: Esme Povirk <esme@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
43788707ce
commit
d7ef1cd82c
|
@ -125,6 +125,7 @@ typedef struct dds_frame_info {
|
||||||
typedef struct DdsDecoder {
|
typedef struct DdsDecoder {
|
||||||
IWICBitmapDecoder IWICBitmapDecoder_iface;
|
IWICBitmapDecoder IWICBitmapDecoder_iface;
|
||||||
IWICDdsDecoder IWICDdsDecoder_iface;
|
IWICDdsDecoder IWICDdsDecoder_iface;
|
||||||
|
IWICWineDecoder IWICWineDecoder_iface;
|
||||||
LONG ref;
|
LONG ref;
|
||||||
BOOL initialized;
|
BOOL initialized;
|
||||||
IStream *stream;
|
IStream *stream;
|
||||||
|
@ -281,6 +282,11 @@ static inline DdsDecoder *impl_from_IWICDdsDecoder(IWICDdsDecoder *iface)
|
||||||
return CONTAINING_RECORD(iface, DdsDecoder, IWICDdsDecoder_iface);
|
return CONTAINING_RECORD(iface, DdsDecoder, IWICDdsDecoder_iface);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline DdsDecoder *impl_from_IWICWineDecoder(IWICWineDecoder *iface)
|
||||||
|
{
|
||||||
|
return CONTAINING_RECORD(iface, DdsDecoder, IWICWineDecoder_iface);
|
||||||
|
}
|
||||||
|
|
||||||
static inline DdsFrameDecode *impl_from_IWICBitmapFrameDecode(IWICBitmapFrameDecode *iface)
|
static inline DdsFrameDecode *impl_from_IWICBitmapFrameDecode(IWICBitmapFrameDecode *iface)
|
||||||
{
|
{
|
||||||
return CONTAINING_RECORD(iface, DdsFrameDecode, IWICBitmapFrameDecode_iface);
|
return CONTAINING_RECORD(iface, DdsFrameDecode, IWICBitmapFrameDecode_iface);
|
||||||
|
@ -566,6 +572,8 @@ static HRESULT WINAPI DdsDecoder_QueryInterface(IWICBitmapDecoder *iface, REFIID
|
||||||
*ppv = &This->IWICBitmapDecoder_iface;
|
*ppv = &This->IWICBitmapDecoder_iface;
|
||||||
} else if (IsEqualIID(&IID_IWICDdsDecoder, iid)) {
|
} else if (IsEqualIID(&IID_IWICDdsDecoder, iid)) {
|
||||||
*ppv = &This->IWICDdsDecoder_iface;
|
*ppv = &This->IWICDdsDecoder_iface;
|
||||||
|
} else if (IsEqualIID(&IID_IWICWineDecoder, iid)) {
|
||||||
|
*ppv = &This->IWICWineDecoder_iface;
|
||||||
} else {
|
} else {
|
||||||
*ppv = NULL;
|
*ppv = NULL;
|
||||||
return E_NOINTERFACE;
|
return E_NOINTERFACE;
|
||||||
|
@ -959,6 +967,37 @@ static const IWICDdsDecoderVtbl DdsDecoder_Dds_Vtbl = {
|
||||||
DdsDecoder_Dds_GetFrame
|
DdsDecoder_Dds_GetFrame
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static HRESULT WINAPI DdsDecoder_Wine_QueryInterface(IWICWineDecoder *iface, REFIID iid, void **ppv)
|
||||||
|
{
|
||||||
|
DdsDecoder *This = impl_from_IWICWineDecoder(iface);
|
||||||
|
return DdsDecoder_QueryInterface(&This->IWICBitmapDecoder_iface, iid, ppv);
|
||||||
|
}
|
||||||
|
|
||||||
|
static ULONG WINAPI DdsDecoder_Wine_AddRef(IWICWineDecoder *iface)
|
||||||
|
{
|
||||||
|
DdsDecoder *This = impl_from_IWICWineDecoder(iface);
|
||||||
|
return DdsDecoder_AddRef(&This->IWICBitmapDecoder_iface);
|
||||||
|
}
|
||||||
|
|
||||||
|
static ULONG WINAPI DdsDecoder_Wine_Release(IWICWineDecoder *iface)
|
||||||
|
{
|
||||||
|
DdsDecoder *This = impl_from_IWICWineDecoder(iface);
|
||||||
|
return DdsDecoder_Release(&This->IWICBitmapDecoder_iface);
|
||||||
|
}
|
||||||
|
|
||||||
|
static HRESULT WINAPI DdsDecoder_Wine_Initialize(IWICWineDecoder *iface, IStream *stream, WICDecodeOptions options)
|
||||||
|
{
|
||||||
|
FIXME("(This %p, stream %p, options %#x)\n", iface, stream, options);
|
||||||
|
return E_NOTIMPL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static const IWICWineDecoderVtbl DdsDecoder_Wine_Vtbl = {
|
||||||
|
DdsDecoder_Wine_QueryInterface,
|
||||||
|
DdsDecoder_Wine_AddRef,
|
||||||
|
DdsDecoder_Wine_Release,
|
||||||
|
DdsDecoder_Wine_Initialize
|
||||||
|
};
|
||||||
|
|
||||||
HRESULT DdsDecoder_CreateInstance(REFIID iid, void** ppv)
|
HRESULT DdsDecoder_CreateInstance(REFIID iid, void** ppv)
|
||||||
{
|
{
|
||||||
DdsDecoder *This;
|
DdsDecoder *This;
|
||||||
|
@ -973,6 +1012,7 @@ HRESULT DdsDecoder_CreateInstance(REFIID iid, void** ppv)
|
||||||
|
|
||||||
This->IWICBitmapDecoder_iface.lpVtbl = &DdsDecoder_Vtbl;
|
This->IWICBitmapDecoder_iface.lpVtbl = &DdsDecoder_Vtbl;
|
||||||
This->IWICDdsDecoder_iface.lpVtbl = &DdsDecoder_Dds_Vtbl;
|
This->IWICDdsDecoder_iface.lpVtbl = &DdsDecoder_Dds_Vtbl;
|
||||||
|
This->IWICWineDecoder_iface.lpVtbl = &DdsDecoder_Wine_Vtbl;
|
||||||
This->ref = 1;
|
This->ref = 1;
|
||||||
This->initialized = FALSE;
|
This->initialized = FALSE;
|
||||||
This->stream = NULL;
|
This->stream = NULL;
|
||||||
|
|
|
@ -1216,6 +1216,16 @@ interface IWICDdsFrameDecode : IUnknown
|
||||||
[out, size_is(bufferSize)] BYTE *buffer);
|
[out, size_is(bufferSize)] BYTE *buffer);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
[
|
||||||
|
object,
|
||||||
|
uuid(b9bd430d-28a8-41d3-a1f5-f36ee02840bf)
|
||||||
|
]
|
||||||
|
interface IWICWineDecoder : IUnknown
|
||||||
|
{
|
||||||
|
HRESULT Initialize(
|
||||||
|
[in] IStream *stream,
|
||||||
|
[in] WICDecodeOptions options);
|
||||||
|
};
|
||||||
|
|
||||||
cpp_quote("HRESULT WINAPI WICConvertBitmapSource(REFWICPixelFormatGUID dstFormat, IWICBitmapSource *pISrc, IWICBitmapSource **ppIDst);")
|
cpp_quote("HRESULT WINAPI WICConvertBitmapSource(REFWICPixelFormatGUID dstFormat, IWICBitmapSource *pISrc, IWICBitmapSource **ppIDst);")
|
||||||
cpp_quote("HRESULT WINAPI WICCreateBitmapFromSection(UINT width, UINT height, REFWICPixelFormatGUID format, HANDLE section, UINT stride, UINT offset, IWICBitmap **bitmap);")
|
cpp_quote("HRESULT WINAPI WICCreateBitmapFromSection(UINT width, UINT height, REFWICPixelFormatGUID format, HANDLE section, UINT stride, UINT offset, IWICBitmap **bitmap);")
|
||||||
|
|
Loading…
Reference in New Issue