d2d1: Add a ID2D1Image interface for effects.
Signed-off-by: Ziqing Hui <zhui@codeweavers.com> Signed-off-by: Henri Verbeet <hverbeet@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
f41d2d7b44
commit
0408225fd6
|
@ -568,10 +568,13 @@ void d2d_device_init(struct d2d_device *device, ID2D1Factory1 *factory, IDXGIDev
|
|||
struct d2d_effect
|
||||
{
|
||||
ID2D1Effect ID2D1Effect_iface;
|
||||
ID2D1Image ID2D1Image_iface;
|
||||
LONG refcount;
|
||||
|
||||
ID2D1Factory *factory;
|
||||
};
|
||||
|
||||
void d2d_effect_init(struct d2d_effect *effect) DECLSPEC_HIDDEN;
|
||||
void d2d_effect_init(struct d2d_effect *effect, ID2D1Factory *factory) DECLSPEC_HIDDEN;
|
||||
|
||||
static inline BOOL d2d_array_reserve(void **elements, size_t *capacity, size_t count, size_t size)
|
||||
{
|
||||
|
|
|
@ -1885,6 +1885,7 @@ static HRESULT STDMETHODCALLTYPE d2d_device_context_CreateBitmapFromDxgiSurface(
|
|||
static HRESULT STDMETHODCALLTYPE d2d_device_context_CreateEffect(ID2D1DeviceContext *iface,
|
||||
REFCLSID effect_id, ID2D1Effect **effect)
|
||||
{
|
||||
struct d2d_device_context *context = impl_from_ID2D1DeviceContext(iface);
|
||||
struct d2d_effect *object;
|
||||
|
||||
FIXME("iface %p, effect_id %s, effect %p stub!\n", iface, debugstr_guid(effect_id), effect);
|
||||
|
@ -1892,7 +1893,7 @@ static HRESULT STDMETHODCALLTYPE d2d_device_context_CreateEffect(ID2D1DeviceCont
|
|||
if (!(object = heap_alloc_zero(sizeof(*object))))
|
||||
return E_OUTOFMEMORY;
|
||||
|
||||
d2d_effect_init(object);
|
||||
d2d_effect_init(object, context->factory);
|
||||
|
||||
TRACE("Created effect %p.\n", object);
|
||||
*effect = &object->ID2D1Effect_iface;
|
||||
|
|
|
@ -27,6 +27,7 @@ static inline struct d2d_effect *impl_from_ID2D1Effect(ID2D1Effect *iface)
|
|||
|
||||
static HRESULT STDMETHODCALLTYPE d2d_effect_QueryInterface(ID2D1Effect *iface, REFIID iid, void **out)
|
||||
{
|
||||
struct d2d_effect *effect = impl_from_ID2D1Effect(iface);
|
||||
TRACE("iface %p, iid %s, out %p.\n", iface, debugstr_guid(iid), out);
|
||||
|
||||
if (IsEqualGUID(iid, &IID_ID2D1Effect)
|
||||
|
@ -38,6 +39,14 @@ static HRESULT STDMETHODCALLTYPE d2d_effect_QueryInterface(ID2D1Effect *iface, R
|
|||
return S_OK;
|
||||
}
|
||||
|
||||
if (IsEqualGUID(iid, &IID_ID2D1Image)
|
||||
|| IsEqualGUID(iid, &IID_ID2D1Resource))
|
||||
{
|
||||
ID2D1Image_AddRef(&effect->ID2D1Image_iface);
|
||||
*out = &effect->ID2D1Image_iface;
|
||||
return S_OK;
|
||||
}
|
||||
|
||||
WARN("%s not implemented, returning E_NOINTERFACE.\n", debugstr_guid(iid));
|
||||
|
||||
*out = NULL;
|
||||
|
@ -62,7 +71,10 @@ static ULONG STDMETHODCALLTYPE d2d_effect_Release(ID2D1Effect *iface)
|
|||
TRACE("%p decreasing refcount to %u.\n", iface, refcount);
|
||||
|
||||
if (!refcount)
|
||||
{
|
||||
ID2D1Factory_Release(effect->factory);
|
||||
heap_free(effect);
|
||||
}
|
||||
|
||||
return refcount;
|
||||
}
|
||||
|
@ -204,8 +216,59 @@ static const ID2D1EffectVtbl d2d_effect_vtbl =
|
|||
d2d_effect_GetOutput,
|
||||
};
|
||||
|
||||
void d2d_effect_init(struct d2d_effect *effect)
|
||||
static inline struct d2d_effect *impl_from_ID2D1Image(ID2D1Image *iface)
|
||||
{
|
||||
return CONTAINING_RECORD(iface, struct d2d_effect, ID2D1Image_iface);
|
||||
}
|
||||
|
||||
static HRESULT STDMETHODCALLTYPE d2d_effect_image_QueryInterface(ID2D1Image *iface, REFIID iid, void **out)
|
||||
{
|
||||
struct d2d_effect *effect = impl_from_ID2D1Image(iface);
|
||||
|
||||
TRACE("iface %p, iid %s, out %p.\n", iface, debugstr_guid(iid), out);
|
||||
|
||||
return d2d_effect_QueryInterface(&effect->ID2D1Effect_iface, iid, out);
|
||||
}
|
||||
|
||||
static ULONG STDMETHODCALLTYPE d2d_effect_image_AddRef(ID2D1Image *iface)
|
||||
{
|
||||
struct d2d_effect *effect = impl_from_ID2D1Image(iface);
|
||||
|
||||
TRACE("iface %p.\n", iface);
|
||||
|
||||
return d2d_effect_AddRef(&effect->ID2D1Effect_iface);
|
||||
}
|
||||
|
||||
static ULONG STDMETHODCALLTYPE d2d_effect_image_Release(ID2D1Image *iface)
|
||||
{
|
||||
struct d2d_effect *effect = impl_from_ID2D1Image(iface);
|
||||
|
||||
TRACE("iface %p.\n", iface);
|
||||
|
||||
return d2d_effect_Release(&effect->ID2D1Effect_iface);
|
||||
}
|
||||
|
||||
static void STDMETHODCALLTYPE d2d_effect_image_GetFactory(ID2D1Image *iface, ID2D1Factory **factory)
|
||||
{
|
||||
struct d2d_effect *effect = impl_from_ID2D1Image(iface);
|
||||
|
||||
TRACE("iface %p, factory %p.\n", iface, factory);
|
||||
|
||||
ID2D1Factory_AddRef(*factory = effect->factory);
|
||||
}
|
||||
|
||||
static const ID2D1ImageVtbl d2d_effect_image_vtbl =
|
||||
{
|
||||
d2d_effect_image_QueryInterface,
|
||||
d2d_effect_image_AddRef,
|
||||
d2d_effect_image_Release,
|
||||
d2d_effect_image_GetFactory,
|
||||
};
|
||||
|
||||
void d2d_effect_init(struct d2d_effect *effect, ID2D1Factory *factory)
|
||||
{
|
||||
effect->ID2D1Effect_iface.lpVtbl = &d2d_effect_vtbl;
|
||||
effect->ID2D1Image_iface.lpVtbl = &d2d_effect_image_vtbl;
|
||||
effect->refcount = 1;
|
||||
ID2D1Factory_AddRef(effect->factory = factory);
|
||||
}
|
||||
|
|
|
@ -9703,16 +9703,13 @@ static void test_effect(BOOL d3d11)
|
|||
ok(hr == S_OK, "Got unexpected hr %#x.\n", hr);
|
||||
|
||||
hr = ID2D1Effect_QueryInterface(effect, &IID_ID2D1Image, (void **)&image_a);
|
||||
todo_wine ok(hr == S_OK, "Got unexpected hr %#x.\n", hr);
|
||||
if (hr != S_OK)
|
||||
goto done;
|
||||
ok(hr == S_OK, "Got unexpected hr %#x.\n", hr);
|
||||
ID2D1Effect_GetOutput(effect, &image_b);
|
||||
todo_wine ok(image_b == image_a, "Got unexpected image_b %p, expected %p.\n", image_b, image_a);
|
||||
if (image_b)
|
||||
ID2D1Image_Release(image_b);
|
||||
ID2D1Image_Release(image_a);
|
||||
|
||||
done:
|
||||
ID2D1Effect_Release(effect);
|
||||
ID2D1DeviceContext_Release(context);
|
||||
ID2D1Factory1_Release(factory);
|
||||
|
|
Loading…
Reference in New Issue