Commit 8e8b70b9 authored by Ziqing Hui's avatar Ziqing Hui Committed by Alexandre Julliard

windowscodecs: Implement IWICDdsEncoder_GetParameters.

parent 795d5aeb
...@@ -168,6 +168,7 @@ typedef struct DdsEncoder { ...@@ -168,6 +168,7 @@ typedef struct DdsEncoder {
UINT frame_count; UINT frame_count;
BOOL uncommitted_frame; BOOL uncommitted_frame;
BOOL committed; BOOL committed;
dds_info info;
} DdsEncoder; } DdsEncoder;
typedef struct DdsFrameEncode { typedef struct DdsFrameEncode {
...@@ -1740,8 +1741,39 @@ static HRESULT WINAPI DdsEncoder_Dds_SetParameters(IWICDdsEncoder *iface, ...@@ -1740,8 +1741,39 @@ static HRESULT WINAPI DdsEncoder_Dds_SetParameters(IWICDdsEncoder *iface,
static HRESULT WINAPI DdsEncoder_Dds_GetParameters(IWICDdsEncoder *iface, static HRESULT WINAPI DdsEncoder_Dds_GetParameters(IWICDdsEncoder *iface,
WICDdsParameters *parameters) WICDdsParameters *parameters)
{ {
FIXME("(%p,%p): stub.\n", iface, parameters); DdsEncoder *This = impl_from_IWICDdsEncoder(iface);
return E_NOTIMPL; HRESULT hr;
TRACE("(%p,%p)\n", iface, parameters);
if (!parameters) return E_INVALIDARG;
EnterCriticalSection(&This->lock);
if (!This->stream)
{
hr = WINCODEC_ERR_WRONGSTATE;
goto end;
}
parameters->Width = This->info.width;
parameters->Height = This->info.height;
parameters->Depth = This->info.depth;
parameters->MipLevels = This->info.mip_levels;
parameters->ArraySize = This->info.array_size;
parameters->DxgiFormat = This->info.format;
parameters->Dimension = This->info.dimension;
parameters->AlphaMode = This->info.alpha_mode;
TRACE("(%p,%p) -> (%dx%d depth=%u mipLevels=%u arraySize=%u dxgiFormat=%#x dimension=%#x alphaMode=%#x)\n",
iface, parameters, parameters->Width, parameters->Height, parameters->Depth, parameters->MipLevels,
parameters->ArraySize, parameters->DxgiFormat, parameters->Dimension, parameters->AlphaMode);
hr = S_OK;
end:
LeaveCriticalSection(&This->lock);
return hr;
} }
static HRESULT WINAPI DdsEncoder_Dds_CreateNewFrame(IWICDdsEncoder *iface, static HRESULT WINAPI DdsEncoder_Dds_CreateNewFrame(IWICDdsEncoder *iface,
...@@ -1835,6 +1867,20 @@ static HRESULT WINAPI DdsEncoder_Initialize(IWICBitmapEncoder *iface, ...@@ -1835,6 +1867,20 @@ static HRESULT WINAPI DdsEncoder_Initialize(IWICBitmapEncoder *iface,
This->stream = stream; This->stream = stream;
IStream_AddRef(stream); IStream_AddRef(stream);
This->info.width = 1;
This->info.height = 1;
This->info.depth = 1;
This->info.mip_levels = 1;
This->info.array_size = 1;
This->info.frame_count = 1;
This->info.data_offset = 0;
This->info.bytes_per_block = get_bytes_per_block_from_format(DXGI_FORMAT_BC3_UNORM);
This->info.format = DXGI_FORMAT_BC3_UNORM;
This->info.dimension = WICDdsTexture2D;
This->info.alpha_mode = WICDdsAlphaModeUnknown;
This->info.pixel_format = &GUID_WICPixelFormatUndefined;
This->info.pixel_format_bpp = 0;
hr = S_OK; hr = S_OK;
end: end:
......
...@@ -1317,11 +1317,9 @@ static void test_dds_encoder_params(IWICBitmapEncoder *encoder, IWICDdsEncoder * ...@@ -1317,11 +1317,9 @@ static void test_dds_encoder_params(IWICBitmapEncoder *encoder, IWICDdsEncoder *
HRESULT hr; HRESULT hr;
hr = IWICDdsEncoder_GetParameters(dds_encoder, NULL); hr = IWICDdsEncoder_GetParameters(dds_encoder, NULL);
todo_wine
ok(hr == E_INVALIDARG, "GetParameters got unexpected hr %#x\n", hr); ok(hr == E_INVALIDARG, "GetParameters got unexpected hr %#x\n", hr);
hr = IWICDdsEncoder_GetParameters(dds_encoder, &params); hr = IWICDdsEncoder_GetParameters(dds_encoder, &params);
todo_wine
ok(hr == S_OK, "GetParameters failed, hr %#x\n", hr); ok(hr == S_OK, "GetParameters failed, hr %#x\n", hr);
if (hr != S_OK) return; if (hr != S_OK) return;
......
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