windowscodecs: Use an iface instead of a vtbl pointer in BmpFrameEncode.
This commit is contained in:
parent
0eff947c09
commit
5cce70ddeb
|
@ -58,7 +58,7 @@ static const struct bmp_pixelformat formats[] = {
|
||||||
};
|
};
|
||||||
|
|
||||||
typedef struct BmpFrameEncode {
|
typedef struct BmpFrameEncode {
|
||||||
const IWICBitmapFrameEncodeVtbl *lpVtbl;
|
IWICBitmapFrameEncode IWICBitmapFrameEncode_iface;
|
||||||
LONG ref;
|
LONG ref;
|
||||||
IStream *stream;
|
IStream *stream;
|
||||||
BOOL initialized;
|
BOOL initialized;
|
||||||
|
@ -71,10 +71,15 @@ typedef struct BmpFrameEncode {
|
||||||
BOOL committed;
|
BOOL committed;
|
||||||
} BmpFrameEncode;
|
} BmpFrameEncode;
|
||||||
|
|
||||||
|
static inline BmpFrameEncode *impl_from_IWICBitmapFrameEncode(IWICBitmapFrameEncode *iface)
|
||||||
|
{
|
||||||
|
return CONTAINING_RECORD(iface, BmpFrameEncode, IWICBitmapFrameEncode_iface);
|
||||||
|
}
|
||||||
|
|
||||||
static HRESULT WINAPI BmpFrameEncode_QueryInterface(IWICBitmapFrameEncode *iface, REFIID iid,
|
static HRESULT WINAPI BmpFrameEncode_QueryInterface(IWICBitmapFrameEncode *iface, REFIID iid,
|
||||||
void **ppv)
|
void **ppv)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
TRACE("(%p,%s,%p)\n", iface, debugstr_guid(iid), ppv);
|
TRACE("(%p,%s,%p)\n", iface, debugstr_guid(iid), ppv);
|
||||||
|
|
||||||
if (!ppv) return E_INVALIDARG;
|
if (!ppv) return E_INVALIDARG;
|
||||||
|
@ -96,7 +101,7 @@ static HRESULT WINAPI BmpFrameEncode_QueryInterface(IWICBitmapFrameEncode *iface
|
||||||
|
|
||||||
static ULONG WINAPI BmpFrameEncode_AddRef(IWICBitmapFrameEncode *iface)
|
static ULONG WINAPI BmpFrameEncode_AddRef(IWICBitmapFrameEncode *iface)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
ULONG ref = InterlockedIncrement(&This->ref);
|
ULONG ref = InterlockedIncrement(&This->ref);
|
||||||
|
|
||||||
TRACE("(%p) refcount=%u\n", iface, ref);
|
TRACE("(%p) refcount=%u\n", iface, ref);
|
||||||
|
@ -106,7 +111,7 @@ static ULONG WINAPI BmpFrameEncode_AddRef(IWICBitmapFrameEncode *iface)
|
||||||
|
|
||||||
static ULONG WINAPI BmpFrameEncode_Release(IWICBitmapFrameEncode *iface)
|
static ULONG WINAPI BmpFrameEncode_Release(IWICBitmapFrameEncode *iface)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
ULONG ref = InterlockedDecrement(&This->ref);
|
ULONG ref = InterlockedDecrement(&This->ref);
|
||||||
|
|
||||||
TRACE("(%p) refcount=%u\n", iface, ref);
|
TRACE("(%p) refcount=%u\n", iface, ref);
|
||||||
|
@ -124,7 +129,7 @@ static ULONG WINAPI BmpFrameEncode_Release(IWICBitmapFrameEncode *iface)
|
||||||
static HRESULT WINAPI BmpFrameEncode_Initialize(IWICBitmapFrameEncode *iface,
|
static HRESULT WINAPI BmpFrameEncode_Initialize(IWICBitmapFrameEncode *iface,
|
||||||
IPropertyBag2 *pIEncoderOptions)
|
IPropertyBag2 *pIEncoderOptions)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
TRACE("(%p,%p)\n", iface, pIEncoderOptions);
|
TRACE("(%p,%p)\n", iface, pIEncoderOptions);
|
||||||
|
|
||||||
if (This->initialized) return WINCODEC_ERR_WRONGSTATE;
|
if (This->initialized) return WINCODEC_ERR_WRONGSTATE;
|
||||||
|
@ -137,7 +142,7 @@ static HRESULT WINAPI BmpFrameEncode_Initialize(IWICBitmapFrameEncode *iface,
|
||||||
static HRESULT WINAPI BmpFrameEncode_SetSize(IWICBitmapFrameEncode *iface,
|
static HRESULT WINAPI BmpFrameEncode_SetSize(IWICBitmapFrameEncode *iface,
|
||||||
UINT uiWidth, UINT uiHeight)
|
UINT uiWidth, UINT uiHeight)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
TRACE("(%p,%u,%u)\n", iface, uiWidth, uiHeight);
|
TRACE("(%p,%u,%u)\n", iface, uiWidth, uiHeight);
|
||||||
|
|
||||||
if (!This->initialized || This->bits) return WINCODEC_ERR_WRONGSTATE;
|
if (!This->initialized || This->bits) return WINCODEC_ERR_WRONGSTATE;
|
||||||
|
@ -151,7 +156,7 @@ static HRESULT WINAPI BmpFrameEncode_SetSize(IWICBitmapFrameEncode *iface,
|
||||||
static HRESULT WINAPI BmpFrameEncode_SetResolution(IWICBitmapFrameEncode *iface,
|
static HRESULT WINAPI BmpFrameEncode_SetResolution(IWICBitmapFrameEncode *iface,
|
||||||
double dpiX, double dpiY)
|
double dpiX, double dpiY)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
TRACE("(%p,%0.2f,%0.2f)\n", iface, dpiX, dpiY);
|
TRACE("(%p,%0.2f,%0.2f)\n", iface, dpiX, dpiY);
|
||||||
|
|
||||||
if (!This->initialized || This->bits) return WINCODEC_ERR_WRONGSTATE;
|
if (!This->initialized || This->bits) return WINCODEC_ERR_WRONGSTATE;
|
||||||
|
@ -165,7 +170,7 @@ static HRESULT WINAPI BmpFrameEncode_SetResolution(IWICBitmapFrameEncode *iface,
|
||||||
static HRESULT WINAPI BmpFrameEncode_SetPixelFormat(IWICBitmapFrameEncode *iface,
|
static HRESULT WINAPI BmpFrameEncode_SetPixelFormat(IWICBitmapFrameEncode *iface,
|
||||||
WICPixelFormatGUID *pPixelFormat)
|
WICPixelFormatGUID *pPixelFormat)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
int i;
|
int i;
|
||||||
TRACE("(%p,%s)\n", iface, debugstr_guid(pPixelFormat));
|
TRACE("(%p,%s)\n", iface, debugstr_guid(pPixelFormat));
|
||||||
|
|
||||||
|
@ -224,7 +229,7 @@ static HRESULT BmpFrameEncode_AllocateBits(BmpFrameEncode *This)
|
||||||
static HRESULT WINAPI BmpFrameEncode_WritePixels(IWICBitmapFrameEncode *iface,
|
static HRESULT WINAPI BmpFrameEncode_WritePixels(IWICBitmapFrameEncode *iface,
|
||||||
UINT lineCount, UINT cbStride, UINT cbBufferSize, BYTE *pbPixels)
|
UINT lineCount, UINT cbStride, UINT cbBufferSize, BYTE *pbPixels)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
WICRect rc;
|
WICRect rc;
|
||||||
TRACE("(%p,%u,%u,%u,%p)\n", iface, lineCount, cbStride, cbBufferSize, pbPixels);
|
TRACE("(%p,%u,%u,%u,%p)\n", iface, lineCount, cbStride, cbBufferSize, pbPixels);
|
||||||
|
@ -253,7 +258,7 @@ static HRESULT WINAPI BmpFrameEncode_WritePixels(IWICBitmapFrameEncode *iface,
|
||||||
static HRESULT WINAPI BmpFrameEncode_WriteSource(IWICBitmapFrameEncode *iface,
|
static HRESULT WINAPI BmpFrameEncode_WriteSource(IWICBitmapFrameEncode *iface,
|
||||||
IWICBitmapSource *pIBitmapSource, WICRect *prc)
|
IWICBitmapSource *pIBitmapSource, WICRect *prc)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
WICRect rc;
|
WICRect rc;
|
||||||
WICPixelFormatGUID guid;
|
WICPixelFormatGUID guid;
|
||||||
|
@ -316,7 +321,7 @@ static HRESULT WINAPI BmpFrameEncode_WriteSource(IWICBitmapFrameEncode *iface,
|
||||||
|
|
||||||
static HRESULT WINAPI BmpFrameEncode_Commit(IWICBitmapFrameEncode *iface)
|
static HRESULT WINAPI BmpFrameEncode_Commit(IWICBitmapFrameEncode *iface)
|
||||||
{
|
{
|
||||||
BmpFrameEncode *This = (BmpFrameEncode*)iface;
|
BmpFrameEncode *This = impl_from_IWICBitmapFrameEncode(iface);
|
||||||
BITMAPFILEHEADER bfh;
|
BITMAPFILEHEADER bfh;
|
||||||
BITMAPV5HEADER bih;
|
BITMAPV5HEADER bih;
|
||||||
UINT info_size;
|
UINT info_size;
|
||||||
|
@ -456,7 +461,7 @@ static ULONG WINAPI BmpEncoder_Release(IWICBitmapEncoder *iface)
|
||||||
if (ref == 0)
|
if (ref == 0)
|
||||||
{
|
{
|
||||||
if (This->stream) IStream_Release(This->stream);
|
if (This->stream) IStream_Release(This->stream);
|
||||||
if (This->frame) IWICBitmapFrameEncode_Release((IWICBitmapFrameEncode*)This->frame);
|
if (This->frame) IWICBitmapFrameEncode_Release(&This->frame->IWICBitmapFrameEncode_iface);
|
||||||
HeapFree(GetProcessHeap(), 0, This);
|
HeapFree(GetProcessHeap(), 0, This);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -538,7 +543,7 @@ static HRESULT WINAPI BmpEncoder_CreateNewFrame(IWICBitmapEncoder *iface,
|
||||||
*ppIEncoderOptions = NULL;
|
*ppIEncoderOptions = NULL;
|
||||||
return E_OUTOFMEMORY;
|
return E_OUTOFMEMORY;
|
||||||
}
|
}
|
||||||
encode->lpVtbl = &BmpFrameEncode_Vtbl;
|
encode->IWICBitmapFrameEncode_iface.lpVtbl = &BmpFrameEncode_Vtbl;
|
||||||
encode->ref = 2;
|
encode->ref = 2;
|
||||||
IStream_AddRef(This->stream);
|
IStream_AddRef(This->stream);
|
||||||
encode->stream = This->stream;
|
encode->stream = This->stream;
|
||||||
|
@ -552,7 +557,7 @@ static HRESULT WINAPI BmpEncoder_CreateNewFrame(IWICBitmapEncoder *iface,
|
||||||
encode->lineswritten = 0;
|
encode->lineswritten = 0;
|
||||||
encode->committed = FALSE;
|
encode->committed = FALSE;
|
||||||
|
|
||||||
*ppIFrameEncode = (IWICBitmapFrameEncode*)encode;
|
*ppIFrameEncode = &encode->IWICBitmapFrameEncode_iface;
|
||||||
This->frame = encode;
|
This->frame = encode;
|
||||||
|
|
||||||
return S_OK;
|
return S_OK;
|
||||||
|
|
Loading…
Reference in New Issue