From 2ddb3b7d9326d639d608e513dcef67855f23390b Mon Sep 17 00:00:00 2001 From: Vincent Povirk Date: Mon, 3 Dec 2012 16:00:36 -0600 Subject: [PATCH] gdiplus: Add a test for drawing to HDC's backed by 32-bit alpha dibs. --- dlls/gdiplus/tests/graphics.c | 50 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) diff --git a/dlls/gdiplus/tests/graphics.c b/dlls/gdiplus/tests/graphics.c index 5fc1626f4bc..553e77fe87e 100644 --- a/dlls/gdiplus/tests/graphics.c +++ b/dlls/gdiplus/tests/graphics.c @@ -4083,6 +4083,55 @@ static void test_measured_extra_space(void) GdipDeleteStringFormat(format); } +static void test_alpha_hdc(void) +{ + GpStatus status; + HDC hdc; + HBITMAP hbm, old_hbm; + GpGraphics *graphics; + ULONG *bits; + BITMAPINFO bmi; + + hdc = CreateCompatibleDC(0); + ok(hdc != NULL, "CreateCompatibleDC failed\n"); + bmi.bmiHeader.biSize = sizeof(bmi.bmiHeader); + bmi.bmiHeader.biHeight = 5; + bmi.bmiHeader.biWidth = 5; + bmi.bmiHeader.biBitCount = 32; + bmi.bmiHeader.biPlanes = 1; + bmi.bmiHeader.biCompression = BI_RGB; + bmi.bmiHeader.biClrUsed = 0; + + hbm = CreateDIBSection(hdc, &bmi, DIB_RGB_COLORS, (void**)&bits, NULL, 0); + ok(hbm != NULL, "CreateDIBSection failed\n"); + + old_hbm = SelectObject(hdc, hbm); + + status = GdipCreateFromHDC(hdc, &graphics); + expect(Ok, status); + + bits[0] = 0xdeadbeef; + + status = GdipGraphicsClear(graphics, 0xffaaaaaa); + expect(Ok, status); + + todo_wine expect(0xffaaaaaa, bits[0]); + + SelectObject(hdc, old_hbm); + + bits[0] = 0xdeadbeef; + + status = GdipGraphicsClear(graphics, 0xffbbbbbb); + expect(Ok, status); + + todo_wine expect(0xffbbbbbb, bits[0]); + + GdipDeleteGraphics(graphics); + + DeleteObject(hbm); + DeleteDC(hdc); +} + START_TEST(graphics) { struct GdiplusStartupInput gdiplusStartupInput; @@ -4149,6 +4198,7 @@ START_TEST(graphics) test_get_set_interpolation(); test_get_set_textrenderinghint(); test_getdc_scaled(); + test_alpha_hdc(); GdiplusShutdown(gdiplusToken); DestroyWindow( hwnd ); -- 2.11.4.GIT