2 * Unit test suite for graphics objects
4 * Copyright (C) 2007 Google (Evan Stade)
5 * Copyright (C) 2012 Dmitry Timoshkov
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General Public
18 * License along with this library; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
24 #define WIN32_NO_STATUS
26 #define COM_NO_WINDOWS_H
28 //#include "windows.h"
29 #include <wine/test.h>
34 #define expect(expected, got) ok((got) == (expected), "Expected %d, got %d\n", (INT)(expected), (INT)(got))
35 #define expectf_(expected, got, precision) ok(fabs((expected) - (got)) <= (precision), "Expected %f, got %f\n", (expected), (got))
36 #define expectf(expected, got) expectf_((expected), (got), 0.001)
38 static const REAL mm_per_inch
= 25.4;
39 static const REAL point_per_inch
= 72.0;
42 static void set_rect_empty(RectF
*rc
)
50 /* converts a given unit to its value in pixels */
51 static REAL
units_to_pixels(REAL units
, GpUnit unit
, REAL dpi
)
59 return units
* dpi
/ point_per_inch
;
63 return units
* dpi
/ 300.0; /* Per MSDN */
65 return units
* dpi
/ mm_per_inch
;
67 ok(0, "Unsupported unit: %d\n", unit
);
72 /* converts value in pixels to a given unit */
73 static REAL
pixels_to_units(REAL pixels
, GpUnit unit
, REAL dpi
)
81 return pixels
* point_per_inch
/ dpi
;
85 return pixels
* 300.0 / dpi
;
87 return pixels
* mm_per_inch
/ dpi
;
89 ok(0, "Unsupported unit: %d\n", unit
);
94 static REAL
units_scale(GpUnit from
, GpUnit to
, REAL dpi
)
96 REAL pixels
= units_to_pixels(1.0, from
, dpi
);
97 return pixels_to_units(pixels
, to
, dpi
);
100 static GpGraphics
*create_graphics(REAL res_x
, REAL res_y
, GpUnit unit
, REAL scale
, GpImage
**image
)
108 GpGraphics
*graphics
= NULL
;
111 status
= GdipCreateBitmapFromScan0(1, 1, 4, PixelFormat24bppRGB
, NULL
, &u
.bitmap
);
114 status
= GdipBitmapSetResolution(u
.bitmap
, res_x
, res_y
);
116 status
= GdipGetImageHorizontalResolution(u
.image
, &res
);
119 status
= GdipGetImageVerticalResolution(u
.image
, &res
);
123 status
= GdipGetImageGraphicsContext(u
.image
, &graphics
);
128 status
= GdipGetDpiX(graphics
, &res
);
131 status
= GdipGetDpiY(graphics
, &res
);
135 status
= GdipSetPageUnit(graphics
, unit
);
137 status
= GdipSetPageScale(graphics
, scale
);
143 static void test_constructor_destructor(void)
146 GpGraphics
*graphics
= NULL
;
147 HDC hdc
= GetDC( hwnd
);
149 stat
= GdipCreateFromHDC(NULL
, &graphics
);
150 expect(OutOfMemory
, stat
);
151 stat
= GdipDeleteGraphics(graphics
);
152 expect(InvalidParameter
, stat
);
154 stat
= GdipCreateFromHDC(hdc
, &graphics
);
156 stat
= GdipDeleteGraphics(graphics
);
159 stat
= GdipCreateFromHWND(NULL
, &graphics
);
161 stat
= GdipDeleteGraphics(graphics
);
164 stat
= GdipCreateFromHWNDICM(NULL
, &graphics
);
166 stat
= GdipDeleteGraphics(graphics
);
169 stat
= GdipDeleteGraphics(NULL
);
170 expect(InvalidParameter
, stat
);
171 ReleaseDC(hwnd
, hdc
);
179 /* Linked list prepend function. */
180 static void log_state(GraphicsState data
, node
** log
)
182 node
* new_entry
= HeapAlloc(GetProcessHeap(), 0, sizeof(node
));
184 new_entry
->data
= data
;
185 new_entry
->next
= *log
;
189 /* Checks if there are duplicates in the list, and frees it. */
190 static void check_no_duplicates(node
* log
)
202 while((temp
= temp
->next
)){
203 if(log
->data
== temp
->data
){
210 }while((log
= log
->next
));
215 HeapFree(GetProcessHeap(), 0, temp
);
223 static void test_save_restore(void)
226 GraphicsState state_a
, state_b
, state_c
;
227 InterpolationMode mode
;
228 GpGraphics
*graphics1
, *graphics2
;
229 node
* state_log
= NULL
;
230 HDC hdc
= GetDC( hwnd
);
231 state_a
= state_b
= state_c
= 0xdeadbeef;
233 /* Invalid saving. */
234 GdipCreateFromHDC(hdc
, &graphics1
);
235 stat
= GdipSaveGraphics(graphics1
, NULL
);
236 expect(InvalidParameter
, stat
);
237 stat
= GdipSaveGraphics(NULL
, &state_a
);
238 expect(InvalidParameter
, stat
);
239 GdipDeleteGraphics(graphics1
);
241 log_state(state_a
, &state_log
);
243 /* Basic save/restore. */
244 GdipCreateFromHDC(hdc
, &graphics1
);
245 GdipSetInterpolationMode(graphics1
, InterpolationModeBilinear
);
246 stat
= GdipSaveGraphics(graphics1
, &state_a
);
248 GdipSetInterpolationMode(graphics1
, InterpolationModeBicubic
);
249 stat
= GdipRestoreGraphics(graphics1
, state_a
);
251 GdipGetInterpolationMode(graphics1
, &mode
);
252 expect(InterpolationModeBilinear
, mode
);
253 GdipDeleteGraphics(graphics1
);
255 log_state(state_a
, &state_log
);
257 /* Restoring garbage doesn't affect saves. */
258 GdipCreateFromHDC(hdc
, &graphics1
);
259 GdipSetInterpolationMode(graphics1
, InterpolationModeBilinear
);
260 GdipSaveGraphics(graphics1
, &state_a
);
261 GdipSetInterpolationMode(graphics1
, InterpolationModeBicubic
);
262 GdipSaveGraphics(graphics1
, &state_b
);
263 GdipSetInterpolationMode(graphics1
, InterpolationModeNearestNeighbor
);
264 stat
= GdipRestoreGraphics(graphics1
, 0xdeadbeef);
266 GdipRestoreGraphics(graphics1
, state_b
);
267 GdipGetInterpolationMode(graphics1
, &mode
);
268 expect(InterpolationModeBicubic
, mode
);
269 GdipRestoreGraphics(graphics1
, state_a
);
270 GdipGetInterpolationMode(graphics1
, &mode
);
271 expect(InterpolationModeBilinear
, mode
);
272 GdipDeleteGraphics(graphics1
);
274 log_state(state_a
, &state_log
);
275 log_state(state_b
, &state_log
);
277 /* Restoring older state invalidates newer saves (but not older saves). */
278 GdipCreateFromHDC(hdc
, &graphics1
);
279 GdipSetInterpolationMode(graphics1
, InterpolationModeBilinear
);
280 GdipSaveGraphics(graphics1
, &state_a
);
281 GdipSetInterpolationMode(graphics1
, InterpolationModeBicubic
);
282 GdipSaveGraphics(graphics1
, &state_b
);
283 GdipSetInterpolationMode(graphics1
, InterpolationModeNearestNeighbor
);
284 GdipSaveGraphics(graphics1
, &state_c
);
285 GdipSetInterpolationMode(graphics1
, InterpolationModeHighQualityBilinear
);
286 GdipRestoreGraphics(graphics1
, state_b
);
287 GdipGetInterpolationMode(graphics1
, &mode
);
288 expect(InterpolationModeBicubic
, mode
);
289 GdipRestoreGraphics(graphics1
, state_c
);
290 GdipGetInterpolationMode(graphics1
, &mode
);
291 expect(InterpolationModeBicubic
, mode
);
292 GdipRestoreGraphics(graphics1
, state_a
);
293 GdipGetInterpolationMode(graphics1
, &mode
);
294 expect(InterpolationModeBilinear
, mode
);
295 GdipDeleteGraphics(graphics1
);
297 log_state(state_a
, &state_log
);
298 log_state(state_b
, &state_log
);
299 log_state(state_c
, &state_log
);
301 /* Restoring older save from one graphics object does not invalidate
302 * newer save from other graphics object. */
303 GdipCreateFromHDC(hdc
, &graphics1
);
304 GdipCreateFromHDC(hdc
, &graphics2
);
305 GdipSetInterpolationMode(graphics1
, InterpolationModeBilinear
);
306 GdipSaveGraphics(graphics1
, &state_a
);
307 GdipSetInterpolationMode(graphics2
, InterpolationModeBicubic
);
308 GdipSaveGraphics(graphics2
, &state_b
);
309 GdipSetInterpolationMode(graphics1
, InterpolationModeNearestNeighbor
);
310 GdipSetInterpolationMode(graphics2
, InterpolationModeNearestNeighbor
);
311 GdipRestoreGraphics(graphics1
, state_a
);
312 GdipGetInterpolationMode(graphics1
, &mode
);
313 expect(InterpolationModeBilinear
, mode
);
314 GdipRestoreGraphics(graphics2
, state_b
);
315 GdipGetInterpolationMode(graphics2
, &mode
);
316 expect(InterpolationModeBicubic
, mode
);
317 GdipDeleteGraphics(graphics1
);
318 GdipDeleteGraphics(graphics2
);
320 /* You can't restore a state to a graphics object that didn't save it. */
321 GdipCreateFromHDC(hdc
, &graphics1
);
322 GdipCreateFromHDC(hdc
, &graphics2
);
323 GdipSetInterpolationMode(graphics1
, InterpolationModeBilinear
);
324 GdipSaveGraphics(graphics1
, &state_a
);
325 GdipSetInterpolationMode(graphics1
, InterpolationModeNearestNeighbor
);
326 GdipSetInterpolationMode(graphics2
, InterpolationModeNearestNeighbor
);
327 GdipRestoreGraphics(graphics2
, state_a
);
328 GdipGetInterpolationMode(graphics2
, &mode
);
329 expect(InterpolationModeNearestNeighbor
, mode
);
330 GdipDeleteGraphics(graphics1
);
331 GdipDeleteGraphics(graphics2
);
333 log_state(state_a
, &state_log
);
335 /* The same state value should never be returned twice. */
337 check_no_duplicates(state_log
);
339 ReleaseDC(hwnd
, hdc
);
342 static void test_GdipFillClosedCurve2(void)
345 GpGraphics
*graphics
= NULL
;
346 GpSolidFill
*brush
= NULL
;
347 HDC hdc
= GetDC( hwnd
);
359 /* make a graphics object and brush object */
360 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
362 status
= GdipCreateFromHDC(hdc
, &graphics
);
364 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
366 GdipCreateSolidFill((ARGB
)0xdeadbeef, &brush
);
368 /* InvalidParameter cases: null graphics, null brush, null points */
369 status
= GdipFillClosedCurve2(NULL
, NULL
, NULL
, 3, 0.5, FillModeAlternate
);
370 expect(InvalidParameter
, status
);
372 status
= GdipFillClosedCurve2(graphics
, NULL
, NULL
, 3, 0.5, FillModeAlternate
);
373 expect(InvalidParameter
, status
);
375 status
= GdipFillClosedCurve2(NULL
, (GpBrush
*)brush
, NULL
, 3, 0.5, FillModeAlternate
);
376 expect(InvalidParameter
, status
);
378 status
= GdipFillClosedCurve2(NULL
, NULL
, points
, 3, 0.5, FillModeAlternate
);
379 expect(InvalidParameter
, status
);
381 status
= GdipFillClosedCurve2(graphics
, (GpBrush
*)brush
, NULL
, 3, 0.5, FillModeAlternate
);
382 expect(InvalidParameter
, status
);
384 status
= GdipFillClosedCurve2(graphics
, NULL
, points
, 3, 0.5, FillModeAlternate
);
385 expect(InvalidParameter
, status
);
387 status
= GdipFillClosedCurve2(NULL
, (GpBrush
*)brush
, points
, 3, 0.5, FillModeAlternate
);
388 expect(InvalidParameter
, status
);
390 /* InvalidParameter cases: invalid count */
391 status
= GdipFillClosedCurve2(graphics
, (GpBrush
*)brush
, points
, -1, 0.5, FillModeAlternate
);
392 expect(InvalidParameter
, status
);
394 status
= GdipFillClosedCurve2(graphics
, (GpBrush
*)brush
, points
, 0, 0.5, FillModeAlternate
);
395 expect(InvalidParameter
, status
);
397 /* Valid test cases */
398 status
= GdipFillClosedCurve2(graphics
, (GpBrush
*)brush
, points
, 1, 0.5, FillModeAlternate
);
401 status
= GdipFillClosedCurve2(graphics
, (GpBrush
*)brush
, points
, 2, 0.5, FillModeAlternate
);
404 status
= GdipFillClosedCurve2(graphics
, (GpBrush
*)brush
, points
, 3, 0.5, FillModeAlternate
);
407 GdipDeleteGraphics(graphics
);
408 GdipDeleteBrush((GpBrush
*)brush
);
410 ReleaseDC(hwnd
, hdc
);
413 static void test_GdipFillClosedCurve2I(void)
416 GpGraphics
*graphics
= NULL
;
417 GpSolidFill
*brush
= NULL
;
418 HDC hdc
= GetDC( hwnd
);
430 /* make a graphics object and brush object */
431 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
433 status
= GdipCreateFromHDC(hdc
, &graphics
);
435 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
437 GdipCreateSolidFill((ARGB
)0xdeadbeef, &brush
);
439 /* InvalidParameter cases: null graphics, null brush */
440 /* Note: GdipFillClosedCurveI and GdipFillClosedCurve2I hang in Windows
441 when points == NULL, so don't test this condition */
442 status
= GdipFillClosedCurve2I(NULL
, NULL
, points
, 3, 0.5, FillModeAlternate
);
443 expect(InvalidParameter
, status
);
445 status
= GdipFillClosedCurve2I(graphics
, NULL
, points
, 3, 0.5, FillModeAlternate
);
446 expect(InvalidParameter
, status
);
448 status
= GdipFillClosedCurve2I(NULL
, (GpBrush
*)brush
, points
, 3, 0.5, FillModeAlternate
);
449 expect(InvalidParameter
, status
);
451 /* InvalidParameter cases: invalid count */
452 status
= GdipFillClosedCurve2I(graphics
, (GpBrush
*)brush
, points
, 0, 0.5, FillModeAlternate
);
453 expect(InvalidParameter
, status
);
455 /* OutOfMemory cases: large (unsigned) int */
456 status
= GdipFillClosedCurve2I(graphics
, (GpBrush
*)brush
, points
, -1, 0.5, FillModeAlternate
);
457 expect(OutOfMemory
, status
);
459 /* Valid test cases */
460 status
= GdipFillClosedCurve2I(graphics
, (GpBrush
*)brush
, points
, 1, 0.5, FillModeAlternate
);
463 status
= GdipFillClosedCurve2I(graphics
, (GpBrush
*)brush
, points
, 2, 0.5, FillModeAlternate
);
466 status
= GdipFillClosedCurve2I(graphics
, (GpBrush
*)brush
, points
, 3, 0.5, FillModeAlternate
);
469 GdipDeleteGraphics(graphics
);
470 GdipDeleteBrush((GpBrush
*)brush
);
472 ReleaseDC(hwnd
, hdc
);
475 static void test_GdipDrawArc(void)
478 GpGraphics
*graphics
= NULL
;
480 HDC hdc
= GetDC( hwnd
);
482 /* make a graphics object and pen object */
483 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
485 status
= GdipCreateFromHDC(hdc
, &graphics
);
487 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
489 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
491 ok(pen
!= NULL
, "Expected pen to be initialized\n");
493 /* InvalidParameter cases: null graphics, null pen, non-positive width, non-positive height */
494 status
= GdipDrawArc(NULL
, NULL
, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0);
495 expect(InvalidParameter
, status
);
497 status
= GdipDrawArc(graphics
, NULL
, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0);
498 expect(InvalidParameter
, status
);
500 status
= GdipDrawArc(NULL
, pen
, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0);
501 expect(InvalidParameter
, status
);
503 status
= GdipDrawArc(graphics
, pen
, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0);
504 expect(InvalidParameter
, status
);
506 status
= GdipDrawArc(graphics
, pen
, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0);
507 expect(InvalidParameter
, status
);
509 /* successful case */
510 status
= GdipDrawArc(graphics
, pen
, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0);
514 GdipDeleteGraphics(graphics
);
516 ReleaseDC(hwnd
, hdc
);
519 static void test_GdipDrawArcI(void)
522 GpGraphics
*graphics
= NULL
;
524 HDC hdc
= GetDC( hwnd
);
526 /* make a graphics object and pen object */
527 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
529 status
= GdipCreateFromHDC(hdc
, &graphics
);
531 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
533 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
535 ok(pen
!= NULL
, "Expected pen to be initialized\n");
537 /* InvalidParameter cases: null graphics, null pen, non-positive width, non-positive height */
538 status
= GdipDrawArcI(NULL
, NULL
, 0, 0, 0, 0, 0, 0);
539 expect(InvalidParameter
, status
);
541 status
= GdipDrawArcI(graphics
, NULL
, 0, 0, 1, 1, 0, 0);
542 expect(InvalidParameter
, status
);
544 status
= GdipDrawArcI(NULL
, pen
, 0, 0, 1, 1, 0, 0);
545 expect(InvalidParameter
, status
);
547 status
= GdipDrawArcI(graphics
, pen
, 0, 0, 1, 0, 0, 0);
548 expect(InvalidParameter
, status
);
550 status
= GdipDrawArcI(graphics
, pen
, 0, 0, 0, 1, 0, 0);
551 expect(InvalidParameter
, status
);
553 /* successful case */
554 status
= GdipDrawArcI(graphics
, pen
, 0, 0, 1, 1, 0, 0);
558 GdipDeleteGraphics(graphics
);
560 ReleaseDC(hwnd
, hdc
);
563 static void test_BeginContainer2(void)
567 REAL defClip
[] = {5, 10, 15, 20};
568 REAL elems
[6], defTrans
[] = {1, 2, 3, 4, 5, 6};
569 GraphicsContainer cont1
, cont2
, cont3
, cont4
;
570 CompositingQuality compqual
, defCompqual
= CompositingQualityHighSpeed
;
571 CompositingMode compmode
, defCompmode
= CompositingModeSourceOver
;
572 InterpolationMode interp
, defInterp
= InterpolationModeHighQualityBicubic
;
573 REAL scale
, defScale
= 17;
574 GpUnit unit
, defUnit
= UnitPixel
;
575 PixelOffsetMode offsetmode
, defOffsetmode
= PixelOffsetModeHighSpeed
;
576 SmoothingMode smoothmode
, defSmoothmode
= SmoothingModeAntiAlias
;
577 UINT contrast
, defContrast
= 5;
578 TextRenderingHint texthint
, defTexthint
= TextRenderingHintAntiAlias
;
581 GpGraphics
*graphics
= NULL
;
582 HDC hdc
= GetDC( hwnd
);
584 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
586 status
= GdipCreateFromHDC(hdc
, &graphics
);
588 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
590 /* null graphics, null container */
591 status
= GdipBeginContainer2(NULL
, &cont1
);
592 expect(InvalidParameter
, status
);
594 status
= GdipBeginContainer2(graphics
, NULL
);
595 expect(InvalidParameter
, status
);
597 status
= GdipEndContainer(NULL
, cont1
);
598 expect(InvalidParameter
, status
);
600 /* test all quality-related values */
601 GdipSetCompositingMode(graphics
, defCompmode
);
602 GdipSetCompositingQuality(graphics
, defCompqual
);
603 GdipSetInterpolationMode(graphics
, defInterp
);
604 GdipSetPageScale(graphics
, defScale
);
605 GdipSetPageUnit(graphics
, defUnit
);
606 GdipSetPixelOffsetMode(graphics
, defOffsetmode
);
607 GdipSetSmoothingMode(graphics
, defSmoothmode
);
608 GdipSetTextContrast(graphics
, defContrast
);
609 GdipSetTextRenderingHint(graphics
, defTexthint
);
611 status
= GdipBeginContainer2(graphics
, &cont1
);
614 GdipSetCompositingMode(graphics
, CompositingModeSourceCopy
);
615 GdipSetCompositingQuality(graphics
, CompositingQualityHighQuality
);
616 GdipSetInterpolationMode(graphics
, InterpolationModeBilinear
);
617 GdipSetPageScale(graphics
, 10);
618 GdipSetPageUnit(graphics
, UnitDocument
);
619 GdipSetPixelOffsetMode(graphics
, PixelOffsetModeHalf
);
620 GdipSetSmoothingMode(graphics
, SmoothingModeNone
);
621 GdipSetTextContrast(graphics
, 7);
622 GdipSetTextRenderingHint(graphics
, TextRenderingHintClearTypeGridFit
);
624 status
= GdipEndContainer(graphics
, cont1
);
627 GdipGetCompositingMode(graphics
, &compmode
);
628 ok(defCompmode
== compmode
, "Expected Compositing Mode to be restored to %d, got %d\n", defCompmode
, compmode
);
630 GdipGetCompositingQuality(graphics
, &compqual
);
631 ok(defCompqual
== compqual
, "Expected Compositing Quality to be restored to %d, got %d\n", defCompqual
, compqual
);
633 GdipGetInterpolationMode(graphics
, &interp
);
634 ok(defInterp
== interp
, "Expected Interpolation Mode to be restored to %d, got %d\n", defInterp
, interp
);
636 GdipGetPageScale(graphics
, &scale
);
637 ok(fabs(defScale
- scale
) < 0.0001, "Expected Page Scale to be restored to %f, got %f\n", defScale
, scale
);
639 GdipGetPageUnit(graphics
, &unit
);
640 ok(defUnit
== unit
, "Expected Page Unit to be restored to %d, got %d\n", defUnit
, unit
);
642 GdipGetPixelOffsetMode(graphics
, &offsetmode
);
643 ok(defOffsetmode
== offsetmode
, "Expected Pixel Offset Mode to be restored to %d, got %d\n", defOffsetmode
, offsetmode
);
645 GdipGetSmoothingMode(graphics
, &smoothmode
);
646 ok(defSmoothmode
== smoothmode
, "Expected Smoothing Mode to be restored to %d, got %d\n", defSmoothmode
, smoothmode
);
648 GdipGetTextContrast(graphics
, &contrast
);
649 ok(defContrast
== contrast
, "Expected Text Contrast to be restored to %d, got %d\n", defContrast
, contrast
);
651 GdipGetTextRenderingHint(graphics
, &texthint
);
652 ok(defTexthint
== texthint
, "Expected Text Hint to be restored to %d, got %d\n", defTexthint
, texthint
);
654 /* test world transform */
655 status
= GdipBeginContainer2(graphics
, &cont1
);
658 status
= GdipCreateMatrix2(defTrans
[0], defTrans
[1], defTrans
[2], defTrans
[3],
659 defTrans
[4], defTrans
[5], &transform
);
661 GdipSetWorldTransform(graphics
, transform
);
662 GdipDeleteMatrix(transform
);
665 status
= GdipBeginContainer2(graphics
, &cont2
);
668 status
= GdipCreateMatrix2(10, 20, 30, 40, 50, 60, &transform
);
670 GdipSetWorldTransform(graphics
, transform
);
671 GdipDeleteMatrix(transform
);
674 status
= GdipEndContainer(graphics
, cont2
);
677 status
= GdipCreateMatrix(&transform
);
679 GdipGetWorldTransform(graphics
, transform
);
680 GdipGetMatrixElements(transform
, elems
);
681 ok(fabs(defTrans
[0] - elems
[0]) < 0.0001 &&
682 fabs(defTrans
[1] - elems
[1]) < 0.0001 &&
683 fabs(defTrans
[2] - elems
[2]) < 0.0001 &&
684 fabs(defTrans
[3] - elems
[3]) < 0.0001 &&
685 fabs(defTrans
[4] - elems
[4]) < 0.0001 &&
686 fabs(defTrans
[5] - elems
[5]) < 0.0001,
687 "Expected World Transform Matrix to be restored to [%f, %f, %f, %f, %f, %f], got [%f, %f, %f, %f, %f, %f]\n",
688 defTrans
[0], defTrans
[1], defTrans
[2], defTrans
[3], defTrans
[4], defTrans
[5],
689 elems
[0], elems
[1], elems
[2], elems
[3], elems
[4], elems
[5]);
690 GdipDeleteMatrix(transform
);
693 status
= GdipEndContainer(graphics
, cont1
);
697 status
= GdipBeginContainer2(graphics
, &cont1
);
700 GdipSetClipRect(graphics
, defClip
[0], defClip
[1], defClip
[2], defClip
[3], CombineModeReplace
);
702 status
= GdipBeginContainer2(graphics
, &cont2
);
705 GdipSetClipRect(graphics
, 2, 4, 6, 8, CombineModeReplace
);
707 status
= GdipEndContainer(graphics
, cont2
);
710 status
= GdipGetClipBounds(graphics
, &clip
);
713 ok(fabs(defClip
[0] - clip
.X
) < 0.0001 &&
714 fabs(defClip
[1] - clip
.Y
) < 0.0001 &&
715 fabs(defClip
[2] - clip
.Width
) < 0.0001 &&
716 fabs(defClip
[3] - clip
.Height
) < 0.0001,
717 "Expected Clipping Rectangle to be restored to [%f, %f, %f, %f], got [%f, %f, %f, %f]\n",
718 defClip
[0], defClip
[1], defClip
[2], defClip
[3],
719 clip
.X
, clip
.Y
, clip
.Width
, clip
.Height
);
721 status
= GdipEndContainer(graphics
, cont1
);
725 status
= GdipBeginContainer2(graphics
, &cont1
);
728 status
= GdipBeginContainer2(graphics
, &cont2
);
731 status
= GdipBeginContainer2(graphics
, &cont3
);
734 status
= GdipEndContainer(graphics
, cont3
);
737 status
= GdipBeginContainer2(graphics
, &cont4
);
740 status
= GdipEndContainer(graphics
, cont4
);
744 status
= GdipEndContainer(graphics
, cont1
);
747 /* end an already-ended container */
748 status
= GdipEndContainer(graphics
, cont1
);
751 GdipDeleteGraphics(graphics
);
752 ReleaseDC(hwnd
, hdc
);
755 static void test_GdipDrawBezierI(void)
758 GpGraphics
*graphics
= NULL
;
760 HDC hdc
= GetDC( hwnd
);
762 /* make a graphics object and pen object */
763 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
765 status
= GdipCreateFromHDC(hdc
, &graphics
);
767 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
769 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
771 ok(pen
!= NULL
, "Expected pen to be initialized\n");
773 /* InvalidParameter cases: null graphics, null pen */
774 status
= GdipDrawBezierI(NULL
, NULL
, 0, 0, 0, 0, 0, 0, 0, 0);
775 expect(InvalidParameter
, status
);
777 status
= GdipDrawBezierI(graphics
, NULL
, 0, 0, 0, 0, 0, 0, 0, 0);
778 expect(InvalidParameter
, status
);
780 status
= GdipDrawBezierI(NULL
, pen
, 0, 0, 0, 0, 0, 0, 0, 0);
781 expect(InvalidParameter
, status
);
783 /* successful case */
784 status
= GdipDrawBezierI(graphics
, pen
, 0, 0, 0, 0, 0, 0, 0, 0);
788 GdipDeleteGraphics(graphics
);
790 ReleaseDC(hwnd
, hdc
);
793 static void test_GdipDrawCurve3(void)
796 GpGraphics
*graphics
= NULL
;
798 HDC hdc
= GetDC( hwnd
);
810 /* make a graphics object and pen object */
811 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
813 status
= GdipCreateFromHDC(hdc
, &graphics
);
815 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
817 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
819 ok(pen
!= NULL
, "Expected pen to be initialized\n");
821 /* InvalidParameter cases: null graphics, null pen */
822 status
= GdipDrawCurve3(NULL
, NULL
, points
, 3, 0, 2, 1);
823 expect(InvalidParameter
, status
);
825 status
= GdipDrawCurve3(graphics
, NULL
, points
, 3, 0, 2, 1);
826 expect(InvalidParameter
, status
);
828 status
= GdipDrawCurve3(NULL
, pen
, points
, 3, 0, 2, 1);
829 expect(InvalidParameter
, status
);
831 /* InvalidParameter cases: invalid count */
832 status
= GdipDrawCurve3(graphics
, pen
, points
, -1, 0, 2, 1);
833 expect(InvalidParameter
, status
);
835 status
= GdipDrawCurve3(graphics
, pen
, points
, 0, 0, 2, 1);
836 expect(InvalidParameter
, status
);
838 status
= GdipDrawCurve3(graphics
, pen
, points
, 1, 0, 0, 1);
839 expect(InvalidParameter
, status
);
841 status
= GdipDrawCurve3(graphics
, pen
, points
, 3, 4, 2, 1);
842 expect(InvalidParameter
, status
);
844 /* InvalidParameter cases: invalid number of segments */
845 status
= GdipDrawCurve3(graphics
, pen
, points
, 3, 0, -1, 1);
846 expect(InvalidParameter
, status
);
848 status
= GdipDrawCurve3(graphics
, pen
, points
, 3, 1, 2, 1);
849 expect(InvalidParameter
, status
);
851 status
= GdipDrawCurve3(graphics
, pen
, points
, 2, 0, 2, 1);
852 expect(InvalidParameter
, status
);
854 /* Valid test cases */
855 status
= GdipDrawCurve3(graphics
, pen
, points
, 2, 0, 1, 1);
858 status
= GdipDrawCurve3(graphics
, pen
, points
, 3, 0, 2, 2);
861 status
= GdipDrawCurve3(graphics
, pen
, points
, 2, 0, 1, -2);
864 status
= GdipDrawCurve3(graphics
, pen
, points
, 3, 1, 1, 0);
868 GdipDeleteGraphics(graphics
);
870 ReleaseDC(hwnd
, hdc
);
873 static void test_GdipDrawCurve3I(void)
876 GpGraphics
*graphics
= NULL
;
878 HDC hdc
= GetDC( hwnd
);
890 /* make a graphics object and pen object */
891 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
893 status
= GdipCreateFromHDC(hdc
, &graphics
);
895 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
897 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
899 ok(pen
!= NULL
, "Expected pen to be initialized\n");
901 /* InvalidParameter cases: null graphics, null pen */
902 status
= GdipDrawCurve3I(NULL
, NULL
, points
, 3, 0, 2, 1);
903 expect(InvalidParameter
, status
);
905 status
= GdipDrawCurve3I(graphics
, NULL
, points
, 3, 0, 2, 1);
906 expect(InvalidParameter
, status
);
908 status
= GdipDrawCurve3I(NULL
, pen
, points
, 3, 0, 2, 1);
909 expect(InvalidParameter
, status
);
911 /* InvalidParameter cases: invalid count */
912 status
= GdipDrawCurve3I(graphics
, pen
, points
, -1, -1, -1, 1);
913 expect(OutOfMemory
, status
);
915 status
= GdipDrawCurve3I(graphics
, pen
, points
, 0, 0, 2, 1);
916 expect(InvalidParameter
, status
);
918 status
= GdipDrawCurve3I(graphics
, pen
, points
, 1, 0, 0, 1);
919 expect(InvalidParameter
, status
);
921 status
= GdipDrawCurve3I(graphics
, pen
, points
, 3, 4, 2, 1);
922 expect(InvalidParameter
, status
);
924 /* InvalidParameter cases: invalid number of segments */
925 status
= GdipDrawCurve3I(graphics
, pen
, points
, 3, 0, -1, 1);
926 expect(InvalidParameter
, status
);
928 status
= GdipDrawCurve3I(graphics
, pen
, points
, 3, 1, 2, 1);
929 expect(InvalidParameter
, status
);
931 status
= GdipDrawCurve3I(graphics
, pen
, points
, 2, 0, 2, 1);
932 expect(InvalidParameter
, status
);
934 /* Valid test cases */
935 status
= GdipDrawCurve3I(graphics
, pen
, points
, 2, 0, 1, 1);
938 status
= GdipDrawCurve3I(graphics
, pen
, points
, 3, 0, 2, 2);
941 status
= GdipDrawCurve3I(graphics
, pen
, points
, 2, 0, 1, -2);
944 status
= GdipDrawCurve3I(graphics
, pen
, points
, 3, 1, 1, 0);
948 GdipDeleteGraphics(graphics
);
950 ReleaseDC(hwnd
, hdc
);
953 static void test_GdipDrawCurve2(void)
956 GpGraphics
*graphics
= NULL
;
958 HDC hdc
= GetDC( hwnd
);
970 /* make a graphics object and pen object */
971 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
973 status
= GdipCreateFromHDC(hdc
, &graphics
);
975 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
977 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
979 ok(pen
!= NULL
, "Expected pen to be initialized\n");
981 /* InvalidParameter cases: null graphics, null pen */
982 status
= GdipDrawCurve2(NULL
, NULL
, points
, 3, 1);
983 expect(InvalidParameter
, status
);
985 status
= GdipDrawCurve2(graphics
, NULL
, points
, 3, 1);
986 expect(InvalidParameter
, status
);
988 status
= GdipDrawCurve2(NULL
, pen
, points
, 3, 1);
989 expect(InvalidParameter
, status
);
991 /* InvalidParameter cases: invalid count */
992 status
= GdipDrawCurve2(graphics
, pen
, points
, -1, 1);
993 expect(InvalidParameter
, status
);
995 status
= GdipDrawCurve2(graphics
, pen
, points
, 0, 1);
996 expect(InvalidParameter
, status
);
998 status
= GdipDrawCurve2(graphics
, pen
, points
, 1, 1);
999 expect(InvalidParameter
, status
);
1001 /* Valid test cases */
1002 status
= GdipDrawCurve2(graphics
, pen
, points
, 2, 1);
1005 status
= GdipDrawCurve2(graphics
, pen
, points
, 3, 2);
1008 status
= GdipDrawCurve2(graphics
, pen
, points
, 3, -2);
1011 status
= GdipDrawCurve2(graphics
, pen
, points
, 3, 0);
1015 GdipDeleteGraphics(graphics
);
1017 ReleaseDC(hwnd
, hdc
);
1020 static void test_GdipDrawCurve2I(void)
1023 GpGraphics
*graphics
= NULL
;
1025 HDC hdc
= GetDC( hwnd
);
1037 /* make a graphics object and pen object */
1038 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
1040 status
= GdipCreateFromHDC(hdc
, &graphics
);
1042 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1044 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
1046 ok(pen
!= NULL
, "Expected pen to be initialized\n");
1048 /* InvalidParameter cases: null graphics, null pen */
1049 status
= GdipDrawCurve2I(NULL
, NULL
, points
, 3, 1);
1050 expect(InvalidParameter
, status
);
1052 status
= GdipDrawCurve2I(graphics
, NULL
, points
, 3, 1);
1053 expect(InvalidParameter
, status
);
1055 status
= GdipDrawCurve2I(NULL
, pen
, points
, 3, 1);
1056 expect(InvalidParameter
, status
);
1058 /* InvalidParameter cases: invalid count */
1059 status
= GdipDrawCurve2I(graphics
, pen
, points
, -1, 1);
1060 expect(OutOfMemory
, status
);
1062 status
= GdipDrawCurve2I(graphics
, pen
, points
, 0, 1);
1063 expect(InvalidParameter
, status
);
1065 status
= GdipDrawCurve2I(graphics
, pen
, points
, 1, 1);
1066 expect(InvalidParameter
, status
);
1068 /* Valid test cases */
1069 status
= GdipDrawCurve2I(graphics
, pen
, points
, 2, 1);
1072 status
= GdipDrawCurve2I(graphics
, pen
, points
, 3, 2);
1075 status
= GdipDrawCurve2I(graphics
, pen
, points
, 3, -2);
1078 status
= GdipDrawCurve2I(graphics
, pen
, points
, 3, 0);
1082 GdipDeleteGraphics(graphics
);
1084 ReleaseDC(hwnd
, hdc
);
1087 static void test_GdipDrawCurve(void)
1090 GpGraphics
*graphics
= NULL
;
1092 HDC hdc
= GetDC( hwnd
);
1104 /* make a graphics object and pen object */
1105 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
1107 status
= GdipCreateFromHDC(hdc
, &graphics
);
1109 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1111 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
1113 ok(pen
!= NULL
, "Expected pen to be initialized\n");
1115 /* InvalidParameter cases: null graphics, null pen */
1116 status
= GdipDrawCurve(NULL
, NULL
, points
, 3);
1117 expect(InvalidParameter
, status
);
1119 status
= GdipDrawCurve(graphics
, NULL
, points
, 3);
1120 expect(InvalidParameter
, status
);
1122 status
= GdipDrawCurve(NULL
, pen
, points
, 3);
1123 expect(InvalidParameter
, status
);
1125 /* InvalidParameter cases: invalid count */
1126 status
= GdipDrawCurve(graphics
, pen
, points
, -1);
1127 expect(InvalidParameter
, status
);
1129 status
= GdipDrawCurve(graphics
, pen
, points
, 0);
1130 expect(InvalidParameter
, status
);
1132 status
= GdipDrawCurve(graphics
, pen
, points
, 1);
1133 expect(InvalidParameter
, status
);
1135 /* Valid test cases */
1136 status
= GdipDrawCurve(graphics
, pen
, points
, 2);
1139 status
= GdipDrawCurve(graphics
, pen
, points
, 3);
1143 GdipDeleteGraphics(graphics
);
1145 ReleaseDC(hwnd
, hdc
);
1148 static void test_GdipDrawCurveI(void)
1151 GpGraphics
*graphics
= NULL
;
1153 HDC hdc
= GetDC( hwnd
);
1165 /* make a graphics object and pen object */
1166 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
1168 status
= GdipCreateFromHDC(hdc
, &graphics
);
1170 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1172 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
1174 ok(pen
!= NULL
, "Expected pen to be initialized\n");
1176 /* InvalidParameter cases: null graphics, null pen */
1177 status
= GdipDrawCurveI(NULL
, NULL
, points
, 3);
1178 expect(InvalidParameter
, status
);
1180 status
= GdipDrawCurveI(graphics
, NULL
, points
, 3);
1181 expect(InvalidParameter
, status
);
1183 status
= GdipDrawCurveI(NULL
, pen
, points
, 3);
1184 expect(InvalidParameter
, status
);
1186 /* InvalidParameter cases: invalid count */
1187 status
= GdipDrawCurveI(graphics
, pen
, points
, -1);
1188 expect(OutOfMemory
, status
);
1190 status
= GdipDrawCurveI(graphics
, pen
, points
, 0);
1191 expect(InvalidParameter
, status
);
1193 status
= GdipDrawCurveI(graphics
, pen
, points
, 1);
1194 expect(InvalidParameter
, status
);
1196 /* Valid test cases */
1197 status
= GdipDrawCurveI(graphics
, pen
, points
, 2);
1200 status
= GdipDrawCurveI(graphics
, pen
, points
, 3);
1204 GdipDeleteGraphics(graphics
);
1206 ReleaseDC(hwnd
, hdc
);
1209 static void test_GdipDrawLineI(void)
1212 GpGraphics
*graphics
= NULL
;
1214 HDC hdc
= GetDC( hwnd
);
1216 /* make a graphics object and pen object */
1217 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
1219 status
= GdipCreateFromHDC(hdc
, &graphics
);
1221 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1223 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
1225 ok(pen
!= NULL
, "Expected pen to be initialized\n");
1227 /* InvalidParameter cases: null graphics, null pen */
1228 status
= GdipDrawLineI(NULL
, NULL
, 0, 0, 0, 0);
1229 expect(InvalidParameter
, status
);
1231 status
= GdipDrawLineI(graphics
, NULL
, 0, 0, 0, 0);
1232 expect(InvalidParameter
, status
);
1234 status
= GdipDrawLineI(NULL
, pen
, 0, 0, 0, 0);
1235 expect(InvalidParameter
, status
);
1237 /* successful case */
1238 status
= GdipDrawLineI(graphics
, pen
, 0, 0, 0, 0);
1242 GdipDeleteGraphics(graphics
);
1244 ReleaseDC(hwnd
, hdc
);
1247 static void test_GdipDrawImagePointsRect(void)
1250 GpGraphics
*graphics
= NULL
;
1252 GpBitmap
*bm
= NULL
;
1253 BYTE rbmi
[sizeof(BITMAPINFOHEADER
)];
1255 BITMAPINFO
*bmi
= (BITMAPINFO
*)rbmi
;
1256 HDC hdc
= GetDC( hwnd
);
1260 memset(rbmi
, 0, sizeof(rbmi
));
1261 bmi
->bmiHeader
.biSize
= sizeof(BITMAPINFOHEADER
);
1262 bmi
->bmiHeader
.biWidth
= 10;
1263 bmi
->bmiHeader
.biHeight
= 10;
1264 bmi
->bmiHeader
.biPlanes
= 1;
1265 bmi
->bmiHeader
.biBitCount
= 32;
1266 bmi
->bmiHeader
.biCompression
= BI_RGB
;
1267 status
= GdipCreateBitmapFromGdiDib(bmi
, buff
, &bm
);
1269 ok(NULL
!= bm
, "Expected bitmap to be initialized\n");
1270 status
= GdipCreateFromHDC(hdc
, &graphics
);
1280 status
= GdipDrawImagePointsRect(graphics
, (GpImage
*)bm
, ptf
, 4, 0, 0, 10, 10, UnitPixel
, NULL
, NULL
, NULL
);
1281 expect(NotImplemented
, status
);
1282 status
= GdipDrawImagePointsRect(graphics
, (GpImage
*)bm
, ptf
, 2, 0, 0, 10, 10, UnitPixel
, NULL
, NULL
, NULL
);
1283 expect(InvalidParameter
, status
);
1284 status
= GdipDrawImagePointsRect(graphics
, (GpImage
*)bm
, ptf
, 3, 0, 0, 10, 10, UnitPixel
, NULL
, NULL
, NULL
);
1286 status
= GdipDrawImagePointsRect(graphics
, NULL
, ptf
, 3, 0, 0, 10, 10, UnitPixel
, NULL
, NULL
, NULL
);
1287 expect(InvalidParameter
, status
);
1288 status
= GdipDrawImagePointsRect(graphics
, (GpImage
*)bm
, NULL
, 3, 0, 0, 10, 10, UnitPixel
, NULL
, NULL
, NULL
);
1289 expect(InvalidParameter
, status
);
1290 status
= GdipDrawImagePointsRect(graphics
, (GpImage
*)bm
, ptf
, 3, 0, 0, 0, 0, UnitPixel
, NULL
, NULL
, NULL
);
1292 memset(ptf
, 0, sizeof(ptf
));
1293 status
= GdipDrawImagePointsRect(graphics
, (GpImage
*)bm
, ptf
, 3, 0, 0, 10, 10, UnitPixel
, NULL
, NULL
, NULL
);
1296 GdipDisposeImage((GpImage
*)bm
);
1297 GdipDeleteGraphics(graphics
);
1298 ReleaseDC(hwnd
, hdc
);
1301 static void test_GdipDrawLinesI(void)
1304 GpGraphics
*graphics
= NULL
;
1306 GpPoint
*ptf
= NULL
;
1307 HDC hdc
= GetDC( hwnd
);
1309 /* make a graphics object and pen object */
1310 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
1312 status
= GdipCreateFromHDC(hdc
, &graphics
);
1314 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1316 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
1318 ok(pen
!= NULL
, "Expected pen to be initialized\n");
1320 /* make some arbitrary valid points*/
1321 ptf
= GdipAlloc(2 * sizeof(GpPointF
));
1329 /* InvalidParameter cases: null graphics, null pen, null points, count < 2*/
1330 status
= GdipDrawLinesI(NULL
, NULL
, NULL
, 0);
1331 expect(InvalidParameter
, status
);
1333 status
= GdipDrawLinesI(graphics
, pen
, ptf
, 0);
1334 expect(InvalidParameter
, status
);
1336 status
= GdipDrawLinesI(graphics
, NULL
, ptf
, 2);
1337 expect(InvalidParameter
, status
);
1339 status
= GdipDrawLinesI(NULL
, pen
, ptf
, 2);
1340 expect(InvalidParameter
, status
);
1342 /* successful case */
1343 status
= GdipDrawLinesI(graphics
, pen
, ptf
, 2);
1348 GdipDeleteGraphics(graphics
);
1350 ReleaseDC(hwnd
, hdc
);
1353 static void test_GdipFillClosedCurve(void)
1356 GpGraphics
*graphics
= NULL
;
1357 GpSolidFill
*brush
= NULL
;
1358 HDC hdc
= GetDC( hwnd
);
1370 /* make a graphics object and brush object */
1371 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
1373 status
= GdipCreateFromHDC(hdc
, &graphics
);
1375 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1377 GdipCreateSolidFill((ARGB
)0xdeadbeef, &brush
);
1379 /* InvalidParameter cases: null graphics, null brush, null points */
1380 status
= GdipFillClosedCurve(NULL
, NULL
, NULL
, 3);
1381 expect(InvalidParameter
, status
);
1383 status
= GdipFillClosedCurve(graphics
, NULL
, NULL
, 3);
1384 expect(InvalidParameter
, status
);
1386 status
= GdipFillClosedCurve(NULL
, (GpBrush
*)brush
, NULL
, 3);
1387 expect(InvalidParameter
, status
);
1389 status
= GdipFillClosedCurve(NULL
, NULL
, points
, 3);
1390 expect(InvalidParameter
, status
);
1392 status
= GdipFillClosedCurve(graphics
, (GpBrush
*)brush
, NULL
, 3);
1393 expect(InvalidParameter
, status
);
1395 status
= GdipFillClosedCurve(graphics
, NULL
, points
, 3);
1396 expect(InvalidParameter
, status
);
1398 status
= GdipFillClosedCurve(NULL
, (GpBrush
*)brush
, points
, 3);
1399 expect(InvalidParameter
, status
);
1401 /* InvalidParameter cases: invalid count */
1402 status
= GdipFillClosedCurve(graphics
, (GpBrush
*)brush
, points
, -1);
1403 expect(InvalidParameter
, status
);
1405 status
= GdipFillClosedCurve(graphics
, (GpBrush
*)brush
, points
, 0);
1406 expect(InvalidParameter
, status
);
1408 /* Valid test cases */
1409 status
= GdipFillClosedCurve(graphics
, (GpBrush
*)brush
, points
, 1);
1412 status
= GdipFillClosedCurve(graphics
, (GpBrush
*)brush
, points
, 2);
1415 status
= GdipFillClosedCurve(graphics
, (GpBrush
*)brush
, points
, 3);
1418 GdipDeleteGraphics(graphics
);
1419 GdipDeleteBrush((GpBrush
*)brush
);
1421 ReleaseDC(hwnd
, hdc
);
1424 static void test_GdipFillClosedCurveI(void)
1427 GpGraphics
*graphics
= NULL
;
1428 GpSolidFill
*brush
= NULL
;
1429 HDC hdc
= GetDC( hwnd
);
1441 /* make a graphics object and brush object */
1442 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
1444 status
= GdipCreateFromHDC(hdc
, &graphics
);
1446 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1448 GdipCreateSolidFill((ARGB
)0xdeadbeef, &brush
);
1450 /* InvalidParameter cases: null graphics, null brush */
1451 /* Note: GdipFillClosedCurveI and GdipFillClosedCurve2I hang in Windows
1452 when points == NULL, so don't test this condition */
1453 status
= GdipFillClosedCurveI(NULL
, NULL
, points
, 3);
1454 expect(InvalidParameter
, status
);
1456 status
= GdipFillClosedCurveI(graphics
, NULL
, points
, 3);
1457 expect(InvalidParameter
, status
);
1459 status
= GdipFillClosedCurveI(NULL
, (GpBrush
*)brush
, points
, 3);
1460 expect(InvalidParameter
, status
);
1462 /* InvalidParameter cases: invalid count */
1463 status
= GdipFillClosedCurveI(graphics
, (GpBrush
*)brush
, points
, 0);
1464 expect(InvalidParameter
, status
);
1466 /* OutOfMemory cases: large (unsigned) int */
1467 status
= GdipFillClosedCurveI(graphics
, (GpBrush
*)brush
, points
, -1);
1468 expect(OutOfMemory
, status
);
1470 /* Valid test cases */
1471 status
= GdipFillClosedCurveI(graphics
, (GpBrush
*)brush
, points
, 1);
1474 status
= GdipFillClosedCurveI(graphics
, (GpBrush
*)brush
, points
, 2);
1477 status
= GdipFillClosedCurveI(graphics
, (GpBrush
*)brush
, points
, 3);
1480 GdipDeleteGraphics(graphics
);
1481 GdipDeleteBrush((GpBrush
*)brush
);
1483 ReleaseDC(hwnd
, hdc
);
1486 static void test_Get_Release_DC(void)
1489 GpGraphics
*graphics
= NULL
;
1493 HDC hdc
= GetDC( hwnd
);
1496 CompositingQuality quality
;
1497 CompositingMode compmode
;
1498 InterpolationMode intmode
;
1502 PixelOffsetMode offsetmode
;
1503 SmoothingMode smoothmode
;
1504 TextRenderingHint texthint
;
1512 ARGB color
= 0x00000000;
1513 HRGN hrgn
= CreateRectRgn(0, 0, 10, 10);
1526 for(i
= 0; i
< 5;i
++){
1527 ptf
[i
].X
= (REAL
)pt
[i
].X
;
1528 ptf
[i
].Y
= (REAL
)pt
[i
].Y
;
1534 rect
[0].Height
= 70;
1538 rect
[1].Height
= 20;
1540 for(i
= 0; i
< 2;i
++){
1541 rectf
[i
].X
= (REAL
)rect
[i
].X
;
1542 rectf
[i
].Y
= (REAL
)rect
[i
].Y
;
1543 rectf
[i
].Height
= (REAL
)rect
[i
].Height
;
1544 rectf
[i
].Width
= (REAL
)rect
[i
].Width
;
1547 status
= GdipCreateMatrix(&m
);
1549 GdipCreateRegion(®ion
);
1550 GdipCreateSolidFill((ARGB
)0xdeadbeef, &brush
);
1551 GdipCreatePath(FillModeAlternate
, &path
);
1552 GdipCreateRegion(&clip
);
1554 status
= GdipCreateFromHDC(hdc
, &graphics
);
1556 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
1557 status
= GdipCreatePen1((ARGB
)0xffff00ff, 10.0f
, UnitPixel
, &pen
);
1560 /* NULL arguments */
1561 status
= GdipGetDC(NULL
, NULL
);
1562 expect(InvalidParameter
, status
);
1563 status
= GdipGetDC(graphics
, NULL
);
1564 expect(InvalidParameter
, status
);
1565 status
= GdipGetDC(NULL
, &retdc
);
1566 expect(InvalidParameter
, status
);
1568 status
= GdipReleaseDC(NULL
, NULL
);
1569 expect(InvalidParameter
, status
);
1570 status
= GdipReleaseDC(graphics
, NULL
);
1571 expect(InvalidParameter
, status
);
1572 status
= GdipReleaseDC(NULL
, (HDC
)0xdeadbeef);
1573 expect(InvalidParameter
, status
);
1575 /* Release without Get */
1576 status
= GdipReleaseDC(graphics
, hdc
);
1577 expect(InvalidParameter
, status
);
1580 status
= GdipGetDC(graphics
, &retdc
);
1582 ok(retdc
== hdc
, "Invalid HDC returned\n");
1583 /* call it once more */
1584 status
= GdipGetDC(graphics
, &retdc
);
1585 expect(ObjectBusy
, status
);
1587 /* try all Graphics calls here */
1588 status
= GdipDrawArc(graphics
, pen
, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0);
1589 expect(ObjectBusy
, status
);
1590 status
= GdipDrawArcI(graphics
, pen
, 0, 0, 1, 1, 0.0, 0.0);
1591 expect(ObjectBusy
, status
);
1592 status
= GdipDrawBezier(graphics
, pen
, 0.0, 10.0, 20.0, 15.0, 35.0, -10.0, 10.0, 10.0);
1593 expect(ObjectBusy
, status
);
1594 status
= GdipDrawBezierI(graphics
, pen
, 0, 0, 0, 0, 0, 0, 0, 0);
1595 expect(ObjectBusy
, status
);
1596 status
= GdipDrawBeziers(graphics
, pen
, ptf
, 5);
1597 expect(ObjectBusy
, status
);
1598 status
= GdipDrawBeziersI(graphics
, pen
, pt
, 5);
1599 expect(ObjectBusy
, status
);
1600 status
= GdipDrawClosedCurve(graphics
, pen
, ptf
, 5);
1601 expect(ObjectBusy
, status
);
1602 status
= GdipDrawClosedCurveI(graphics
, pen
, pt
, 5);
1603 expect(ObjectBusy
, status
);
1604 status
= GdipDrawClosedCurve2(graphics
, pen
, ptf
, 5, 1.0);
1605 expect(ObjectBusy
, status
);
1606 status
= GdipDrawClosedCurve2I(graphics
, pen
, pt
, 5, 1.0);
1607 expect(ObjectBusy
, status
);
1608 status
= GdipDrawCurve(graphics
, pen
, ptf
, 5);
1609 expect(ObjectBusy
, status
);
1610 status
= GdipDrawCurveI(graphics
, pen
, pt
, 5);
1611 expect(ObjectBusy
, status
);
1612 status
= GdipDrawCurve2(graphics
, pen
, ptf
, 5, 1.0);
1613 expect(ObjectBusy
, status
);
1614 status
= GdipDrawCurve2I(graphics
, pen
, pt
, 5, 1.0);
1615 expect(ObjectBusy
, status
);
1616 status
= GdipDrawEllipse(graphics
, pen
, 0.0, 0.0, 100.0, 50.0);
1617 expect(ObjectBusy
, status
);
1618 status
= GdipDrawEllipseI(graphics
, pen
, 0, 0, 100, 50);
1619 expect(ObjectBusy
, status
);
1620 /* GdipDrawImage/GdipDrawImageI */
1621 /* GdipDrawImagePointsRect/GdipDrawImagePointsRectI */
1622 /* GdipDrawImageRectRect/GdipDrawImageRectRectI */
1623 /* GdipDrawImageRect/GdipDrawImageRectI */
1624 status
= GdipDrawLine(graphics
, pen
, 0.0, 0.0, 100.0, 200.0);
1625 expect(ObjectBusy
, status
);
1626 status
= GdipDrawLineI(graphics
, pen
, 0, 0, 100, 200);
1627 expect(ObjectBusy
, status
);
1628 status
= GdipDrawLines(graphics
, pen
, ptf
, 5);
1629 expect(ObjectBusy
, status
);
1630 status
= GdipDrawLinesI(graphics
, pen
, pt
, 5);
1631 expect(ObjectBusy
, status
);
1632 status
= GdipDrawPath(graphics
, pen
, path
);
1633 expect(ObjectBusy
, status
);
1634 status
= GdipDrawPie(graphics
, pen
, 0.0, 0.0, 100.0, 100.0, 0.0, 90.0);
1635 expect(ObjectBusy
, status
);
1636 status
= GdipDrawPieI(graphics
, pen
, 0, 0, 100, 100, 0.0, 90.0);
1637 expect(ObjectBusy
, status
);
1638 status
= GdipDrawRectangle(graphics
, pen
, 0.0, 0.0, 100.0, 300.0);
1639 expect(ObjectBusy
, status
);
1640 status
= GdipDrawRectangleI(graphics
, pen
, 0, 0, 100, 300);
1641 expect(ObjectBusy
, status
);
1642 status
= GdipDrawRectangles(graphics
, pen
, rectf
, 2);
1643 expect(ObjectBusy
, status
);
1644 status
= GdipDrawRectanglesI(graphics
, pen
, rect
, 2);
1645 expect(ObjectBusy
, status
);
1646 /* GdipDrawString */
1647 status
= GdipFillClosedCurve2(graphics
, (GpBrush
*)brush
, ptf
, 5, 1.0, FillModeAlternate
);
1648 expect(ObjectBusy
, status
);
1649 status
= GdipFillClosedCurve2I(graphics
, (GpBrush
*)brush
, pt
, 5, 1.0, FillModeAlternate
);
1650 expect(ObjectBusy
, status
);
1651 status
= GdipFillClosedCurve(graphics
, (GpBrush
*)brush
, ptf
, 5);
1652 expect(ObjectBusy
, status
);
1653 status
= GdipFillClosedCurveI(graphics
, (GpBrush
*)brush
, pt
, 5);
1654 expect(ObjectBusy
, status
);
1655 status
= GdipFillEllipse(graphics
, (GpBrush
*)brush
, 0.0, 0.0, 100.0, 100.0);
1656 expect(ObjectBusy
, status
);
1657 status
= GdipFillEllipseI(graphics
, (GpBrush
*)brush
, 0, 0, 100, 100);
1658 expect(ObjectBusy
, status
);
1659 status
= GdipFillPath(graphics
, (GpBrush
*)brush
, path
);
1660 expect(ObjectBusy
, status
);
1661 status
= GdipFillPie(graphics
, (GpBrush
*)brush
, 0.0, 0.0, 100.0, 100.0, 0.0, 15.0);
1662 expect(ObjectBusy
, status
);
1663 status
= GdipFillPieI(graphics
, (GpBrush
*)brush
, 0, 0, 100, 100, 0.0, 15.0);
1664 expect(ObjectBusy
, status
);
1665 status
= GdipFillPolygon(graphics
, (GpBrush
*)brush
, ptf
, 5, FillModeAlternate
);
1666 expect(ObjectBusy
, status
);
1667 status
= GdipFillPolygonI(graphics
, (GpBrush
*)brush
, pt
, 5, FillModeAlternate
);
1668 expect(ObjectBusy
, status
);
1669 status
= GdipFillPolygon2(graphics
, (GpBrush
*)brush
, ptf
, 5);
1670 expect(ObjectBusy
, status
);
1671 status
= GdipFillPolygon2I(graphics
, (GpBrush
*)brush
, pt
, 5);
1672 expect(ObjectBusy
, status
);
1673 status
= GdipFillRectangle(graphics
, (GpBrush
*)brush
, 0.0, 0.0, 100.0, 100.0);
1674 expect(ObjectBusy
, status
);
1675 status
= GdipFillRectangleI(graphics
, (GpBrush
*)brush
, 0, 0, 100, 100);
1676 expect(ObjectBusy
, status
);
1677 status
= GdipFillRectangles(graphics
, (GpBrush
*)brush
, rectf
, 2);
1678 expect(ObjectBusy
, status
);
1679 status
= GdipFillRectanglesI(graphics
, (GpBrush
*)brush
, rect
, 2);
1680 expect(ObjectBusy
, status
);
1681 status
= GdipFillRegion(graphics
, (GpBrush
*)brush
, region
);
1682 expect(ObjectBusy
, status
);
1683 status
= GdipFlush(graphics
, FlushIntentionFlush
);
1684 expect(ObjectBusy
, status
);
1685 status
= GdipGetClipBounds(graphics
, rectf
);
1686 expect(ObjectBusy
, status
);
1687 status
= GdipGetClipBoundsI(graphics
, rect
);
1688 expect(ObjectBusy
, status
);
1689 status
= GdipGetCompositingMode(graphics
, &compmode
);
1690 expect(ObjectBusy
, status
);
1691 status
= GdipGetCompositingQuality(graphics
, &quality
);
1692 expect(ObjectBusy
, status
);
1693 status
= GdipGetInterpolationMode(graphics
, &intmode
);
1694 expect(ObjectBusy
, status
);
1695 status
= GdipGetNearestColor(graphics
, &color
);
1696 expect(ObjectBusy
, status
);
1697 status
= GdipGetPageScale(graphics
, &r
);
1698 expect(ObjectBusy
, status
);
1699 status
= GdipGetPageUnit(graphics
, &unit
);
1700 expect(ObjectBusy
, status
);
1701 status
= GdipGetPixelOffsetMode(graphics
, &offsetmode
);
1702 expect(ObjectBusy
, status
);
1703 status
= GdipGetSmoothingMode(graphics
, &smoothmode
);
1704 expect(ObjectBusy
, status
);
1705 status
= GdipGetTextRenderingHint(graphics
, &texthint
);
1706 expect(ObjectBusy
, status
);
1707 status
= GdipGetWorldTransform(graphics
, m
);
1708 expect(ObjectBusy
, status
);
1709 status
= GdipGraphicsClear(graphics
, 0xdeadbeef);
1710 expect(ObjectBusy
, status
);
1711 status
= GdipIsVisiblePoint(graphics
, 0.0, 0.0, &res
);
1712 expect(ObjectBusy
, status
);
1713 status
= GdipIsVisiblePointI(graphics
, 0, 0, &res
);
1714 expect(ObjectBusy
, status
);
1715 /* GdipMeasureCharacterRanges */
1716 /* GdipMeasureString */
1717 status
= GdipResetClip(graphics
);
1718 expect(ObjectBusy
, status
);
1719 status
= GdipResetWorldTransform(graphics
);
1720 expect(ObjectBusy
, status
);
1721 /* GdipRestoreGraphics */
1722 status
= GdipRotateWorldTransform(graphics
, 15.0, MatrixOrderPrepend
);
1723 expect(ObjectBusy
, status
);
1724 /* GdipSaveGraphics */
1725 status
= GdipScaleWorldTransform(graphics
, 1.0, 1.0, MatrixOrderPrepend
);
1726 expect(ObjectBusy
, status
);
1727 status
= GdipSetCompositingMode(graphics
, CompositingModeSourceOver
);
1728 expect(ObjectBusy
, status
);
1729 status
= GdipSetCompositingQuality(graphics
, CompositingQualityDefault
);
1730 expect(ObjectBusy
, status
);
1731 status
= GdipSetInterpolationMode(graphics
, InterpolationModeDefault
);
1732 expect(ObjectBusy
, status
);
1733 status
= GdipSetPageScale(graphics
, 1.0);
1734 expect(ObjectBusy
, status
);
1735 status
= GdipSetPageUnit(graphics
, UnitWorld
);
1736 expect(ObjectBusy
, status
);
1737 status
= GdipSetPixelOffsetMode(graphics
, PixelOffsetModeDefault
);
1738 expect(ObjectBusy
, status
);
1739 status
= GdipSetSmoothingMode(graphics
, SmoothingModeDefault
);
1740 expect(ObjectBusy
, status
);
1741 status
= GdipSetTextRenderingHint(graphics
, TextRenderingHintSystemDefault
);
1742 expect(ObjectBusy
, status
);
1743 status
= GdipSetWorldTransform(graphics
, m
);
1744 expect(ObjectBusy
, status
);
1745 status
= GdipTranslateWorldTransform(graphics
, 0.0, 0.0, MatrixOrderPrepend
);
1746 expect(ObjectBusy
, status
);
1747 status
= GdipSetClipHrgn(graphics
, hrgn
, CombineModeReplace
);
1748 expect(ObjectBusy
, status
);
1749 status
= GdipSetClipPath(graphics
, path
, CombineModeReplace
);
1750 expect(ObjectBusy
, status
);
1751 status
= GdipSetClipRect(graphics
, 0.0, 0.0, 10.0, 10.0, CombineModeReplace
);
1752 expect(ObjectBusy
, status
);
1753 status
= GdipSetClipRectI(graphics
, 0, 0, 10, 10, CombineModeReplace
);
1754 expect(ObjectBusy
, status
);
1755 status
= GdipSetClipRegion(graphics
, clip
, CombineModeReplace
);
1756 expect(ObjectBusy
, status
);
1757 status
= GdipTranslateClip(graphics
, 0.0, 0.0);
1758 expect(ObjectBusy
, status
);
1759 status
= GdipTranslateClipI(graphics
, 0, 0);
1760 expect(ObjectBusy
, status
);
1761 status
= GdipDrawPolygon(graphics
, pen
, ptf
, 5);
1762 expect(ObjectBusy
, status
);
1763 status
= GdipDrawPolygonI(graphics
, pen
, pt
, 5);
1764 expect(ObjectBusy
, status
);
1765 status
= GdipGetDpiX(graphics
, &r
);
1766 expect(ObjectBusy
, status
);
1767 status
= GdipGetDpiY(graphics
, &r
);
1768 expect(ObjectBusy
, status
);
1769 status
= GdipMultiplyWorldTransform(graphics
, m
, MatrixOrderPrepend
);
1770 expect(ObjectBusy
, status
);
1771 status
= GdipGetClip(graphics
, region
);
1772 expect(ObjectBusy
, status
);
1773 status
= GdipTransformPoints(graphics
, CoordinateSpacePage
, CoordinateSpaceWorld
, ptf
, 5);
1774 expect(ObjectBusy
, status
);
1776 /* try to delete before release */
1777 status
= GdipDeleteGraphics(graphics
);
1778 expect(ObjectBusy
, status
);
1780 status
= GdipReleaseDC(graphics
, retdc
);
1784 GdipDeleteGraphics(graphics
);
1786 GdipDeleteRegion(clip
);
1787 GdipDeletePath(path
);
1788 GdipDeleteBrush((GpBrush
*)brush
);
1789 GdipDeleteRegion(region
);
1790 GdipDeleteMatrix(m
);
1793 ReleaseDC(hwnd
, hdc
);
1796 static void test_transformpoints(void)
1799 GpGraphics
*graphics
= NULL
;
1800 HDC hdc
= GetDC( hwnd
);
1804 status
= GdipCreateFromHDC(hdc
, &graphics
);
1807 /* NULL arguments */
1808 status
= GdipTransformPoints(NULL
, CoordinateSpacePage
, CoordinateSpaceWorld
, NULL
, 0);
1809 expect(InvalidParameter
, status
);
1810 status
= GdipTransformPoints(graphics
, CoordinateSpacePage
, CoordinateSpaceWorld
, NULL
, 0);
1811 expect(InvalidParameter
, status
);
1812 status
= GdipTransformPoints(graphics
, CoordinateSpacePage
, CoordinateSpaceWorld
, ptf
, 0);
1813 expect(InvalidParameter
, status
);
1814 status
= GdipTransformPoints(graphics
, CoordinateSpacePage
, CoordinateSpaceWorld
, ptf
, -1);
1815 expect(InvalidParameter
, status
);
1821 status
= GdipTransformPoints(graphics
, CoordinateSpaceDevice
, CoordinateSpaceWorld
, ptf
, 2);
1823 expectf(1.0, ptf
[0].X
);
1824 expectf(0.0, ptf
[0].Y
);
1825 expectf(0.0, ptf
[1].X
);
1826 expectf(1.0, ptf
[1].Y
);
1828 status
= GdipTranslateWorldTransform(graphics
, 5.0, 5.0, MatrixOrderAppend
);
1830 status
= GdipSetPageUnit(graphics
, UnitPixel
);
1832 status
= GdipSetPageScale(graphics
, 3.0);
1839 status
= GdipTransformPoints(graphics
, CoordinateSpaceDevice
, CoordinateSpaceWorld
, ptf
, 2);
1841 expectf(18.0, ptf
[0].X
);
1842 expectf(15.0, ptf
[0].Y
);
1843 expectf(15.0, ptf
[1].X
);
1844 expectf(18.0, ptf
[1].Y
);
1850 status
= GdipTransformPoints(graphics
, CoordinateSpacePage
, CoordinateSpaceWorld
, ptf
, 2);
1852 expectf(6.0, ptf
[0].X
);
1853 expectf(5.0, ptf
[0].Y
);
1854 expectf(5.0, ptf
[1].X
);
1855 expectf(6.0, ptf
[1].Y
);
1861 status
= GdipTransformPoints(graphics
, CoordinateSpaceDevice
, CoordinateSpacePage
, ptf
, 2);
1863 expectf(3.0, ptf
[0].X
);
1864 expectf(0.0, ptf
[0].Y
);
1865 expectf(0.0, ptf
[1].X
);
1866 expectf(3.0, ptf
[1].Y
);
1872 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
1874 expectf(1.0, ptf
[0].X
);
1875 expectf(0.0, ptf
[0].Y
);
1876 expectf(0.0, ptf
[1].X
);
1877 expectf(1.0, ptf
[1].Y
);
1883 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpacePage
, ptf
, 2);
1885 expectf(1.0, ptf
[0].X
);
1886 expectf(0.0, ptf
[0].Y
);
1887 expectf(0.0, ptf
[1].X
);
1888 expectf(1.0, ptf
[1].Y
);
1894 status
= GdipTransformPoints(graphics
, CoordinateSpacePage
, CoordinateSpaceDevice
, ptf
, 2);
1896 expectf(1.0, ptf
[0].X
);
1897 expectf(0.0, ptf
[0].Y
);
1898 expectf(0.0, ptf
[1].X
);
1899 expectf(1.0, ptf
[1].Y
);
1905 status
= GdipTransformPointsI(graphics
, CoordinateSpaceDevice
, CoordinateSpaceWorld
, pt
, 2);
1907 expect(18, pt
[0].X
);
1908 expect(15, pt
[0].Y
);
1909 expect(15, pt
[1].X
);
1910 expect(18, pt
[1].Y
);
1912 GdipDeleteGraphics(graphics
);
1913 ReleaseDC(hwnd
, hdc
);
1916 static void test_get_set_clip(void)
1919 GpGraphics
*graphics
= NULL
;
1920 HDC hdc
= GetDC( hwnd
);
1925 status
= GdipCreateFromHDC(hdc
, &graphics
);
1928 rect
.X
= rect
.Y
= 0.0;
1929 rect
.Height
= rect
.Width
= 100.0;
1931 status
= GdipCreateRegionRect(&rect
, &clip
);
1934 /* NULL arguments */
1935 status
= GdipGetClip(NULL
, NULL
);
1936 expect(InvalidParameter
, status
);
1937 status
= GdipGetClip(graphics
, NULL
);
1938 expect(InvalidParameter
, status
);
1939 status
= GdipGetClip(NULL
, clip
);
1940 expect(InvalidParameter
, status
);
1942 status
= GdipSetClipRegion(NULL
, NULL
, CombineModeReplace
);
1943 expect(InvalidParameter
, status
);
1944 status
= GdipSetClipRegion(graphics
, NULL
, CombineModeReplace
);
1945 expect(InvalidParameter
, status
);
1947 status
= GdipSetClipPath(NULL
, NULL
, CombineModeReplace
);
1948 expect(InvalidParameter
, status
);
1949 status
= GdipSetClipPath(graphics
, NULL
, CombineModeReplace
);
1950 expect(InvalidParameter
, status
);
1953 status
= GdipGetClip(graphics
, clip
);
1955 status
= GdipIsInfiniteRegion(clip
, graphics
, &res
);
1959 /* remains infinite after reset */
1961 status
= GdipResetClip(graphics
);
1963 status
= GdipGetClip(graphics
, clip
);
1965 status
= GdipIsInfiniteRegion(clip
, graphics
, &res
);
1969 /* set to empty and then reset to infinite */
1970 status
= GdipSetEmpty(clip
);
1972 status
= GdipSetClipRegion(graphics
, clip
, CombineModeReplace
);
1975 status
= GdipGetClip(graphics
, clip
);
1978 status
= GdipIsEmptyRegion(clip
, graphics
, &res
);
1981 status
= GdipResetClip(graphics
);
1983 status
= GdipGetClip(graphics
, clip
);
1986 status
= GdipIsInfiniteRegion(clip
, graphics
, &res
);
1990 GdipDeleteRegion(clip
);
1992 GdipDeleteGraphics(graphics
);
1993 ReleaseDC(hwnd
, hdc
);
1996 static void test_isempty(void)
1999 GpGraphics
*graphics
= NULL
;
2000 HDC hdc
= GetDC( hwnd
);
2004 status
= GdipCreateFromHDC(hdc
, &graphics
);
2007 status
= GdipCreateRegion(&clip
);
2011 status
= GdipIsClipEmpty(NULL
, NULL
);
2012 expect(InvalidParameter
, status
);
2013 status
= GdipIsClipEmpty(graphics
, NULL
);
2014 expect(InvalidParameter
, status
);
2015 status
= GdipIsClipEmpty(NULL
, &res
);
2016 expect(InvalidParameter
, status
);
2018 /* default is infinite */
2020 status
= GdipIsClipEmpty(graphics
, &res
);
2024 GdipDeleteRegion(clip
);
2026 GdipDeleteGraphics(graphics
);
2027 ReleaseDC(hwnd
, hdc
);
2030 static void test_clear(void)
2034 status
= GdipGraphicsClear(NULL
, 0xdeadbeef);
2035 expect(InvalidParameter
, status
);
2038 static void test_textcontrast(void)
2041 HDC hdc
= GetDC( hwnd
);
2042 GpGraphics
*graphics
;
2045 status
= GdipGetTextContrast(NULL
, NULL
);
2046 expect(InvalidParameter
, status
);
2048 status
= GdipCreateFromHDC(hdc
, &graphics
);
2051 status
= GdipGetTextContrast(graphics
, NULL
);
2052 expect(InvalidParameter
, status
);
2053 status
= GdipGetTextContrast(graphics
, &contrast
);
2055 expect(4, contrast
);
2057 GdipDeleteGraphics(graphics
);
2058 ReleaseDC(hwnd
, hdc
);
2061 static void test_GdipDrawString(void)
2064 GpGraphics
*graphics
= NULL
;
2067 GpStringFormat
*format
;
2070 HDC hdc
= GetDC( hwnd
);
2071 static const WCHAR string
[] = {'T','e','s','t',0};
2072 static const PointF positions
[4] = {{0,0}, {1,1}, {2,2}, {3,3}};
2075 memset(&logfont
,0,sizeof(logfont
));
2076 strcpy(logfont
.lfFaceName
,"Arial");
2077 logfont
.lfHeight
= 12;
2078 logfont
.lfCharSet
= DEFAULT_CHARSET
;
2080 status
= GdipCreateFromHDC(hdc
, &graphics
);
2083 status
= GdipCreateFontFromLogfontA(hdc
, &logfont
, &fnt
);
2084 if (status
== NotTrueTypeFont
|| status
== FileNotFound
)
2086 skip("Arial not installed.\n");
2091 status
= GdipCreateSolidFill((ARGB
)0xdeadbeef, (GpSolidFill
**)&brush
);
2094 status
= GdipCreateStringFormat(0,0,&format
);
2102 status
= GdipDrawString(graphics
, string
, 4, fnt
, &rect
, format
, brush
);
2105 status
= GdipCreateMatrix(&matrix
);
2108 status
= GdipDrawDriverString(NULL
, string
, 4, fnt
, brush
, positions
, DriverStringOptionsCmapLookup
, matrix
);
2109 expect(InvalidParameter
, status
);
2111 status
= GdipDrawDriverString(graphics
, NULL
, 4, fnt
, brush
, positions
, DriverStringOptionsCmapLookup
, matrix
);
2112 expect(InvalidParameter
, status
);
2114 status
= GdipDrawDriverString(graphics
, string
, 4, NULL
, brush
, positions
, DriverStringOptionsCmapLookup
, matrix
);
2115 expect(InvalidParameter
, status
);
2117 status
= GdipDrawDriverString(graphics
, string
, 4, fnt
, NULL
, positions
, DriverStringOptionsCmapLookup
, matrix
);
2118 expect(InvalidParameter
, status
);
2120 status
= GdipDrawDriverString(graphics
, string
, 4, fnt
, brush
, NULL
, DriverStringOptionsCmapLookup
, matrix
);
2121 expect(InvalidParameter
, status
);
2123 status
= GdipDrawDriverString(graphics
, string
, 4, fnt
, brush
, positions
, DriverStringOptionsCmapLookup
|0x10, matrix
);
2126 status
= GdipDrawDriverString(graphics
, string
, 4, fnt
, brush
, positions
, DriverStringOptionsCmapLookup
, NULL
);
2129 status
= GdipDrawDriverString(graphics
, string
, 4, fnt
, brush
, positions
, DriverStringOptionsCmapLookup
, matrix
);
2132 GdipDeleteMatrix(matrix
);
2133 GdipDeleteGraphics(graphics
);
2134 GdipDeleteBrush(brush
);
2135 GdipDeleteFont(fnt
);
2136 GdipDeleteStringFormat(format
);
2138 ReleaseDC(hwnd
, hdc
);
2141 static void test_GdipGetVisibleClipBounds_screen(void)
2144 GpGraphics
*graphics
= NULL
;
2146 GpRectF rectf
, exp
, clipr
;
2149 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
2151 status
= GdipCreateFromHDC(hdc
, &graphics
);
2153 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
2155 /* no clipping rect */
2158 exp
.Width
= GetDeviceCaps(hdc
, HORZRES
);
2159 exp
.Height
= GetDeviceCaps(hdc
, VERTRES
);
2161 status
= GdipGetVisibleClipBounds(graphics
, &rectf
);
2163 ok(rectf
.X
== exp
.X
&&
2165 rectf
.Width
== exp
.Width
&&
2166 rectf
.Height
== exp
.Height
,
2167 "Expected clip bounds (%0.f, %0.f, %0.f, %0.f) to be the size of "
2168 "the screen (%0.f, %0.f, %0.f, %0.f)\n",
2169 rectf
.X
, rectf
.Y
, rectf
.Width
, rectf
.Height
,
2170 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2172 /* clipping rect entirely within window */
2173 exp
.X
= clipr
.X
= 10;
2174 exp
.Y
= clipr
.Y
= 12;
2175 exp
.Width
= clipr
.Width
= 14;
2176 exp
.Height
= clipr
.Height
= 16;
2178 status
= GdipSetClipRect(graphics
, clipr
.X
, clipr
.Y
, clipr
.Width
, clipr
.Height
, CombineModeReplace
);
2181 status
= GdipGetVisibleClipBounds(graphics
, &rectf
);
2183 ok(rectf
.X
== exp
.X
&&
2185 rectf
.Width
== exp
.Width
&&
2186 rectf
.Height
== exp
.Height
,
2187 "Expected clip bounds (%0.f, %0.f, %0.f, %0.f) to be the size of "
2188 "the clipping rect (%0.f, %0.f, %0.f, %0.f)\n",
2189 rectf
.X
, rectf
.Y
, rectf
.Width
, rectf
.Height
,
2190 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2192 /* clipping rect partially outside of screen */
2198 status
= GdipSetClipRect(graphics
, clipr
.X
, clipr
.Y
, clipr
.Width
, clipr
.Height
, CombineModeReplace
);
2206 status
= GdipGetVisibleClipBounds(graphics
, &rectf
);
2208 ok(rectf
.X
== exp
.X
&&
2210 rectf
.Width
== exp
.Width
&&
2211 rectf
.Height
== exp
.Height
,
2212 "Expected clip bounds (%0.f, %0.f, %0.f, %0.f) to be the size of "
2213 "the visible clipping rect (%0.f, %0.f, %0.f, %0.f)\n",
2214 rectf
.X
, rectf
.Y
, rectf
.Width
, rectf
.Height
,
2215 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2217 status
= GdipGetVisibleClipBoundsI(graphics
, &recti
);
2219 ok(recti
.X
== exp
.X
&&
2221 recti
.Width
== exp
.Width
&&
2222 recti
.Height
== exp
.Height
,
2223 "Expected clip bounds (%d, %d, %d, %d) to be the size of "
2224 "the visible clipping rect (%0.f, %0.f, %0.f, %0.f)\n",
2225 recti
.X
, recti
.Y
, recti
.Width
, recti
.Height
,
2226 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2228 GdipDeleteGraphics(graphics
);
2232 static void test_GdipGetVisibleClipBounds_window(void)
2235 GpGraphics
*graphics
= NULL
;
2236 GpRectF rectf
, window
, exp
, clipr
;
2242 /* get client area size */
2243 ok(GetClientRect(hwnd
, &wnd_rect
), "GetClientRect should have succeeded\n");
2244 window
.X
= wnd_rect
.left
;
2245 window
.Y
= wnd_rect
.top
;
2246 window
.Width
= wnd_rect
.right
- wnd_rect
.left
;
2247 window
.Height
= wnd_rect
.bottom
- wnd_rect
.top
;
2249 hdc
= BeginPaint(hwnd
, &ps
);
2251 status
= GdipCreateFromHDC(hdc
, &graphics
);
2253 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
2255 status
= GdipGetVisibleClipBounds(graphics
, &rectf
);
2257 ok(rectf
.X
== window
.X
&&
2258 rectf
.Y
== window
.Y
&&
2259 rectf
.Width
== window
.Width
&&
2260 rectf
.Height
== window
.Height
,
2261 "Expected clip bounds (%0.f, %0.f, %0.f, %0.f) to be the size of "
2262 "the window (%0.f, %0.f, %0.f, %0.f)\n",
2263 rectf
.X
, rectf
.Y
, rectf
.Width
, rectf
.Height
,
2264 window
.X
, window
.Y
, window
.Width
, window
.Height
);
2266 /* clipping rect entirely within window */
2267 exp
.X
= clipr
.X
= 20;
2268 exp
.Y
= clipr
.Y
= 8;
2269 exp
.Width
= clipr
.Width
= 30;
2270 exp
.Height
= clipr
.Height
= 20;
2272 status
= GdipSetClipRect(graphics
, clipr
.X
, clipr
.Y
, clipr
.Width
, clipr
.Height
, CombineModeReplace
);
2275 status
= GdipGetVisibleClipBounds(graphics
, &rectf
);
2277 ok(rectf
.X
== exp
.X
&&
2279 rectf
.Width
== exp
.Width
&&
2280 rectf
.Height
== exp
.Height
,
2281 "Expected clip bounds (%0.f, %0.f, %0.f, %0.f) to be the size of "
2282 "the clipping rect (%0.f, %0.f, %0.f, %0.f)\n",
2283 rectf
.X
, rectf
.Y
, rectf
.Width
, rectf
.Height
,
2284 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2286 /* clipping rect partially outside of window */
2287 clipr
.X
= window
.Width
- 10;
2288 clipr
.Y
= window
.Height
- 15;
2292 status
= GdipSetClipRect(graphics
, clipr
.X
, clipr
.Y
, clipr
.Width
, clipr
.Height
, CombineModeReplace
);
2295 exp
.X
= window
.Width
- 10;
2296 exp
.Y
= window
.Height
- 15;
2300 status
= GdipGetVisibleClipBounds(graphics
, &rectf
);
2302 ok(rectf
.X
== exp
.X
&&
2304 rectf
.Width
== exp
.Width
&&
2305 rectf
.Height
== exp
.Height
,
2306 "Expected clip bounds (%0.f, %0.f, %0.f, %0.f) to be the size of "
2307 "the visible clipping rect (%0.f, %0.f, %0.f, %0.f)\n",
2308 rectf
.X
, rectf
.Y
, rectf
.Width
, rectf
.Height
,
2309 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2311 status
= GdipGetVisibleClipBoundsI(graphics
, &recti
);
2313 ok(recti
.X
== exp
.X
&&
2315 recti
.Width
== exp
.Width
&&
2316 recti
.Height
== exp
.Height
,
2317 "Expected clip bounds (%d, %d, %d, %d) to be the size of "
2318 "the visible clipping rect (%0.f, %0.f, %0.f, %0.f)\n",
2319 recti
.X
, recti
.Y
, recti
.Width
, recti
.Height
,
2320 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2322 /* window bounds with transform applied */
2323 status
= GdipResetClip(graphics
);
2326 status
= GdipScaleWorldTransform(graphics
, 0.5, 0.5, MatrixOrderPrepend
);
2329 exp
.X
= window
.X
* 2.0;
2330 exp
.Y
= window
.Y
* 2.0;
2331 exp
.Width
= window
.Width
* 2.0;
2332 exp
.Height
= window
.Height
* 2.0;
2334 status
= GdipGetVisibleClipBounds(graphics
, &rectf
);
2336 ok(rectf
.X
== exp
.X
&&
2338 rectf
.Width
== exp
.Width
&&
2339 rectf
.Height
== exp
.Height
,
2340 "Expected clip bounds (%0.f, %0.f, %0.f, %0.f) to be "
2341 "twice the window size (%0.f, %0.f, %0.f, %0.f)\n",
2342 rectf
.X
, rectf
.Y
, rectf
.Width
, rectf
.Height
,
2343 exp
.X
, exp
.Y
, exp
.Width
, exp
.Height
);
2345 GdipDeleteGraphics(graphics
);
2346 EndPaint(hwnd
, &ps
);
2349 static void test_GdipGetVisibleClipBounds(void)
2351 GpGraphics
* graphics
= NULL
;
2354 HDC hdc
= GetDC( hwnd
);
2357 status
= GdipCreateFromHDC(hdc
, &graphics
);
2359 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
2361 /* test null parameters */
2362 status
= GdipGetVisibleClipBounds(graphics
, NULL
);
2363 expect(InvalidParameter
, status
);
2365 status
= GdipGetVisibleClipBounds(NULL
, &rectf
);
2366 expect(InvalidParameter
, status
);
2368 status
= GdipGetVisibleClipBoundsI(graphics
, NULL
);
2369 expect(InvalidParameter
, status
);
2371 status
= GdipGetVisibleClipBoundsI(NULL
, &rect
);
2372 expect(InvalidParameter
, status
);
2374 GdipDeleteGraphics(graphics
);
2375 ReleaseDC(hwnd
, hdc
);
2377 test_GdipGetVisibleClipBounds_screen();
2378 test_GdipGetVisibleClipBounds_window();
2381 static void test_fromMemoryBitmap(void)
2384 GpGraphics
*graphics
= NULL
;
2385 GpBitmap
*bitmap
= NULL
;
2386 BYTE bits
[48] = {0};
2390 status
= GdipCreateBitmapFromScan0(4, 4, 12, PixelFormat24bppRGB
, bits
, &bitmap
);
2393 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2396 status
= GdipGraphicsClear(graphics
, 0xff686868);
2399 GdipDeleteGraphics(graphics
);
2401 /* drawing writes to the memory provided */
2402 expect(0x68, bits
[10]);
2404 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2407 status
= GdipGetDC(graphics
, &hdc
);
2409 ok(hdc
!= NULL
, "got NULL hdc\n");
2411 color
= GetPixel(hdc
, 0, 0);
2412 /* The HDC is write-only, and native fills with a solid color to figure out
2413 * which pixels have changed. */
2414 todo_wine
expect(0x0c0b0d, color
);
2416 SetPixel(hdc
, 0, 0, 0x797979);
2417 SetPixel(hdc
, 1, 0, 0x0c0b0d);
2419 status
= GdipReleaseDC(graphics
, hdc
);
2422 GdipDeleteGraphics(graphics
);
2424 expect(0x79, bits
[0]);
2425 todo_wine
expect(0x68, bits
[3]);
2427 GdipDisposeImage((GpImage
*)bitmap
);
2429 /* We get the same kind of write-only HDC for a "normal" bitmap */
2430 status
= GdipCreateBitmapFromScan0(4, 4, 12, PixelFormat24bppRGB
, NULL
, &bitmap
);
2433 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2436 status
= GdipGetDC(graphics
, &hdc
);
2438 ok(hdc
!= NULL
, "got NULL hdc\n");
2440 color
= GetPixel(hdc
, 0, 0);
2441 todo_wine
expect(0x0c0b0d, color
);
2443 status
= GdipReleaseDC(graphics
, hdc
);
2446 GdipDeleteGraphics(graphics
);
2448 GdipDisposeImage((GpImage
*)bitmap
);
2450 /* If we don't draw to the HDC, the bits are never accessed */
2451 status
= GdipCreateBitmapFromScan0(4, 4, 12, PixelFormat24bppRGB
, (BYTE
*)1, &bitmap
);
2454 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2457 status
= GdipGetDC(graphics
, &hdc
);
2459 ok(hdc
!= NULL
, "got NULL hdc\n");
2461 color
= GetPixel(hdc
, 0, 0);
2462 todo_wine
expect(0x0c0b0d, color
);
2464 status
= GdipReleaseDC(graphics
, hdc
);
2467 GdipDeleteGraphics(graphics
);
2469 GdipDisposeImage((GpImage
*)bitmap
);
2472 static void test_GdipIsVisiblePoint(void)
2475 GpGraphics
*graphics
= NULL
;
2476 HDC hdc
= GetDC( hwnd
);
2480 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
2482 status
= GdipCreateFromHDC(hdc
, &graphics
);
2484 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
2486 /* null parameters */
2487 status
= GdipIsVisiblePoint(NULL
, 0, 0, &val
);
2488 expect(InvalidParameter
, status
);
2490 status
= GdipIsVisiblePoint(graphics
, 0, 0, NULL
);
2491 expect(InvalidParameter
, status
);
2493 status
= GdipIsVisiblePointI(NULL
, 0, 0, &val
);
2494 expect(InvalidParameter
, status
);
2496 status
= GdipIsVisiblePointI(graphics
, 0, 0, NULL
);
2497 expect(InvalidParameter
, status
);
2501 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2503 ok(val
== TRUE
, "Expected (%.2f, %.2f) to be visible\n", x
, y
);
2507 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2509 ok(val
== FALSE
, "Expected (%.2f, %.2f) not to be visible\n", x
, y
);
2513 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2515 ok(val
== FALSE
, "Expected (%.2f, %.2f) not to be visible\n", x
, y
);
2519 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2521 ok(val
== TRUE
, "Expected (%.2f, %.2f) to be visible\n", x
, y
);
2523 status
= GdipSetClipRect(graphics
, 10, 20, 30, 40, CombineModeReplace
);
2528 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2530 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2534 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2536 ok(val
== TRUE
, "After clipping, expected (%.2f, %.2f) to be visible\n", x
, y
);
2538 /* translate into the center of the rect */
2539 GdipTranslateWorldTransform(graphics
, 25, 40, MatrixOrderAppend
);
2543 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2545 ok(val
== TRUE
, "Expected (%.2f, %.2f) to be visible\n", x
, y
);
2549 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2551 ok(val
== FALSE
, "Expected (%.2f, %.2f) not to be visible\n", x
, y
);
2553 GdipTranslateWorldTransform(graphics
, -25, -40, MatrixOrderAppend
);
2558 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2560 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2564 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2566 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2570 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2572 ok(val
== TRUE
, "After clipping, expected (%.2f, %.2f) to be visible\n", x
, y
);
2576 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2578 ok(val
== TRUE
, "After clipping, expected (%.2f, %.2f) to be visible\n", x
, y
);
2582 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2584 ok(val
== TRUE
, "After clipping, expected (%.2f, %.2f) to be visible\n", x
, y
);
2588 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2590 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2594 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2596 ok(val
== TRUE
, "After clipping, expected (%.2f, %.2f) to be visible\n", x
, y
);
2600 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2602 ok(val
== TRUE
, "After clipping, expected (%.2f, %.2f) to be visible\n", x
, y
);
2606 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2608 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2612 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2614 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2618 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2620 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2624 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2626 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2630 status
= GdipIsVisiblePoint(graphics
, x
, y
, &val
);
2632 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2634 /* integer version */
2637 status
= GdipIsVisiblePointI(graphics
, (INT
)x
, (INT
)y
, &val
);
2639 ok(val
== TRUE
, "After clipping, expected (%.2f, %.2f) to be visible\n", x
, y
);
2643 status
= GdipIsVisiblePointI(graphics
, (INT
)x
, (INT
)y
, &val
);
2645 ok(val
== FALSE
, "After clipping, expected (%.2f, %.2f) not to be visible\n", x
, y
);
2647 GdipDeleteGraphics(graphics
);
2648 ReleaseDC(hwnd
, hdc
);
2651 static void test_GdipIsVisibleRect(void)
2654 GpGraphics
*graphics
= NULL
;
2655 HDC hdc
= GetDC( hwnd
);
2656 REAL x
, y
, width
, height
;
2659 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
2661 status
= GdipCreateFromHDC(hdc
, &graphics
);
2663 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
2665 status
= GdipIsVisibleRect(NULL
, 0, 0, 0, 0, &val
);
2666 expect(InvalidParameter
, status
);
2668 status
= GdipIsVisibleRect(graphics
, 0, 0, 0, 0, NULL
);
2669 expect(InvalidParameter
, status
);
2671 status
= GdipIsVisibleRectI(NULL
, 0, 0, 0, 0, &val
);
2672 expect(InvalidParameter
, status
);
2674 status
= GdipIsVisibleRectI(graphics
, 0, 0, 0, 0, NULL
);
2675 expect(InvalidParameter
, status
);
2677 /* entirely within the visible region */
2680 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2682 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2684 /* partially outside */
2685 x
= -10; width
= 20;
2686 y
= -10; height
= 20;
2687 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2689 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2691 /* entirely outside */
2693 y
= -10; height
= 5;
2694 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2696 ok(val
== FALSE
, "Expected (%.2f, %.2f, %.2f, %.2f) not to be visible\n", x
, y
, width
, height
);
2698 status
= GdipSetClipRect(graphics
, 10, 20, 30, 40, CombineModeReplace
);
2701 /* entirely within the visible region */
2703 y
= 22; height
= 10;
2704 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2706 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2708 /* partially outside */
2710 y
= 55; height
= 10;
2711 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2713 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2715 /* entirely outside */
2718 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2720 ok(val
== FALSE
, "Expected (%.2f, %.2f, %.2f, %.2f) not to be visible\n", x
, y
, width
, height
);
2722 /* translate into center of clipping rect */
2723 GdipTranslateWorldTransform(graphics
, 25, 40, MatrixOrderAppend
);
2727 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2729 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2733 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2735 ok(val
== FALSE
, "Expected (%.2f, %.2f, %.2f, %.2f) not to be visible\n", x
, y
, width
, height
);
2737 GdipTranslateWorldTransform(graphics
, -25, -40, MatrixOrderAppend
);
2739 /* corners entirely outside, but some intersections */
2742 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2744 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2748 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2750 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2754 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2756 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2760 y
= 20; height
= 40;
2761 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2763 ok(val
== FALSE
, "Expected (%.2f, %.2f, %.2f, %.2f) not to be visible\n", x
, y
, width
, height
);
2767 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2769 ok(val
== FALSE
, "Expected (%.2f, %.2f, %.2f, %.2f) not to be visible\n", x
, y
, width
, height
);
2772 y
= 20; height
= 40;
2773 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2775 ok(val
== FALSE
, "Expected (%.2f, %.2f, %.2f, %.2f) not to be visible\n", x
, y
, width
, height
);
2778 y
= 60; height
= 10;
2779 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2781 ok(val
== FALSE
, "Expected (%.2f, %.2f, %.2f, %.2f) not to be visible\n", x
, y
, width
, height
);
2783 /* rounding tests */
2784 x
= 0.4; width
= 10.4;
2785 y
= 20; height
= 40;
2786 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2788 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2791 y
= 0.4; height
= 20.4;
2792 status
= GdipIsVisibleRect(graphics
, x
, y
, width
, height
, &val
);
2794 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2796 /* integer version */
2799 status
= GdipIsVisibleRectI(graphics
, (INT
)x
, (INT
)y
, (INT
)width
, (INT
)height
, &val
);
2801 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2804 y
= 22; height
= 10;
2805 status
= GdipIsVisibleRectI(graphics
, (INT
)x
, (INT
)y
, (INT
)width
, (INT
)height
, &val
);
2807 ok(val
== TRUE
, "Expected (%.2f, %.2f, %.2f, %.2f) to be visible\n", x
, y
, width
, height
);
2809 GdipDeleteGraphics(graphics
);
2810 ReleaseDC(hwnd
, hdc
);
2813 static void test_GdipGetNearestColor(void)
2816 GpGraphics
*graphics
;
2818 ARGB color
= 0xdeadbeef;
2819 HDC hdc
= GetDC( hwnd
);
2821 /* create a graphics object */
2822 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
2824 status
= GdipCreateFromHDC(hdc
, &graphics
);
2826 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
2828 status
= GdipGetNearestColor(graphics
, NULL
);
2829 expect(InvalidParameter
, status
);
2831 status
= GdipGetNearestColor(NULL
, &color
);
2832 expect(InvalidParameter
, status
);
2833 GdipDeleteGraphics(graphics
);
2835 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat1bppIndexed
, NULL
, &bitmap
);
2837 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2838 ok(broken(status
== OutOfMemory
) /* winver < Win7 */ || status
== Ok
, "status=%u\n", status
);
2841 status
= GdipGetNearestColor(graphics
, &color
);
2843 expect(0xdeadbeef, color
);
2844 GdipDeleteGraphics(graphics
);
2846 GdipDisposeImage((GpImage
*)bitmap
);
2848 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat4bppIndexed
, NULL
, &bitmap
);
2850 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2851 ok(broken(status
== OutOfMemory
) /* winver < Win7 */ || status
== Ok
, "status=%u\n", status
);
2854 status
= GdipGetNearestColor(graphics
, &color
);
2856 expect(0xdeadbeef, color
);
2857 GdipDeleteGraphics(graphics
);
2859 GdipDisposeImage((GpImage
*)bitmap
);
2861 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat8bppIndexed
, NULL
, &bitmap
);
2863 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2864 ok(broken(status
== OutOfMemory
) /* winver < Win7 */ || status
== Ok
, "status=%u\n", status
);
2867 status
= GdipGetNearestColor(graphics
, &color
);
2869 expect(0xdeadbeef, color
);
2870 GdipDeleteGraphics(graphics
);
2872 GdipDisposeImage((GpImage
*)bitmap
);
2874 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat16bppGrayScale
, NULL
, &bitmap
);
2876 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2877 todo_wine
expect(OutOfMemory
, status
);
2879 GdipDeleteGraphics(graphics
);
2880 GdipDisposeImage((GpImage
*)bitmap
);
2882 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat24bppRGB
, NULL
, &bitmap
);
2884 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2886 status
= GdipGetNearestColor(graphics
, &color
);
2888 expect(0xdeadbeef, color
);
2889 GdipDeleteGraphics(graphics
);
2890 GdipDisposeImage((GpImage
*)bitmap
);
2892 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat32bppRGB
, NULL
, &bitmap
);
2894 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2896 status
= GdipGetNearestColor(graphics
, &color
);
2898 expect(0xdeadbeef, color
);
2899 GdipDeleteGraphics(graphics
);
2900 GdipDisposeImage((GpImage
*)bitmap
);
2902 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat32bppARGB
, NULL
, &bitmap
);
2904 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2906 status
= GdipGetNearestColor(graphics
, &color
);
2908 expect(0xdeadbeef, color
);
2909 GdipDeleteGraphics(graphics
);
2910 GdipDisposeImage((GpImage
*)bitmap
);
2912 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat48bppRGB
, NULL
, &bitmap
);
2916 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2918 status
= GdipGetNearestColor(graphics
, &color
);
2920 expect(0xdeadbeef, color
);
2921 GdipDeleteGraphics(graphics
);
2922 GdipDisposeImage((GpImage
*)bitmap
);
2925 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat64bppARGB
, NULL
, &bitmap
);
2929 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2931 status
= GdipGetNearestColor(graphics
, &color
);
2933 expect(0xdeadbeef, color
);
2934 GdipDeleteGraphics(graphics
);
2935 GdipDisposeImage((GpImage
*)bitmap
);
2938 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat64bppPARGB
, NULL
, &bitmap
);
2942 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2944 status
= GdipGetNearestColor(graphics
, &color
);
2946 expect(0xdeadbeef, color
);
2947 GdipDeleteGraphics(graphics
);
2948 GdipDisposeImage((GpImage
*)bitmap
);
2951 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat16bppRGB565
, NULL
, &bitmap
);
2953 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2955 status
= GdipGetNearestColor(graphics
, &color
);
2957 todo_wine
expect(0xffa8bce8, color
);
2958 GdipDeleteGraphics(graphics
);
2959 GdipDisposeImage((GpImage
*)bitmap
);
2961 status
= GdipCreateBitmapFromScan0(10, 10, 10, PixelFormat16bppRGB555
, NULL
, &bitmap
);
2963 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
2965 status
= GdipGetNearestColor(graphics
, &color
);
2968 ok(color
== 0xffa8b8e8 ||
2969 broken(color
== 0xffa0b8e0), /* Win98/WinMe */
2970 "Expected ffa8b8e8, got %.8x\n", color
);
2971 GdipDeleteGraphics(graphics
);
2972 GdipDisposeImage((GpImage
*)bitmap
);
2974 ReleaseDC(hwnd
, hdc
);
2977 static void test_string_functions(void)
2980 GpGraphics
*graphics
;
2981 GpFontFamily
*family
;
2983 RectF rc
, char_bounds
, bounds
;
2985 ARGB color
= 0xff000000;
2986 HDC hdc
= GetDC( hwnd
);
2987 const WCHAR fontname
[] = {'T','a','h','o','m','a',0};
2988 const WCHAR teststring
[] = {'M','M',' ','M','\n','M',0};
2989 const WCHAR teststring2
[] = {'j',0};
2990 REAL char_width
, char_height
;
2991 INT codepointsfitted
, linesfilled
;
2992 GpStringFormat
*format
;
2993 CharacterRange ranges
[3] = {{0, 1}, {1, 3}, {5, 1}};
2994 GpRegion
*regions
[4];
2995 BOOL region_isempty
[4];
2997 PointF positions
[8];
3000 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
3001 status
= GdipCreateFromHDC(hdc
, &graphics
);
3003 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
3005 status
= GdipCreateFontFamilyFromName(fontname
, NULL
, &family
);
3008 status
= GdipCreateFont(family
, 10.0, FontStyleRegular
, UnitPixel
, &font
);
3011 status
= GdipCreateSolidFill(color
, (GpSolidFill
**)&brush
);
3014 status
= GdipCreateStringFormat(0, LANG_NEUTRAL
, &format
);
3022 status
= GdipDrawString(NULL
, teststring
, 6, font
, &rc
, NULL
, brush
);
3023 expect(InvalidParameter
, status
);
3025 status
= GdipDrawString(graphics
, NULL
, 6, font
, &rc
, NULL
, brush
);
3026 expect(InvalidParameter
, status
);
3028 status
= GdipDrawString(graphics
, teststring
, 6, NULL
, &rc
, NULL
, brush
);
3029 expect(InvalidParameter
, status
);
3031 status
= GdipDrawString(graphics
, teststring
, 6, font
, NULL
, NULL
, brush
);
3032 expect(InvalidParameter
, status
);
3034 status
= GdipDrawString(graphics
, teststring
, 6, font
, &rc
, NULL
, NULL
);
3035 expect(InvalidParameter
, status
);
3037 status
= GdipDrawString(graphics
, teststring
, 6, font
, &rc
, NULL
, brush
);
3040 status
= GdipMeasureString(NULL
, teststring
, 6, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3041 expect(InvalidParameter
, status
);
3043 status
= GdipMeasureString(graphics
, NULL
, 6, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3044 expect(InvalidParameter
, status
);
3046 status
= GdipMeasureString(graphics
, teststring
, 6, NULL
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3047 expect(InvalidParameter
, status
);
3049 status
= GdipMeasureString(graphics
, teststring
, 6, font
, NULL
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3050 expect(InvalidParameter
, status
);
3052 status
= GdipMeasureString(graphics
, teststring
, 6, font
, &rc
, NULL
, NULL
, &codepointsfitted
, &linesfilled
);
3053 expect(InvalidParameter
, status
);
3055 status
= GdipMeasureString(graphics
, teststring
, 6, font
, &rc
, NULL
, &bounds
, NULL
, &linesfilled
);
3058 status
= GdipMeasureString(graphics
, teststring
, 6, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, NULL
);
3061 status
= GdipMeasureString(graphics
, teststring
, 1, font
, &rc
, NULL
, &char_bounds
, &codepointsfitted
, &linesfilled
);
3063 expectf(0.0, char_bounds
.X
);
3064 expectf(0.0, char_bounds
.Y
);
3065 ok(char_bounds
.Width
> 0, "got %0.2f\n", bounds
.Width
);
3066 ok(char_bounds
.Height
> 0, "got %0.2f\n", bounds
.Height
);
3067 expect(1, codepointsfitted
);
3068 expect(1, linesfilled
);
3070 status
= GdipMeasureString(graphics
, teststring
, 2, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3072 expectf(0.0, bounds
.X
);
3073 expectf(0.0, bounds
.Y
);
3074 ok(bounds
.Width
> char_bounds
.Width
, "got %0.2f, expected at least %0.2f\n", bounds
.Width
, char_bounds
.Width
);
3075 expectf(char_bounds
.Height
, bounds
.Height
);
3076 expect(2, codepointsfitted
);
3077 expect(1, linesfilled
);
3078 char_width
= bounds
.Width
- char_bounds
.Width
;
3080 status
= GdipMeasureString(graphics
, teststring
, 6, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3082 expectf(0.0, bounds
.X
);
3083 expectf(0.0, bounds
.Y
);
3084 ok(bounds
.Width
> char_bounds
.Width
+ char_width
* 2, "got %0.2f, expected at least %0.2f\n",
3085 bounds
.Width
, char_bounds
.Width
+ char_width
* 2);
3086 ok(bounds
.Height
> char_bounds
.Height
, "got %0.2f, expected at least %0.2f\n", bounds
.Height
, char_bounds
.Height
);
3087 expect(6, codepointsfitted
);
3088 expect(2, linesfilled
);
3089 char_height
= bounds
.Height
- char_bounds
.Height
;
3091 /* Measure the first line. */
3092 status
= GdipMeasureString(graphics
, teststring
, 4, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3094 expectf(0.0, bounds
.X
);
3095 expectf(0.0, bounds
.Y
);
3096 expect(4, codepointsfitted
);
3097 expect(1, linesfilled
);
3099 /* Give just enough space to fit the first line. */
3100 rc
.Width
= bounds
.Width
;
3101 status
= GdipMeasureString(graphics
, teststring
, 5, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3103 expectf(0.0, bounds
.X
);
3104 expectf(0.0, bounds
.Y
);
3105 todo_wine
expect(5, codepointsfitted
);
3106 todo_wine
expect(1, linesfilled
);
3108 /* Cut off everything after the first space. */
3109 rc
.Width
= char_bounds
.Width
+ char_width
* 2.1;
3111 status
= GdipMeasureString(graphics
, teststring
, 6, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3113 expectf(0.0, bounds
.X
);
3114 expectf(0.0, bounds
.Y
);
3115 expectf_(char_bounds
.Width
+ char_width
, bounds
.Width
, 0.01);
3116 expectf_(char_bounds
.Height
+ char_height
* 2, bounds
.Height
, 0.01);
3117 expect(6, codepointsfitted
);
3118 expect(3, linesfilled
);
3120 /* Cut off everything including the first space. */
3121 rc
.Width
= char_bounds
.Width
+ char_width
* 1.7;
3123 status
= GdipMeasureString(graphics
, teststring
, 6, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3125 expectf(0.0, bounds
.X
);
3126 expectf(0.0, bounds
.Y
);
3127 expectf_(char_bounds
.Width
+ char_width
, bounds
.Width
, 0.01);
3128 expectf_(char_bounds
.Height
+ char_height
* 2, bounds
.Height
, 0.01);
3129 expect(6, codepointsfitted
);
3130 expect(3, linesfilled
);
3132 /* Cut off everything after the first character. */
3133 rc
.Width
= char_bounds
.Width
+ char_width
* 0.8;
3135 status
= GdipMeasureString(graphics
, teststring
, 6, font
, &rc
, NULL
, &bounds
, &codepointsfitted
, &linesfilled
);
3137 expectf(0.0, bounds
.X
);
3138 expectf(0.0, bounds
.Y
);
3139 expectf_(char_bounds
.Width
, bounds
.Width
, 0.01);
3140 expectf_(char_bounds
.Height
+ char_height
* 3, bounds
.Height
, 0.05);
3141 expect(6, codepointsfitted
);
3142 todo_wine
expect(4, linesfilled
);
3144 for (i
= 0; i
< 4; i
++)
3145 regions
[i
] = (GpRegion
*)0xdeadbeef;
3147 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, format
, 0, regions
);
3150 for (i
= 0; i
< 4; i
++)
3151 ok(regions
[i
] == (GpRegion
*)0xdeadbeef, "expected 0xdeadbeef, got %p\n", regions
[i
]);
3153 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, format
, 3, regions
);
3156 for (i
= 0; i
< 4; i
++)
3157 ok(regions
[i
] == (GpRegion
*)0xdeadbeef, "expected 0xdeadbeef, got %p\n", regions
[i
]);
3159 status
= GdipSetStringFormatMeasurableCharacterRanges(format
, 3, ranges
);
3162 set_rect_empty(&rc
);
3166 status
= GdipCreateRegion(®ions
[i
]);
3168 status
= GdipSetEmpty(regions
[i
]);
3172 status
= GdipMeasureCharacterRanges(NULL
, teststring
, 6, font
, &rc
, format
, 3, regions
);
3173 expect(InvalidParameter
, status
);
3175 status
= GdipMeasureCharacterRanges(graphics
, NULL
, 6, font
, &rc
, format
, 3, regions
);
3176 expect(InvalidParameter
, status
);
3178 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, NULL
, &rc
, format
, 3, regions
);
3179 expect(InvalidParameter
, status
);
3181 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, NULL
, format
, 3, regions
);
3182 expect(InvalidParameter
, status
);
3186 /* Crashes on Windows XP */
3187 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, NULL
, 3, regions
);
3188 expect(InvalidParameter
, status
);
3191 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, format
, 3, NULL
);
3192 expect(InvalidParameter
, status
);
3194 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, format
, 2, regions
);
3195 expect(InvalidParameter
, status
);
3197 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, format
, 3, regions
);
3200 for (i
= 0; i
< 4; i
++)
3202 status
= GdipIsEmptyRegion(regions
[i
], graphics
, ®ion_isempty
[i
]);
3206 ok(region_isempty
[0], "region should be empty\n");
3207 ok(region_isempty
[1], "region should be empty\n");
3208 ok(region_isempty
[2], "region should be empty\n");
3209 ok(region_isempty
[3], "region should be empty\n");
3214 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, format
, 4, regions
);
3219 status
= GdipIsEmptyRegion(regions
[i
], graphics
, ®ion_isempty
[i
]);
3223 ok(!region_isempty
[0], "region shouldn't be empty\n");
3224 ok(!region_isempty
[1], "region shouldn't be empty\n");
3225 ok(!region_isempty
[2], "region shouldn't be empty\n");
3226 ok(region_isempty
[3], "region should be empty\n");
3228 /* Cut off everything after the first space, and the second line. */
3229 rc
.Width
= char_bounds
.Width
+ char_width
* 2.1;
3230 rc
.Height
= char_bounds
.Height
+ char_height
* 0.5;
3232 status
= GdipMeasureCharacterRanges(graphics
, teststring
, 6, font
, &rc
, format
, 3, regions
);
3237 status
= GdipIsEmptyRegion(regions
[i
], graphics
, ®ion_isempty
[i
]);
3241 ok(!region_isempty
[0], "region shouldn't be empty\n");
3242 ok(!region_isempty
[1], "region shouldn't be empty\n");
3243 ok(region_isempty
[2], "region should be empty\n");
3244 ok(region_isempty
[3], "region should be empty\n");
3247 GdipDeleteRegion(regions
[i
]);
3249 status
= GdipCreateMatrix(&identity
);
3256 memset(positions
, 0, sizeof(positions
));
3257 status
= GdipMeasureDriverString(NULL
, teststring
, 6, font
, positions
,
3258 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3260 expect(InvalidParameter
, status
);
3262 status
= GdipMeasureDriverString(graphics
, NULL
, 6, font
, positions
,
3263 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3265 expect(InvalidParameter
, status
);
3267 status
= GdipMeasureDriverString(graphics
, teststring
, 6, NULL
, positions
,
3268 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3270 expect(InvalidParameter
, status
);
3272 status
= GdipMeasureDriverString(graphics
, teststring
, 6, font
, NULL
,
3273 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3275 expect(InvalidParameter
, status
);
3277 status
= GdipMeasureDriverString(graphics
, teststring
, 6, font
, positions
,
3278 0x100, identity
, &rc
);
3281 status
= GdipMeasureDriverString(graphics
, teststring
, 6, font
, positions
,
3282 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3286 status
= GdipMeasureDriverString(graphics
, teststring
, 6, font
, positions
,
3287 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3289 expect(InvalidParameter
, status
);
3295 status
= GdipMeasureDriverString(graphics
, teststring
, 6, font
, positions
,
3296 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3301 ok(rc
.Y
< 0.0, "unexpected Y %0.2f\n", rc
.Y
);
3302 ok(rc
.Width
> 0.0, "unexpected Width %0.2f\n", rc
.Width
);
3303 ok(rc
.Height
> 0.0, "unexpected Y %0.2f\n", rc
.Y
);
3305 char_width
= rc
.Width
;
3306 char_height
= rc
.Height
;
3312 status
= GdipMeasureDriverString(graphics
, teststring
, 4, font
, positions
,
3313 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3318 ok(rc
.Y
< 0.0, "unexpected Y %0.2f\n", rc
.Y
);
3319 ok(rc
.Width
< char_width
, "got Width %0.2f, expecting less than %0.2f\n", rc
.Width
, char_width
);
3320 expectf(char_height
, rc
.Height
);
3326 status
= GdipMeasureDriverString(graphics
, teststring2
, 1, font
, positions
,
3327 DriverStringOptionsCmapLookup
|DriverStringOptionsRealizedAdvance
,
3332 ok(rc
.Y
< 0.0, "unexpected Y %0.2f\n", rc
.Y
);
3333 ok(rc
.Width
> 0, "unexpected Width %0.2f\n", rc
.Width
);
3334 expectf(rc
.Height
, char_height
);
3336 GdipDeleteMatrix(identity
);
3337 GdipDeleteStringFormat(format
);
3338 GdipDeleteBrush(brush
);
3339 GdipDeleteFont(font
);
3340 GdipDeleteFontFamily(family
);
3341 GdipDeleteGraphics(graphics
);
3343 ReleaseDC(hwnd
, hdc
);
3346 static void test_get_set_interpolation(void)
3348 GpGraphics
*graphics
;
3349 HDC hdc
= GetDC( hwnd
);
3351 InterpolationMode mode
;
3353 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
3354 status
= GdipCreateFromHDC(hdc
, &graphics
);
3356 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
3358 status
= GdipGetInterpolationMode(NULL
, &mode
);
3359 expect(InvalidParameter
, status
);
3363 /* Crashes on Windows XP */
3364 status
= GdipGetInterpolationMode(graphics
, NULL
);
3365 expect(InvalidParameter
, status
);
3368 status
= GdipSetInterpolationMode(NULL
, InterpolationModeNearestNeighbor
);
3369 expect(InvalidParameter
, status
);
3372 status
= GdipSetInterpolationMode(graphics
, InterpolationModeHighQualityBicubic
+1);
3373 expect(InvalidParameter
, status
);
3375 status
= GdipSetInterpolationMode(graphics
, InterpolationModeInvalid
);
3376 expect(InvalidParameter
, status
);
3378 status
= GdipGetInterpolationMode(graphics
, &mode
);
3380 expect(InterpolationModeBilinear
, mode
);
3382 status
= GdipSetInterpolationMode(graphics
, InterpolationModeNearestNeighbor
);
3385 status
= GdipGetInterpolationMode(graphics
, &mode
);
3387 expect(InterpolationModeNearestNeighbor
, mode
);
3389 status
= GdipSetInterpolationMode(graphics
, InterpolationModeDefault
);
3392 status
= GdipGetInterpolationMode(graphics
, &mode
);
3394 expect(InterpolationModeBilinear
, mode
);
3396 status
= GdipSetInterpolationMode(graphics
, InterpolationModeLowQuality
);
3399 status
= GdipGetInterpolationMode(graphics
, &mode
);
3401 expect(InterpolationModeBilinear
, mode
);
3403 status
= GdipSetInterpolationMode(graphics
, InterpolationModeHighQuality
);
3406 status
= GdipGetInterpolationMode(graphics
, &mode
);
3408 expect(InterpolationModeHighQualityBicubic
, mode
);
3410 GdipDeleteGraphics(graphics
);
3412 ReleaseDC(hwnd
, hdc
);
3415 static void test_get_set_textrenderinghint(void)
3417 GpGraphics
*graphics
;
3418 HDC hdc
= GetDC( hwnd
);
3420 TextRenderingHint hint
;
3422 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
3423 status
= GdipCreateFromHDC(hdc
, &graphics
);
3425 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
3427 status
= GdipGetTextRenderingHint(NULL
, &hint
);
3428 expect(InvalidParameter
, status
);
3430 status
= GdipGetTextRenderingHint(graphics
, NULL
);
3431 expect(InvalidParameter
, status
);
3433 status
= GdipSetTextRenderingHint(NULL
, TextRenderingHintAntiAlias
);
3434 expect(InvalidParameter
, status
);
3437 status
= GdipSetTextRenderingHint(graphics
, TextRenderingHintClearTypeGridFit
+1);
3438 expect(InvalidParameter
, status
);
3440 status
= GdipGetTextRenderingHint(graphics
, &hint
);
3442 expect(TextRenderingHintSystemDefault
, hint
);
3444 status
= GdipSetTextRenderingHint(graphics
, TextRenderingHintSystemDefault
);
3447 status
= GdipGetTextRenderingHint(graphics
, &hint
);
3449 expect(TextRenderingHintSystemDefault
, hint
);
3451 status
= GdipSetTextRenderingHint(graphics
, TextRenderingHintAntiAliasGridFit
);
3454 status
= GdipGetTextRenderingHint(graphics
, &hint
);
3456 expect(TextRenderingHintAntiAliasGridFit
, hint
);
3458 GdipDeleteGraphics(graphics
);
3460 ReleaseDC(hwnd
, hdc
);
3463 static void test_getdc_scaled(void)
3466 GpGraphics
*graphics
= NULL
;
3467 GpBitmap
*bitmap
= NULL
;
3469 HBRUSH hbrush
, holdbrush
;
3472 status
= GdipCreateBitmapFromScan0(10, 10, 12, PixelFormat24bppRGB
, NULL
, &bitmap
);
3475 status
= GdipGetImageGraphicsContext((GpImage
*)bitmap
, &graphics
);
3478 status
= GdipScaleWorldTransform(graphics
, 2.0, 2.0, MatrixOrderPrepend
);
3481 status
= GdipGetDC(graphics
, &hdc
);
3483 ok(hdc
!= NULL
, "got NULL hdc\n");
3485 hbrush
= CreateSolidBrush(RGB(255, 0, 0));
3487 holdbrush
= SelectObject(hdc
, hbrush
);
3489 Rectangle(hdc
, 2, 2, 6, 6);
3491 SelectObject(hdc
, holdbrush
);
3493 DeleteObject(hbrush
);
3495 status
= GdipReleaseDC(graphics
, hdc
);
3498 GdipDeleteGraphics(graphics
);
3500 status
= GdipBitmapGetPixel(bitmap
, 3, 3, &color
);
3502 expect(0xffff0000, color
);
3504 status
= GdipBitmapGetPixel(bitmap
, 8, 8, &color
);
3506 expect(0xff000000, color
);
3508 GdipDisposeImage((GpImage
*)bitmap
);
3511 static void test_GdipMeasureString(void)
3513 static const struct test_data
3515 REAL res_x
, res_y
, page_scale
;
3519 { 200.0, 200.0, 1.0, UnitPixel
}, /* base */
3520 { 200.0, 200.0, 2.0, UnitPixel
},
3521 { 200.0, 200.0, 1.0, UnitDisplay
},
3522 { 200.0, 200.0, 2.0, UnitDisplay
},
3523 { 200.0, 200.0, 1.0, UnitInch
},
3524 { 200.0, 200.0, 2.0, UnitInch
},
3525 { 200.0, 600.0, 1.0, UnitPoint
},
3526 { 200.0, 600.0, 2.0, UnitPoint
},
3527 { 200.0, 600.0, 1.0, UnitDocument
},
3528 { 200.0, 600.0, 2.0, UnitDocument
},
3529 { 200.0, 600.0, 1.0, UnitMillimeter
},
3530 { 200.0, 600.0, 2.0, UnitMillimeter
},
3531 { 200.0, 600.0, 1.0, UnitDisplay
},
3532 { 200.0, 600.0, 2.0, UnitDisplay
},
3533 { 200.0, 600.0, 1.0, UnitPixel
},
3534 { 200.0, 600.0, 2.0, UnitPixel
},
3536 static const WCHAR tahomaW
[] = { 'T','a','h','o','m','a',0 };
3537 static const WCHAR string
[] = { '1','2','3','4','5','6','7',0 };
3539 GpGraphics
*graphics
;
3540 GpFontFamily
*family
;
3542 GpStringFormat
*format
;
3544 REAL base_cx
= 0, base_cy
= 0, height
;
3549 GpUnit font_unit
, unit
;
3551 status
= GdipCreateStringFormat(0, LANG_NEUTRAL
, &format
);
3553 status
= GdipCreateFontFamilyFromName(tahomaW
, NULL
, &family
);
3556 /* font size in pixels */
3557 status
= GdipCreateFont(family
, 100.0, FontStyleRegular
, UnitPixel
, &font
);
3559 status
= GdipGetFontSize(font
, &font_size
);
3561 expectf(100.0, font_size
);
3562 status
= GdipGetFontUnit(font
, &font_unit
);
3564 expect(UnitPixel
, font_unit
);
3566 for (i
= 0; i
< sizeof(td
)/sizeof(td
[0]); i
++)
3570 graphics
= create_graphics(td
[i
].res_x
, td
[i
].res_y
, td
[i
].unit
, td
[i
].page_scale
, &image
);
3572 lf
.lfHeight
= 0xdeadbeef;
3573 status
= GdipGetLogFontW(font
, graphics
, &lf
);
3575 height
= units_to_pixels(font_size
, td
[i
].unit
, td
[i
].res_y
);
3576 if (td
[i
].unit
!= UnitDisplay
)
3577 height
*= td
[i
].page_scale
;
3578 ok(-lf
.lfHeight
== (LONG
)(height
+ 0.5), "%u: expected %d (%f), got %d\n",
3579 i
, (LONG
)(height
+ 0.5), height
, lf
.lfHeight
);
3581 height
= font_size
+ 2.0 * font_size
/ 6.0;
3583 set_rect_empty(&rc
);
3584 set_rect_empty(&bounds
);
3585 status
= GdipMeasureString(graphics
, string
, -1, font
, &rc
, format
, &bounds
, &chars
, &lines
);
3590 base_cx
= bounds
.Width
;
3591 base_cy
= bounds
.Height
;
3594 expectf(0.0, bounds
.X
);
3595 expectf(0.0, bounds
.Y
);
3597 expectf_(height
, bounds
.Height
, height
/ 100.0);
3598 expectf_(bounds
.Height
/ base_cy
, bounds
.Width
/ base_cx
, 0.1);
3602 /* make sure it really fits */
3603 bounds
.Width
+= 1.0;
3604 bounds
.Height
+= 1.0;
3608 set_rect_empty(&bounds
);
3609 status
= GdipMeasureString(graphics
, string
, -1, font
, &rc
, format
, &bounds
, &chars
, &lines
);
3611 expectf(50.0, bounds
.X
);
3612 expectf(50.0, bounds
.Y
);
3614 expectf_(height
, bounds
.Height
, height
/ 100.0);
3615 expectf_(bounds
.Height
/ base_cy
, bounds
.Width
/ base_cx
, 0.1);
3619 status
= GdipDeleteGraphics(graphics
);
3622 status
= GdipDisposeImage(image
);
3626 GdipDeleteFont(font
);
3628 /* font size in logical units */
3629 /* UnitPoint = 3, UnitInch = 4, UnitDocument = 5, UnitMillimeter = 6 */
3630 for (unit
= 3; unit
<= 6; unit
++)
3632 /* create a font which final height is 100.0 pixels with 200 dpi device */
3633 /* height + 2 * (height/6) = 100 => height = 100 * 3 / 4 => 75 */
3634 height
= pixels_to_units(75.0, unit
, 200.0);
3635 status
= GdipCreateFont(family
, height
, FontStyleRegular
, unit
, &font
);
3637 status
= GdipGetFontSize(font
, &font_size
);
3639 expectf(height
, font_size
);
3640 status
= GdipGetFontUnit(font
, &font_unit
);
3642 expect(unit
, font_unit
);
3644 for (i
= 0; i
< sizeof(td
)/sizeof(td
[0]); i
++)
3649 graphics
= create_graphics(td
[i
].res_x
, td
[i
].res_y
, td
[i
].unit
, td
[i
].page_scale
, &image
);
3651 lf
.lfHeight
= 0xdeadbeef;
3652 status
= GdipGetLogFontW(font
, graphics
, &lf
);
3654 if (td
[i
].unit
== UnitDisplay
|| td
[i
].unit
== UnitPixel
)
3655 height
= units_to_pixels(font_size
, font_unit
, td
[i
].res_x
);
3657 height
= units_to_pixels(font_size
, font_unit
, td
[i
].res_y
);
3658 /*trace("%.1f font units = %f pixels with %.1f dpi, page_scale %.1f\n", font_size, height, td[i].res_y, td[i].page_scale);*/
3659 ok(-lf
.lfHeight
== (LONG
)(height
+ 0.5), "%u: expected %d (%f), got %d\n",
3660 i
, (LONG
)(height
+ 0.5), height
, lf
.lfHeight
);
3662 if (td
[i
].unit
== UnitDisplay
|| td
[i
].unit
== UnitPixel
)
3663 unit_scale
= units_scale(font_unit
, td
[i
].unit
, td
[i
].res_x
);
3665 unit_scale
= units_scale(font_unit
, td
[i
].unit
, td
[i
].res_y
);
3666 /*trace("%u: %d to %d, %.1f dpi => unit_scale %f\n", i, font_unit, td[i].unit, td[i].res_y, unit_scale);*/
3667 height
= (font_size
+ 2.0 * font_size
/ 6.0) * unit_scale
;
3668 if (td
[i
].unit
!= UnitDisplay
)
3669 height
/= td
[i
].page_scale
;
3670 /*trace("%u: %.1f font units = %f units with %.1f dpi, page_scale %.1f\n", i, font_size, height, td[i].res_y, td[i].page_scale);*/
3672 set_rect_empty(&rc
);
3673 set_rect_empty(&bounds
);
3674 status
= GdipMeasureString(graphics
, string
, -1, font
, &rc
, format
, &bounds
, &chars
, &lines
);
3679 base_cx
= bounds
.Width
;
3680 base_cy
= bounds
.Height
;
3683 expectf(0.0, bounds
.X
);
3684 expectf(0.0, bounds
.Y
);
3686 expectf_(height
, bounds
.Height
, height
/ 85.0);
3687 expectf_(bounds
.Height
/ base_cy
, bounds
.Width
/ base_cx
, 0.1);
3691 /* make sure it really fits */
3692 bounds
.Width
+= 1.0;
3693 bounds
.Height
+= 1.0;
3697 set_rect_empty(&bounds
);
3698 status
= GdipMeasureString(graphics
, string
, -1, font
, &rc
, format
, &bounds
, &chars
, &lines
);
3700 expectf(50.0, bounds
.X
);
3701 expectf(50.0, bounds
.Y
);
3703 expectf_(height
, bounds
.Height
, height
/ 85.0);
3704 expectf_(bounds
.Height
/ base_cy
, bounds
.Width
/ base_cx
, 0.1);
3708 /* verify the result */
3709 height
= units_to_pixels(bounds
.Height
, td
[i
].unit
, td
[i
].res_x
);
3710 if (td
[i
].unit
!= UnitDisplay
)
3711 height
*= td
[i
].page_scale
;
3712 /*trace("%u: unit %u, %.1fx%.1f dpi, scale %.1f, height %f, pixels %f\n",
3713 i, td[i].unit, td[i].res_x, td[i].res_y, td[i].page_scale, bounds.Height, height);*/
3715 expectf_(100.0, height
, 1.1);
3717 status
= GdipDeleteGraphics(graphics
);
3720 status
= GdipDisposeImage(image
);
3724 GdipDeleteFont(font
);
3727 /* Font with units = UnitWorld */
3728 for (i
= 0; i
< sizeof(td
)/sizeof(td
[0]); i
++)
3730 GpPointF pt
= {0.0, 100.0};
3732 REAL expected_width
, expected_height
;
3734 graphics
= create_graphics(td
[i
].res_x
, td
[i
].res_y
, td
[i
].unit
, td
[i
].page_scale
, &image
);
3736 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, &pt
, 1);
3739 status
= GdipCreateFont(family
, pt
.Y
, FontStyleRegular
, UnitWorld
, &font
);
3742 status
= GdipGetFontUnit(font
, &font_unit
);
3744 expect(UnitWorld
, font_unit
);
3746 lf
.lfHeight
= 0xdeadbeef;
3747 status
= GdipGetLogFontW(font
, graphics
, &lf
);
3749 ok(lf
.lfHeight
== -100, "%u: expected -100, got %d\n", i
, lf
.lfHeight
);
3751 set_rect_empty(&rc
);
3752 set_rect_empty(&bounds
);
3753 status
= GdipMeasureString(graphics
, string
, -1, font
, &rc
, format
, &bounds
, &chars
, &lines
);
3758 base_cx
= bounds
.Width
;
3759 base_cy
= bounds
.Height
;
3765 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, &pt
, 1);
3768 /* height is constant in device space, width is proportional to height in world space */
3769 expected_width
= base_cx
* pt
.Y
;
3770 expected_height
= base_cy
* pt
.Y
;
3772 todo_wine_if(td
[i
].unit
!= UnitDisplay
&& td
[i
].unit
!= UnitPixel
)
3773 ok(fabs(expected_width
- bounds
.Width
) <= 0.001, "%u: expected %f, got %f\n", i
, expected_width
, bounds
.Width
);
3774 ok(fabs(expected_height
- bounds
.Height
) <= 0.001, "%u: expected %f, got %f\n", i
, expected_height
, bounds
.Height
);
3776 GdipDeleteGraphics(graphics
);
3777 GdipDisposeImage(image
);
3778 GdipDeleteFont(font
);
3781 GdipDeleteFontFamily(family
);
3782 GdipDeleteStringFormat(format
);
3785 static void test_transform(void)
3787 static const struct test_data
3789 REAL res_x
, res_y
, scale
;
3791 GpPointF in
[2], out
[2];
3794 { 96.0, 96.0, 1.0, UnitPixel
,
3795 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 100.0, 0.0 }, { 0.0, 100.0 } } },
3796 { 96.0, 96.0, 1.0, UnitDisplay
,
3797 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 100.0, 0.0 }, { 0.0, 100.0 } } },
3798 { 96.0, 96.0, 1.0, UnitInch
,
3799 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 9600.0, 0.0 }, { 0.0, 9600.0 } } },
3800 { 123.0, 456.0, 1.0, UnitPoint
,
3801 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 170.833313, 0.0 }, { 0.0, 633.333252 } } },
3802 { 123.0, 456.0, 1.0, UnitDocument
,
3803 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 40.999996, 0.0 }, { 0.0, 151.999985 } } },
3804 { 123.0, 456.0, 2.0, UnitMillimeter
,
3805 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 968.503845, 0.0 }, { 0.0, 3590.550781 } } },
3806 { 196.0, 296.0, 1.0, UnitDisplay
,
3807 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 100.0, 0.0 }, { 0.0, 100.0 } } },
3808 { 196.0, 296.0, 1.0, UnitPixel
,
3809 { { 100.0, 0.0 }, { 0.0, 100.0 } }, { { 100.0, 0.0 }, { 0.0, 100.0 } } },
3812 GpGraphics
*graphics
;
3817 for (i
= 0; i
< sizeof(td
)/sizeof(td
[0]); i
++)
3819 graphics
= create_graphics(td
[i
].res_x
, td
[i
].res_y
, td
[i
].unit
, td
[i
].scale
, &image
);
3820 ptf
[0].X
= td
[i
].in
[0].X
;
3821 ptf
[0].Y
= td
[i
].in
[0].Y
;
3822 ptf
[1].X
= td
[i
].in
[1].X
;
3823 ptf
[1].Y
= td
[i
].in
[1].Y
;
3824 status
= GdipTransformPoints(graphics
, CoordinateSpaceDevice
, CoordinateSpaceWorld
, ptf
, 2);
3826 expectf(td
[i
].out
[0].X
, ptf
[0].X
);
3827 expectf(td
[i
].out
[0].Y
, ptf
[0].Y
);
3828 expectf(td
[i
].out
[1].X
, ptf
[1].X
);
3829 expectf(td
[i
].out
[1].Y
, ptf
[1].Y
);
3830 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
3832 expectf(td
[i
].in
[0].X
, ptf
[0].X
);
3833 expectf(td
[i
].in
[0].Y
, ptf
[0].Y
);
3834 expectf(td
[i
].in
[1].X
, ptf
[1].X
);
3835 expectf(td
[i
].in
[1].Y
, ptf
[1].Y
);
3836 status
= GdipDeleteGraphics(graphics
);
3838 status
= GdipDisposeImage(image
);
3843 static void test_pen_thickness(void)
3845 static const struct test_data
3847 REAL res_x
, res_y
, scale
;
3848 GpUnit pen_unit
, page_unit
;
3853 { 10.0, 10.0, 1.0, UnitPixel
, UnitPixel
, 1.0, 1, 1 },
3854 { 10.0, 10.0, 3.0, UnitPixel
, UnitPixel
, 2.0, 2, 2 },
3855 { 10.0, 10.0, 30.0, UnitPixel
, UnitInch
, 1.0, 1, 1 },
3856 { 10.0, 10.0, 1.0, UnitWorld
, UnitPixel
, 1.0, 1, 1 },
3857 { 10.0, 10.0, 3.0, UnitWorld
, UnitPixel
, 2.0, 6, 6 },
3858 { 10.0, 10.0, 2.0, UnitWorld
, UnitInch
, 1.0, 20, 20 },
3862 GpGraphics
*graphics
;
3873 for (i
= 0; i
< sizeof(td
)/sizeof(td
[0]); i
++)
3875 status
= GdipCreateBitmapFromScan0(100, 100, 0, PixelFormat24bppRGB
, NULL
, &u
.bitmap
);
3878 status
= GdipBitmapSetResolution(u
.bitmap
, td
[i
].res_x
, td
[i
].res_y
);
3881 status
= GdipGetImageGraphicsContext(u
.image
, &graphics
);
3884 status
= GdipSetPageUnit(graphics
, td
[i
].page_unit
);
3887 status
= GdipSetPageScale(graphics
, td
[i
].scale
);
3890 status
= GdipCreatePen1(0xffffffff, td
[i
].pen_width
, td
[i
].pen_unit
, &pen
);
3893 corner
.X
= corner
.Y
= 100.0;
3894 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, &corner
, 1);
3897 status
= GdipDrawLine(graphics
, pen
, corner
.X
/2, 0, corner
.X
/2, corner
.Y
);
3900 status
= GdipDrawLine(graphics
, pen
, 0, corner
.Y
/2, corner
.X
, corner
.Y
/2);
3903 status
= GdipBitmapLockBits(u
.bitmap
, NULL
, ImageLockModeRead
, PixelFormat24bppRGB
, &bd
);
3909 for (j
=0; j
<100; j
++)
3911 if (((BYTE
*)bd
.Scan0
)[j
*3] == 0xff)
3918 for (j
=99; j
>=0; j
--)
3920 if (((BYTE
*)bd
.Scan0
)[j
*3] == 0xff)
3929 ok(size
== td
[i
].cx
, "%u: expected %d, got %d\n", i
, td
[i
].cx
, size
);
3934 for (j
=0; j
<100; j
++)
3936 if (((BYTE
*)bd
.Scan0
)[bd
.Stride
*j
] == 0xff)
3943 for (j
=99; j
>=0; j
--)
3945 if (((BYTE
*)bd
.Scan0
)[bd
.Stride
*j
] == 0xff)
3954 ok(size
== td
[i
].cy
, "%u: expected %d, got %d\n", i
, td
[i
].cy
, size
);
3956 status
= GdipBitmapUnlockBits(u
.bitmap
, &bd
);
3960 GdipDeleteGraphics(graphics
);
3961 GdipDisposeImage(u
.image
);
3965 /* Many people on the net ask why there is so much difference in rendered
3966 * text height between gdiplus and gdi32, this test suggests an answer to
3967 * that question. Important: this test assumes that font dpi == device dpi.
3969 static void test_font_height_scaling(void)
3971 static const WCHAR tahomaW
[] = { 'T','a','h','o','m','a',0 };
3972 static const WCHAR string
[] = { '1','2','3','4','5','6','7',0 };
3974 GpStringFormat
*format
;
3975 CharacterRange range
= { 0, 7 };
3977 GpGraphics
*graphics
;
3978 GpFontFamily
*family
;
3982 REAL height
, dpi
, scale
;
3984 GpUnit gfx_unit
, font_unit
;
3986 status
= GdipCreateStringFormat(StringFormatFlagsNoWrap
, LANG_NEUTRAL
, &format
);
3988 status
= GdipSetStringFormatMeasurableCharacterRanges(format
, 1, &range
);
3990 status
= GdipCreateRegion(®ion
);
3993 status
= GdipCreateFontFamilyFromName(tahomaW
, NULL
, &family
);
3996 hdc
= CreateCompatibleDC(0);
3997 status
= GdipCreateFromHDC(hdc
, &graphics
);
4000 status
= GdipGetDpiY(graphics
, &dpi
);
4003 /* First check if tested functionality works:
4004 * under XP if font and graphics units differ then GdipTransformPoints
4005 * followed by GdipSetPageUnit to change the graphics units breaks region
4006 * scaling in GdipMeasureCharacterRanges called later.
4008 status
= GdipSetPageUnit(graphics
, UnitDocument
);
4013 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, &ptf
, 1);
4016 status
= GdipSetPageUnit(graphics
, UnitInch
);
4019 status
= GdipCreateFont(family
, 720.0, FontStyleRegular
, UnitPoint
, &font
);
4022 set_rect_empty(&rect
);
4023 set_rect_empty(&bounds
);
4024 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, NULL
, NULL
);
4026 trace("test bounds: %f,%f,%f,%f\n", bounds
.X
, bounds
.Y
, bounds
.Width
, bounds
.Height
);
4028 set_rect_empty(&rect
);
4029 rect
.Width
= 32000.0;
4030 rect
.Height
= 32000.0;
4031 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4034 set_rect_empty(&rect
);
4035 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
4037 trace("test region: %f,%f,%f,%f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4039 GdipDeleteFont(font
);
4041 scale
= rect
.Height
/ bounds
.Height
;
4042 if (fabs(scale
- 1.0) > 0.1)
4044 win_skip("GdipGetRegionBounds is broken, scale %f (should be near 1.0)\n", scale
);
4048 status
= GdipScaleWorldTransform(graphics
, 0.01, 0.01, MatrixOrderAppend
);
4051 /* UnitPixel = 2, UnitPoint = 3, UnitInch = 4, UnitDocument = 5, UnitMillimeter = 6 */
4052 /* UnitPixel as a font base unit is not tested because it drastically
4053 differs in behaviour */
4054 for (font_unit
= 3; font_unit
<= 6; font_unit
++)
4056 /* create a font for the final text height of 100 pixels */
4057 /* height + 2 * (height/6) = 100 => height = 100 * 3 / 4 => 75 */
4058 status
= GdipSetPageUnit(graphics
, font_unit
);
4062 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, &ptf
, 1);
4065 /*trace("height %f units\n", height);*/
4066 status
= GdipCreateFont(family
, height
, FontStyleRegular
, font_unit
, &font
);
4069 /* UnitPixel = 2, UnitPoint = 3, UnitInch = 4, UnitDocument = 5, UnitMillimeter = 6 */
4070 for (gfx_unit
= 2; gfx_unit
<= 6; gfx_unit
++)
4072 static const WCHAR doubleW
[2] = { 'W','W' };
4073 RectF bounds_1
, bounds_2
;
4074 REAL margin
, margin_y
, font_height
;
4077 status
= GdipSetPageUnit(graphics
, gfx_unit
);
4080 margin_y
= units_to_pixels(height
/ 8.0, font_unit
, dpi
);
4081 margin_y
= pixels_to_units(margin_y
, gfx_unit
, dpi
);
4083 status
= GdipGetFontHeight(font
, graphics
, &font_height
);
4086 set_rect_empty(&rect
);
4087 set_rect_empty(&bounds
);
4088 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, NULL
, NULL
);
4090 /*trace("bounds: %f,%f,%f,%f\n", bounds.X, bounds.Y, bounds.Width, bounds.Height);*/
4092 expectf_(font_height
+ margin_y
, bounds
.Height
, 0.005);
4095 ptf
.Y
= bounds
.Height
;
4096 status
= GdipTransformPoints(graphics
, CoordinateSpaceDevice
, CoordinateSpaceWorld
, &ptf
, 1);
4098 match
= fabs(100.0 - ptf
.Y
) <= 1.0;
4100 ok(match
, "Expected 100.0, got %f\n", ptf
.Y
);
4102 /* verify the result */
4103 ptf
.Y
= units_to_pixels(bounds
.Height
, gfx_unit
, dpi
);
4105 match
= fabs(100.0 - ptf
.Y
) <= 1.0;
4107 ok(match
, "Expected 100.0, got %f\n", ptf
.Y
);
4109 /* bounds.width of 1 glyph: [margin]+[width]+[margin] */
4110 set_rect_empty(&rect
);
4111 set_rect_empty(&bounds_1
);
4112 status
= GdipMeasureString(graphics
, doubleW
, 1, font
, &rect
, format
, &bounds_1
, NULL
, NULL
);
4114 /* bounds.width of 2 identical glyphs: [margin]+[width]+[width]+[margin] */
4115 set_rect_empty(&rect
);
4116 set_rect_empty(&bounds_2
);
4117 status
= GdipMeasureString(graphics
, doubleW
, 2, font
, &rect
, format
, &bounds_2
, NULL
, NULL
);
4120 /* margin = [bounds.width of 1] - [bounds.width of 2] / 2*/
4121 margin
= bounds_1
.Width
- bounds_2
.Width
/ 2.0;
4122 /*trace("margin %f\n", margin);*/
4123 ok(margin
> 0.0, "wrong margin %f\n", margin
);
4125 set_rect_empty(&rect
);
4126 rect
.Width
= 320000.0;
4127 rect
.Height
= 320000.0;
4128 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4130 set_rect_empty(&rect
);
4131 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
4133 /*trace("region: %f,%f,%f,%f\n", rect.X, rect.Y, rect.Width, rect.Height);*/
4134 ok(rect
.X
> 0.0, "wrong rect.X %f\n", rect
.X
);
4135 expectf(0.0, rect
.Y
);
4136 match
= fabs(1.0 - margin
/ rect
.X
) <= 0.05;
4137 ok(match
, "Expected %f, got %f\n", margin
, rect
.X
);
4138 match
= fabs(1.0 - font_height
/ rect
.Height
) <= 0.1;
4139 ok(match
, "Expected %f, got %f\n", font_height
, rect
.Height
);
4140 match
= fabs(1.0 - bounds
.Width
/ (rect
.Width
+ margin
* 2.0)) <= 0.05;
4141 ok(match
, "Expected %f, got %f\n", bounds
.Width
, rect
.Width
+ margin
* 2.0);
4144 GdipDeleteFont(font
);
4148 status
= GdipDeleteGraphics(graphics
);
4152 GdipDeleteFontFamily(family
);
4153 GdipDeleteRegion(region
);
4154 GdipDeleteStringFormat(format
);
4157 static void test_measure_string(void)
4159 static const WCHAR tahomaW
[] = { 'T','a','h','o','m','a',0 };
4160 static const WCHAR string
[] = { 'A','0','1',0 };
4162 GpStringFormat
*format
;
4163 CharacterRange range
;
4165 GpGraphics
*graphics
;
4166 GpFontFamily
*family
;
4170 REAL width
, height
, width_1
, width_2
;
4171 REAL margin_x
, margin_y
, width_rgn
, height_rgn
;
4174 status
= GdipCreateStringFormat(StringFormatFlagsNoWrap
, LANG_NEUTRAL
, &format
);
4178 status
= GdipCreateRegion(®ion
);
4181 status
= GdipCreateFontFamilyFromName(tahomaW
, NULL
, &family
);
4184 hdc
= CreateCompatibleDC(0);
4185 status
= GdipCreateFromHDC(hdc
, &graphics
);
4187 status
= GdipCreateFont(family
, 20, FontStyleRegular
, UnitPixel
, &font
);
4190 margin_x
= 20.0 / 6.0;
4191 margin_y
= 20.0 / 8.0;
4193 set_rect_empty(&rect
);
4194 set_rect_empty(&bounds
);
4195 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4199 expectf(0.0, bounds
.X
);
4200 expectf(0.0, bounds
.Y
);
4201 width
= bounds
.Width
;
4202 height
= bounds
.Height
;
4204 set_rect_empty(&rect
);
4205 rect
.Height
= height
/ 2.0;
4206 set_rect_empty(&bounds
);
4207 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4211 expectf(0.0, bounds
.X
);
4212 expectf(0.0, bounds
.Y
);
4213 expectf(width
, bounds
.Width
);
4215 expectf(height
/ 2.0, bounds
.Height
);
4218 range
.Length
= lstrlenW(string
);
4219 status
= GdipSetStringFormatMeasurableCharacterRanges(format
, 1, &range
);
4224 rect
.Width
= 32000.0;
4225 rect
.Height
= 32000.0;
4226 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4228 set_rect_empty(&bounds
);
4229 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4231 expectf_(5.0 + margin_x
, bounds
.X
, 1.0);
4232 expectf(5.0, bounds
.Y
);
4233 expectf_(width
- margin_x
*2.0, bounds
.Width
, 1.0);
4235 expectf_(height
- margin_y
, bounds
.Height
, 1.0);
4237 width_rgn
= bounds
.Width
;
4238 height_rgn
= bounds
.Height
;
4242 status
= GdipSetStringFormatMeasurableCharacterRanges(format
, 1, &range
);
4245 set_rect_empty(&rect
);
4246 rect
.Width
= 32000.0;
4247 rect
.Height
= 32000.0;
4248 status
= GdipMeasureCharacterRanges(graphics
, string
, 1, font
, &rect
, format
, 1, ®ion
);
4250 set_rect_empty(&bounds
);
4251 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4253 expectf_(margin_x
, bounds
.X
, 1.0);
4254 expectf(0.0, bounds
.Y
);
4255 ok(bounds
.Width
< width_rgn
/ 2.0, "width of 1 glyph is wrong\n");
4256 expectf(height_rgn
, bounds
.Height
);
4257 width_1
= bounds
.Width
;
4260 range
.Length
= lstrlenW(string
);
4261 status
= GdipSetStringFormatMeasurableCharacterRanges(format
, 1, &range
);
4268 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4270 set_rect_empty(&bounds
);
4271 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4273 expectf(0.0, bounds
.X
);
4274 expectf(0.0, bounds
.Y
);
4275 expectf(0.0, bounds
.Width
);
4276 expectf(0.0, bounds
.Height
);
4280 rect
.Width
= width_rgn
/ 2.0;
4281 rect
.Height
= 32000.0;
4282 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4284 set_rect_empty(&bounds
);
4285 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4287 expectf_(5.0 + margin_x
, bounds
.X
, 1.0);
4288 expectf(5.0, bounds
.Y
);
4289 expectf_(width_1
, bounds
.Width
, 1.0);
4291 expectf_(height
- margin_y
, bounds
.Height
, 1.0);
4293 status
= GdipSetStringFormatFlags(format
, StringFormatFlagsNoWrap
| StringFormatFlagsNoClip
);
4299 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4301 set_rect_empty(&bounds
);
4302 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4304 expectf_(5.0 + margin_x
, bounds
.X
, 1.0);
4305 expectf(5.0, bounds
.Y
);
4306 expectf(width_rgn
, bounds
.Width
);
4307 expectf(height_rgn
, bounds
.Height
);
4311 rect
.Width
= width_rgn
/ 2.0;
4312 rect
.Height
= 32000.0;
4313 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4315 set_rect_empty(&bounds
);
4316 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4318 expectf_(5.0 + margin_x
, bounds
.X
, 1.0);
4319 expectf(5.0, bounds
.Y
);
4320 expectf_(width_1
, bounds
.Width
, 1.0);
4321 expectf(height_rgn
, bounds
.Height
);
4323 set_rect_empty(&rect
);
4324 rect
.Height
= height
/ 2.0;
4325 set_rect_empty(&bounds
);
4326 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4330 expectf(0.0, bounds
.X
);
4331 expectf(0.0, bounds
.Y
);
4332 expectf_(width
, bounds
.Width
, 0.01);
4334 expectf(height
, bounds
.Height
);
4336 set_rect_empty(&rect
);
4337 set_rect_empty(&bounds
);
4338 status
= GdipMeasureString(graphics
, string
, 1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4342 expectf(0.0, bounds
.X
);
4343 expectf(0.0, bounds
.Y
);
4344 ok(bounds
.Width
< width
/ 2.0, "width of 1 glyph is wrong\n");
4345 expectf(height
, bounds
.Height
);
4346 width_1
= bounds
.Width
;
4348 set_rect_empty(&rect
);
4349 set_rect_empty(&bounds
);
4350 status
= GdipMeasureString(graphics
, string
, 2, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4354 expectf(0.0, bounds
.X
);
4355 expectf(0.0, bounds
.Y
);
4356 ok(bounds
.Width
< width
, "width of 2 glyphs is wrong\n");
4357 ok(bounds
.Width
> width_1
, "width of 2 glyphs is wrong\n");
4358 expectf(height
, bounds
.Height
);
4359 width_2
= bounds
.Width
;
4361 set_rect_empty(&rect
);
4362 rect
.Width
= width
/ 2.0;
4363 set_rect_empty(&bounds
);
4364 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4368 expectf(0.0, bounds
.X
);
4369 expectf(0.0, bounds
.Y
);
4370 expectf_(width_1
, bounds
.Width
, 0.01);
4371 expectf(height
, bounds
.Height
);
4373 set_rect_empty(&rect
);
4374 rect
.Height
= height
;
4375 rect
.Width
= width
- 0.05;
4376 set_rect_empty(&bounds
);
4377 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4381 expectf(0.0, bounds
.X
);
4382 expectf(0.0, bounds
.Y
);
4383 expectf_(width_2
, bounds
.Width
, 0.01);
4384 expectf(height
, bounds
.Height
);
4386 set_rect_empty(&rect
);
4387 rect
.Height
= height
;
4388 rect
.Width
= width_2
- 0.05;
4389 set_rect_empty(&bounds
);
4390 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4394 expectf(0.0, bounds
.X
);
4395 expectf(0.0, bounds
.Y
);
4396 expectf_(width_1
, bounds
.Width
, 0.01);
4397 expectf(height
, bounds
.Height
);
4399 /* Default (Near) alignment */
4402 rect
.Width
= width
* 2.0;
4403 rect
.Height
= height
* 2.0;
4404 set_rect_empty(&bounds
);
4405 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4409 expectf(5.0, bounds
.X
);
4410 expectf(5.0, bounds
.Y
);
4411 expectf_(width
, bounds
.Width
, 0.01);
4412 expectf(height
, bounds
.Height
);
4416 rect
.Width
= 32000.0;
4417 rect
.Height
= 32000.0;
4418 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4420 set_rect_empty(&bounds
);
4421 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4423 expectf_(5.0 + margin_x
, bounds
.X
, 1.0);
4424 expectf(5.0, bounds
.Y
);
4425 expectf_(width
- margin_x
*2.0, bounds
.Width
, 1.0);
4427 expectf_(height
- margin_y
, bounds
.Height
, 1.0);
4429 width_rgn
= bounds
.Width
;
4430 height_rgn
= bounds
.Height
;
4432 /* Center alignment */
4433 GdipSetStringFormatAlign(format
, StringAlignmentCenter
);
4434 GdipSetStringFormatLineAlign(format
, StringAlignmentCenter
);
4438 rect
.Width
= width
* 2.0;
4439 rect
.Height
= height
* 2.0;
4440 set_rect_empty(&bounds
);
4441 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4446 expectf_(5.0 + width
/2.0, bounds
.X
, 0.01);
4448 expectf(5.0 + height
/2.0, bounds
.Y
);
4449 expectf_(width
, bounds
.Width
, 0.01);
4450 expectf(height
, bounds
.Height
);
4456 set_rect_empty(&bounds
);
4457 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4462 expectf_(5.0 - width
/2.0, bounds
.X
, 0.01);
4464 expectf(5.0 - height
/2.0, bounds
.Y
);
4465 expectf_(width
, bounds
.Width
, 0.01);
4466 expectf(height
, bounds
.Height
);
4470 rect
.Width
= width_rgn
* 2.0;
4471 rect
.Height
= height_rgn
* 2.0;
4472 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4474 set_rect_empty(&bounds
);
4475 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4478 expectf_(5.0 + width_rgn
/2.0, bounds
.X
, 1.0);
4480 expectf_(5.0 + height_rgn
/2.0, bounds
.Y
, 1.0);
4481 expectf_(width_rgn
, bounds
.Width
, 1.0);
4482 expectf_(height_rgn
, bounds
.Height
, 1.0);
4488 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4490 set_rect_empty(&bounds
);
4491 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4494 expectf_(5.0 - width_rgn
/2.0, bounds
.X
, 1.0);
4496 expectf_(5.0 - height_rgn
/2.0, bounds
.Y
, 1.0);
4497 expectf_(width_rgn
, bounds
.Width
, 1.0);
4498 expectf_(height_rgn
, bounds
.Height
, 1.0);
4501 GdipSetStringFormatAlign(format
, StringAlignmentFar
);
4502 GdipSetStringFormatLineAlign(format
, StringAlignmentFar
);
4506 rect
.Width
= width
* 2.0;
4507 rect
.Height
= height
* 2.0;
4508 set_rect_empty(&bounds
);
4509 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4514 expectf_(5.0 + width
, bounds
.X
, 0.01);
4516 expectf(5.0 + height
, bounds
.Y
);
4517 expectf_(width
, bounds
.Width
, 0.01);
4518 expectf(height
, bounds
.Height
);
4524 set_rect_empty(&bounds
);
4525 status
= GdipMeasureString(graphics
, string
, -1, font
, &rect
, format
, &bounds
, &glyphs
, &lines
);
4530 expectf_(5.0 - width
, bounds
.X
, 0.01);
4532 expectf(5.0 - height
, bounds
.Y
);
4533 expectf_(width
, bounds
.Width
, 0.01);
4534 expectf(height
, bounds
.Height
);
4538 rect
.Width
= width_rgn
* 2.0;
4539 rect
.Height
= height_rgn
* 2.0;
4540 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4542 set_rect_empty(&bounds
);
4543 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4546 expectf_(5.0 + width_rgn
, bounds
.X
, 2.0);
4548 expectf_(5.0 + height_rgn
, bounds
.Y
, 1.0);
4549 expectf_(width_rgn
, bounds
.Width
, 1.0);
4550 expectf_(height_rgn
, bounds
.Height
, 1.0);
4556 status
= GdipMeasureCharacterRanges(graphics
, string
, -1, font
, &rect
, format
, 1, ®ion
);
4558 set_rect_empty(&bounds
);
4559 status
= GdipGetRegionBounds(region
, graphics
, &bounds
);
4562 expectf_(5.0 - width_rgn
, bounds
.X
, 2.0);
4564 expectf_(5.0 - height_rgn
, bounds
.Y
, 1.0);
4565 expectf_(width_rgn
, bounds
.Width
, 1.0);
4566 expectf_(height_rgn
, bounds
.Height
, 1.0);
4568 status
= GdipDeleteFont(font
);
4571 status
= GdipDeleteGraphics(graphics
);
4575 GdipDeleteFontFamily(family
);
4576 GdipDeleteRegion(region
);
4577 GdipDeleteStringFormat(format
);
4580 static void test_measured_extra_space(void)
4582 static const WCHAR tahomaW
[] = { 'T','a','h','o','m','a',0 };
4583 static const WCHAR string
[2] = { 'W','W' };
4584 GpStringFormat
*format
;
4586 GpGraphics
*graphics
;
4587 GpFontFamily
*family
;
4590 GpUnit gfx_unit
, font_unit
;
4591 RectF bounds_1
, bounds_2
, rect
;
4592 REAL margin
, font_size
, dpi
;
4594 status
= GdipCreateStringFormat(0, LANG_NEUTRAL
, &format
);
4597 status
= GdipCreateFontFamilyFromName(tahomaW
, NULL
, &family
);
4599 hdc
= CreateCompatibleDC(0);
4600 status
= GdipCreateFromHDC(hdc
, &graphics
);
4603 status
= GdipGetDpiX(graphics
, &dpi
);
4606 /* UnitPixel = 2, UnitPoint = 3, UnitInch = 4, UnitDocument = 5, UnitMillimeter = 6 */
4607 /* UnitPixel as a font base unit is not tested because it differs in behaviour */
4608 for (font_unit
= 3; font_unit
<= 6; font_unit
++)
4610 status
= GdipCreateFont(family
, 1234.0, FontStyleRegular
, font_unit
, &font
);
4613 status
= GdipGetFontSize(font
, &font_size
);
4615 font_size
= units_to_pixels(font_size
, font_unit
, dpi
);
4616 /*trace("font size/6 = %f pixels\n", font_size / 6.0);*/
4618 /* UnitPixel = 2, UnitPoint = 3, UnitInch = 4, UnitDocument = 5, UnitMillimeter = 6 */
4619 for (gfx_unit
= 2; gfx_unit
<= 6; gfx_unit
++)
4621 status
= GdipSetPageUnit(graphics
, gfx_unit
);
4624 /* bounds.width of 1 glyph: [margin]+[width]+[margin] */
4625 set_rect_empty(&rect
);
4626 set_rect_empty(&bounds_1
);
4627 status
= GdipMeasureString(graphics
, string
, 1, font
, &rect
, format
, &bounds_1
, NULL
, NULL
);
4629 /* bounds.width of 2 identical glyphs: [margin]+[width]+[width]+[margin] */
4630 set_rect_empty(&rect
);
4631 set_rect_empty(&bounds_2
);
4632 status
= GdipMeasureString(graphics
, string
, 2, font
, &rect
, format
, &bounds_2
, NULL
, NULL
);
4635 /* margin = [bounds.width of 1] - [bounds.width of 2] / 2*/
4636 margin
= units_to_pixels(bounds_1
.Width
- bounds_2
.Width
/ 2.0, gfx_unit
, dpi
);
4637 /*trace("margin %f pixels\n", margin);*/
4638 expectf_(font_size
/ 6.0, margin
, font_size
/ 100.0);
4641 GdipDeleteFont(font
);
4644 GdipDeleteGraphics(graphics
);
4646 GdipDeleteFontFamily(family
);
4647 GdipDeleteStringFormat(format
);
4650 static void test_alpha_hdc(void)
4654 HBITMAP hbm
, old_hbm
;
4655 GpGraphics
*graphics
;
4661 hdc
= CreateCompatibleDC(0);
4662 ok(hdc
!= NULL
, "CreateCompatibleDC failed\n");
4663 bmi
.bmiHeader
.biSize
= sizeof(bmi
.bmiHeader
);
4664 bmi
.bmiHeader
.biHeight
= 5;
4665 bmi
.bmiHeader
.biWidth
= 5;
4666 bmi
.bmiHeader
.biBitCount
= 32;
4667 bmi
.bmiHeader
.biPlanes
= 1;
4668 bmi
.bmiHeader
.biCompression
= BI_RGB
;
4669 bmi
.bmiHeader
.biClrUsed
= 0;
4671 hbm
= CreateDIBSection(hdc
, &bmi
, DIB_RGB_COLORS
, (void**)&bits
, NULL
, 0);
4672 ok(hbm
!= NULL
, "CreateDIBSection failed\n");
4674 old_hbm
= SelectObject(hdc
, hbm
);
4676 status
= GdipCreateFromHDC(hdc
, &graphics
);
4679 status
= GdipGetVisibleClipBounds(graphics
, &bounds
);
4681 expectf(0.0, bounds
.X
);
4682 expectf(0.0, bounds
.Y
);
4683 expectf(5.0, bounds
.Width
);
4684 expectf(5.0, bounds
.Height
);
4686 bits
[0] = 0xdeadbeef;
4688 status
= GdipGraphicsClear(graphics
, 0xffaaaaaa);
4691 expect(0xffaaaaaa, bits
[0]);
4693 bits
[0] = 0xdeadbeef;
4695 status
= GdipGetDC(graphics
, &gp_hdc
);
4698 colorref
= GetPixel(gp_hdc
, 0, 4);
4699 expect(0xefbead, colorref
);
4701 SetPixel(gp_hdc
, 0, 4, 0xffffff);
4703 expect(0xffffff, bits
[0]);
4705 status
= GdipReleaseDC(graphics
, gp_hdc
);
4708 SelectObject(hdc
, old_hbm
);
4710 bits
[0] = 0xdeadbeef;
4712 status
= GdipGraphicsClear(graphics
, 0xffbbbbbb);
4715 todo_wine
expect(0xffbbbbbb, bits
[0]);
4717 GdipDeleteGraphics(graphics
);
4723 static void test_bitmapfromgraphics(void)
4726 GpGraphics
*graphics
= NULL
;
4727 HDC hdc
= GetDC( hwnd
);
4728 GpBitmap
*bitmap
= NULL
;
4730 REAL imageres
, graphicsres
;
4733 stat
= GdipCreateFromHDC(hdc
, &graphics
);
4736 stat
= GdipCreateBitmapFromGraphics(12, 13, NULL
, &bitmap
);
4737 expect(InvalidParameter
, stat
);
4739 stat
= GdipCreateBitmapFromGraphics(12, 13, graphics
, NULL
);
4740 expect(InvalidParameter
, stat
);
4742 stat
= GdipCreateBitmapFromGraphics(12, 13, graphics
, &bitmap
);
4745 stat
= GdipGetImagePixelFormat((GpImage
*)bitmap
, &format
);
4747 expect(PixelFormat32bppPARGB
, format
);
4749 stat
= GdipGetDpiX(graphics
, &graphicsres
);
4752 stat
= GdipGetImageHorizontalResolution((GpImage
*)bitmap
, &imageres
);
4754 expectf(graphicsres
, imageres
);
4756 stat
= GdipGetDpiY(graphics
, &graphicsres
);
4759 stat
= GdipGetImageVerticalResolution((GpImage
*)bitmap
, &imageres
);
4761 expectf(graphicsres
, imageres
);
4763 stat
= GdipGetImageWidth((GpImage
*)bitmap
, &width
);
4767 stat
= GdipGetImageHeight((GpImage
*)bitmap
, &height
);
4771 GdipDeleteGraphics(graphics
);
4772 GdipDisposeImage((GpImage
*)bitmap
);
4775 static void test_clipping(void)
4779 GpGraphics
*graphics
;
4780 GpRegion
*region
, *region100x100
;
4789 hdc
= CreateCompatibleDC(0);
4790 status
= GdipCreateFromHDC(hdc
, &graphics
);
4793 status
= GdipGetPageUnit(graphics
, &unit
);
4795 expect(UnitDisplay
, unit
);
4797 status
= GdipCreateRegion(®ion
);
4799 status
= GdipSetEmpty(region
);
4802 status
= GdipCreateRegion(®ion100x100
);
4804 status
= GdipSetEmpty(region100x100
);
4807 rect
.X
= rect
.Y
= 100.0;
4808 rect
.Width
= rect
.Height
= 100.0;
4809 status
= GdipCombineRegionRect(region100x100
, &rect
, CombineModeUnion
);
4811 status
= GdipSetClipRegion(graphics
, region100x100
, CombineModeReplace
);
4814 status
= GdipGetClipBounds(graphics
, &rect
);
4816 ok(rect
.X
== 100.0 && rect
.Y
== 100.0 && rect
.Width
== 100.0 && rect
.Height
== 100.0,
4817 "expected 100.0,100.0-100.0,100.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4819 status
= GdipSetEmpty(region
);
4821 status
= GdipGetClip(graphics
, region
);
4823 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
4825 ok(rect
.X
== 100.0 && rect
.Y
== 100.0 && rect
.Width
== 100.0 && rect
.Height
== 100.0,
4826 "expected 100.0,100.0-100.0,100.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4832 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
4834 ok(ptf
[0].X
== 100.0 && ptf
[0].Y
== 100.0 && ptf
[1].X
== 200.0 && ptf
[1].Y
== 200.0,
4835 "expected 100.0,100.0-200.0,200.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
4837 status
= GdipCreateMatrix(&matrix
);
4839 status
= GdipScaleMatrix(matrix
, 2.0, 4.0, MatrixOrderAppend
);
4841 status
= GdipTranslateMatrix(matrix
, 10.0, 20.0, MatrixOrderAppend
);
4843 status
= GdipSetWorldTransform(graphics
, matrix
);
4846 status
= GdipGetClipBounds(graphics
, &rect
);
4848 ok(rect
.X
== 45.0 && rect
.Y
== 20.0 && rect
.Width
== 50.0 && rect
.Height
== 25.0,
4849 "expected 45.0,20.0-50.0,25.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4851 status
= GdipSetEmpty(region
);
4853 status
= GdipGetClip(graphics
, region
);
4855 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
4857 ok(rect
.X
== 45.0 && rect
.Y
== 20.0 && rect
.Width
== 50.0 && rect
.Height
== 25.0,
4858 "expected 45.0,20.0-50.0,25.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4860 status
= GdipGetRegionBounds(region100x100
, graphics
, &rect
);
4862 ok(rect
.X
== 100.0 && rect
.Y
== 100.0 && rect
.Width
== 100.0 && rect
.Height
== 100.0,
4863 "expected 100.0,100.0-100.0,100.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4865 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
4867 ret
= GetRgnBox(hrgn
, &rc
);
4868 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4869 ok(rc
.left
== 45 && rc
.top
== 20 && rc
.right
== 95 && rc
.bottom
== 45,
4870 "expected 45,20-95,45, got %s\n", wine_dbgstr_rect(&rc
));
4873 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
4875 ret
= GetRgnBox(hrgn
, &rc
);
4876 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4877 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
4878 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
4885 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
4887 ok(ptf
[0].X
== 45.0 && ptf
[0].Y
== 20.0 && ptf
[1].X
== 95.0 && ptf
[1].Y
== 45.0,
4888 "expected 45.0,20.0-95.0,45.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
4890 status
= GdipGetRegionHRgn(region100x100
, NULL
, &hrgn
);
4892 ret
= GetRgnBox(hrgn
, &rc
);
4893 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4894 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
4895 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
4898 status
= GdipGetRegionHRgn(region100x100
, graphics
, &hrgn
);
4900 ret
= GetRgnBox(hrgn
, &rc
);
4901 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4902 ok(rc
.left
== 210 && rc
.top
== 420 && rc
.right
== 410 && rc
.bottom
== 820,
4903 "expected 210,420-410,820, got %s\n", wine_dbgstr_rect(&rc
));
4910 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
4912 ok(ptf
[0].X
== 100.0 && ptf
[0].Y
== 100.0 && ptf
[1].X
== 200.0 && ptf
[1].Y
== 200.0,
4913 "expected 100.0,100.0-200.0,200.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
4915 status
= GdipSetPageScale(graphics
, 2.0);
4918 status
= GdipGetClipBounds(graphics
, &rect
);
4920 ok(rect
.X
== 45.0 && rect
.Y
== 20.0 && rect
.Width
== 50.0 && rect
.Height
== 25.0,
4921 "expected 45.0,20.0-50.0,25.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4923 status
= GdipSetEmpty(region
);
4925 status
= GdipGetClip(graphics
, region
);
4927 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
4929 ok(rect
.X
== 45.0 && rect
.Y
== 20.0 && rect
.Width
== 50.0 && rect
.Height
== 25.0,
4930 "expected 45.0,20.0-50.0,25.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4932 status
= GdipGetRegionBounds(region100x100
, graphics
, &rect
);
4934 ok(rect
.X
== 100.0 && rect
.Y
== 100.0 && rect
.Width
== 100.0 && rect
.Height
== 100.0,
4935 "expected 100.0,100.0-100.0,100.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4937 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
4939 ret
= GetRgnBox(hrgn
, &rc
);
4940 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4941 ok(rc
.left
== 45 && rc
.top
== 20 && rc
.right
== 95 && rc
.bottom
== 45,
4942 "expected 45,20-95,45, got %s\n", wine_dbgstr_rect(&rc
));
4945 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
4947 ret
= GetRgnBox(hrgn
, &rc
);
4948 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4949 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
4950 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
4957 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
4959 ok(ptf
[0].X
== 45.0 && ptf
[0].Y
== 20.0 && ptf
[1].X
== 95.0 && ptf
[1].Y
== 45.0,
4960 "expected 45.0,20.0-95.0,45.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
4962 status
= GdipGetRegionHRgn(region100x100
, NULL
, &hrgn
);
4964 ret
= GetRgnBox(hrgn
, &rc
);
4965 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4966 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
4967 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
4970 status
= GdipGetRegionHRgn(region100x100
, graphics
, &hrgn
);
4972 ret
= GetRgnBox(hrgn
, &rc
);
4973 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
4974 ok(rc
.left
== 210 && rc
.top
== 420 && rc
.right
== 410 && rc
.bottom
== 820,
4975 "expected 210,420-410,820, got %s\n", wine_dbgstr_rect(&rc
));
4982 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
4984 ok(ptf
[0].X
== 100.0 && ptf
[0].Y
== 100.0 && ptf
[1].X
== 200.0 && ptf
[1].Y
== 200.0,
4985 "expected 100.0,100.0-200.0,200.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
4987 GdipSetPageUnit(graphics
, UnitPoint
);
4990 status
= GdipGetClipBounds(graphics
, &rect
);
4992 ok((rect
.X
== 13.75 && rect
.Y
== 4.375 && rect
.Width
== 18.75 && rect
.Height
== 9.375) ||
4993 /* rounding under Wine is slightly different */
4994 (rect
.X
== 14.0 && rect
.Y
== 4.0 && rect
.Width
== 19.0 && rect
.Height
== 10.0) /* Wine */ ||
4995 broken(rect
.X
== 45.0 && rect
.Y
== 20.0 && rect
.Width
== 50.0 && rect
.Height
== 25.0) /* before Win7 */,
4996 "expected 13.75,4.375-18.75,9.375, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
4998 status
= GdipSetEmpty(region
);
5000 status
= GdipGetClip(graphics
, region
);
5002 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
5004 ok((rect
.X
== 13.75 && rect
.Y
== 4.375 && rect
.Width
== 18.75 && rect
.Height
== 9.375) ||
5005 /* rounding under Wine is slightly different */
5006 (rect
.X
== 14.0 && rect
.Y
== 4.0 && rect
.Width
== 19.0 && rect
.Height
== 10.0) /* Wine */ ||
5007 broken(rect
.X
== 45.0 && rect
.Y
== 20.0 && rect
.Width
== 50.0 && rect
.Height
== 25.0) /* before Win7 */,
5008 "expected 13.75,4.375-18.75,9.375, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
5010 status
= GdipGetRegionBounds(region100x100
, graphics
, &rect
);
5012 ok(rect
.X
== 100.0 && rect
.Y
== 100.0 && rect
.Width
== 100.0 && rect
.Height
== 100.0,
5013 "expected 100.0,100.0-100.0,100.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
5015 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5017 ret
= GetRgnBox(hrgn
, &rc
);
5018 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5019 ok((rc
.left
== 14 && rc
.top
== 5 && rc
.right
== 33 && rc
.bottom
== 14) ||
5020 /* rounding under Wine is slightly different */
5021 (rc
.left
== 14 && rc
.top
== 4 && rc
.right
== 33 && rc
.bottom
== 14) /* Wine */ ||
5022 broken(rc
.left
== 45 && rc
.top
== 20 && rc
.right
== 95 && rc
.bottom
== 45) /* before Win7 */,
5023 "expected 14,5-33,14, got %s\n", wine_dbgstr_rect(&rc
));
5026 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5028 ret
= GetRgnBox(hrgn
, &rc
);
5029 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5030 ok((rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200) ||
5031 broken(rc
.left
== 267 && rc
.top
== 267 && rc
.right
== 534 && rc
.bottom
== 534) /* before Win7 */,
5032 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5039 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5041 ok((ptf
[0].X
== 13.75 && ptf
[0].Y
== 4.375 && ptf
[1].X
== 32.5 && ptf
[1].Y
== 13.75) ||
5042 broken(ptf
[0].X
== 45.0 && ptf
[0].Y
== 20.0 && ptf
[1].X
== 95.0 && ptf
[1].Y
== 45.0) /* before Win7 */,
5043 "expected 13.75,4.375-32.5,13.75, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
5045 status
= GdipGetRegionHRgn(region100x100
, NULL
, &hrgn
);
5047 ret
= GetRgnBox(hrgn
, &rc
);
5048 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5049 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5050 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5053 status
= GdipGetRegionHRgn(region100x100
, graphics
, &hrgn
);
5055 ret
= GetRgnBox(hrgn
, &rc
);
5056 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5057 ok((rc
.left
== 560 && rc
.top
== 1120 && rc
.right
== 1094 && rc
.bottom
== 2187) ||
5058 /* rounding under Wine is slightly different */
5059 (rc
.left
== 560 && rc
.top
== 1120 && rc
.right
== 1093 && rc
.bottom
== 2187) /* Wine */,
5060 "expected 560,1120-1094,2187, got %s\n", wine_dbgstr_rect(&rc
));
5067 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5069 if (fabs(ptf
[0].X
- 100.0) < 0.001)
5071 expectf(100.0, ptf
[0].X
);
5072 expectf(100.0, ptf
[0].Y
);
5073 expectf(200.125, ptf
[1].X
);
5074 expectf(200.03125, ptf
[1].Y
);
5076 else /* before Win7 */
5078 ok(broken(fabs(ptf
[0].X
- 275.0) < 0.001), "expected 275.0, got %f\n", ptf
[0].X
);
5079 ok(broken(fabs(ptf
[0].Y
- 275.0) < 0.001), "expected 275.0, got %f\n", ptf
[0].Y
);
5080 ok(broken(fabs(ptf
[1].X
- 542.0) < 0.001), "expected 542.0, got %f\n", ptf
[1].X
);
5081 ok(broken(fabs(ptf
[1].Y
- 541.75) < 0.001), "expected 541.75, got %f\n", ptf
[1].Y
);
5084 status
= GdipTransformRegion(region100x100
, matrix
);
5087 status
= GdipGetRegionBounds(region100x100
, graphics
, &rect
);
5089 ok(rect
.X
== 210.0 && rect
.Y
== 420.0 && rect
.Width
== 200.0 && rect
.Height
== 400.0,
5090 "expected 210.0,420.0-200.0,400.0, got %.2f,%.2f-%.2f,%.2f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
5092 status
= GdipGetRegionHRgn(region100x100
, NULL
, &hrgn
);
5094 ret
= GetRgnBox(hrgn
, &rc
);
5095 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5096 ok(rc
.left
== 210 && rc
.top
== 420 && rc
.right
== 410 && rc
.bottom
== 820,
5097 "expected 210,420-410,820, got %s\n", wine_dbgstr_rect(&rc
));
5100 status
= GdipGetRegionHRgn(region100x100
, graphics
, &hrgn
);
5102 ret
= GetRgnBox(hrgn
, &rc
);
5103 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5104 ok((rc
.left
== 1147 && rc
.top
== 4534 && rc
.right
== 2214 && rc
.bottom
== 8800) ||
5105 /* rounding under Wine is slightly different */
5106 (rc
.left
== 1147 && rc
.top
== 4533 && rc
.right
== 2213 && rc
.bottom
== 8800) /* Wine */,
5107 "expected 1147,4534-2214,8800, got %s\n", wine_dbgstr_rect(&rc
));
5114 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5116 if (fabs(ptf
[0].X
- 210.0625) < 0.001)
5118 expectf(210.0625, ptf
[0].X
);
5119 expectf(420.0625, ptf
[0].Y
);
5120 expectf(410.125, ptf
[1].X
);
5121 expectf(820.0, ptf
[1].Y
);
5123 else /* before Win7 */
5125 ok(broken(fabs(ptf
[0].X
- 568.5) < 0.001), "expected 568.5, got %f\n", ptf
[0].X
);
5126 ok(broken(fabs(ptf
[0].Y
- 1128.5) < 0.001), "expected 1128.5, got %f\n", ptf
[0].Y
);
5127 ok(broken(fabs(ptf
[1].X
- 1102.0) < 0.001), "expected 1102.0, got %f\n", ptf
[1].X
);
5128 ok(broken(fabs(ptf
[1].Y
- 2195.0) < 0.001), "expected 2195.0, got %f\n", ptf
[1].Y
);
5131 status
= GdipRotateMatrix(matrix
, 30.0, MatrixOrderAppend
);
5133 status
= GdipSetWorldTransform(graphics
, matrix
);
5136 status
= GdipGetClipBounds(graphics
, &rect
);
5138 expectf_(20.612978, rect
.X
, 1.0);
5139 expectf_(-6.256012, rect
.Y
, 1.5);
5140 expectf_(25.612978, rect
.Width
, 1.0);
5141 expectf_(12.806489, rect
.Height
, 1.0);
5143 status
= GdipSetEmpty(region
);
5145 status
= GdipGetClip(graphics
, region
);
5147 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
5149 /* rounding under Wine is slightly different */
5150 expectf_(20.612978, rect
.X
, 1.0);
5151 expectf_(-6.256012, rect
.Y
, 1.5);
5152 expectf_(25.612978, rect
.Width
, 1.0);
5153 expectf_(12.806489, rect
.Height
, 1.0);
5155 status
= GdipGetRegionBounds(region100x100
, graphics
, &rect
);
5157 ok(rect
.X
== 210.0 && rect
.Y
== 420.0 && rect
.Width
== 200.0 && rect
.Height
== 400.0,
5158 "expected 210.0,420.0-200.0,400.0, got %f,%f-%f,%f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
5160 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5162 ret
= GetRgnBox(hrgn
, &rc
);
5163 ok(ret
== COMPLEXREGION
, "expected COMPLEXREGION, got %d\n", ret
);
5164 ok((rc
.left
== 22 && rc
.top
== -6 && rc
.right
== 46 && rc
.bottom
== 7) ||
5165 /* rounding under Wine is slightly different */
5166 (rc
.left
== 21 && rc
.top
== -5 && rc
.right
== 46 && rc
.bottom
== 7) /* Wine */,
5167 "expected (22,-6)-(46,7), got %s\n", wine_dbgstr_rect(&rc
));
5170 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5172 ret
= GetRgnBox(hrgn
, &rc
);
5173 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5174 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5175 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5186 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 4);
5188 expectf(20.612978, ptf
[0].X
);
5189 expectf(-1.568512, ptf
[0].Y
);
5190 expectf(46.225956, ptf
[1].X
);
5191 expectf(1.862977, ptf
[1].Y
);
5192 expectf(36.850956, ptf
[2].X
);
5193 expectf(-6.256012, ptf
[2].Y
);
5194 expectf(29.987980, ptf
[3].X
);
5195 expectf(6.550478, ptf
[3].Y
);
5197 status
= GdipGetRegionHRgn(region100x100
, NULL
, &hrgn
);
5199 ret
= GetRgnBox(hrgn
, &rc
);
5200 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5201 ok(rc
.left
== 210 && rc
.top
== 420 && rc
.right
== 410 && rc
.bottom
== 820,
5202 "expected 210,420-410,820, got %s\n", wine_dbgstr_rect(&rc
));
5205 status
= GdipGetRegionHRgn(region100x100
, graphics
, &hrgn
);
5207 ret
= GetRgnBox(hrgn
, &rc
);
5208 ok(ret
== COMPLEXREGION
, "expected COMPLEXREGION, got %d\n", ret
);
5209 ok((rc
.left
== -3406 && rc
.top
== 4500 && rc
.right
== -350 && rc
.bottom
== 8728) ||
5210 /* rounding under Wine is slightly different */
5211 (rc
.left
== -3407 && rc
.top
== 4500 && rc
.right
== -350 && rc
.bottom
== 8728) /* Wine */,
5212 "expected (-3406,4500)-(-350,8728), got %s\n", wine_dbgstr_rect(&rc
));
5223 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 4);
5225 expectf(-136.190491, ptf
[0].X
);
5226 expectf(520.010742, ptf
[0].Y
);
5227 expectf(756.417175, ptf
[1].X
);
5228 expectf(720.031616, ptf
[1].Y
);
5229 expectf(360.042114, ptf
[2].X
);
5230 expectf(376.760742, ptf
[2].Y
);
5231 expectf(260.184570, ptf
[3].X
);
5232 expectf(863.281616, ptf
[3].Y
);
5234 status
= GdipRotateMatrix(matrix
, -90.0, MatrixOrderAppend
);
5236 status
= GdipSetWorldTransform(graphics
, matrix
);
5239 status
= GdipGetClipBounds(graphics
, &rect
);
5241 expectf_(-28.100956, rect
.X
, 1.0);
5242 expectf_(7.806488, rect
.Y
, 1.5);
5243 expectf_(25.612978, rect
.Width
, 1.0);
5244 expectf_(12.806489, rect
.Height
, 1.0);
5246 status
= GdipSetEmpty(region
);
5248 status
= GdipGetClip(graphics
, region
);
5250 status
= GdipGetRegionBounds(region
, graphics
, &rect
);
5252 /* rounding under Wine is slightly different */
5253 expectf_(-28.100956, rect
.X
, 1.0);
5254 expectf_(7.806488, rect
.Y
, 1.5);
5255 expectf_(25.612978, rect
.Width
, 1.0);
5256 expectf_(12.806489, rect
.Height
, 1.0);
5258 status
= GdipGetRegionBounds(region100x100
, graphics
, &rect
);
5260 ok(rect
.X
== 210.0 && rect
.Y
== 420.0 && rect
.Width
== 200.0 && rect
.Height
== 400.0,
5261 "expected 210.0,420.0-200.0,400.0, got %f,%f-%f,%f\n", rect
.X
, rect
.Y
, rect
.Width
, rect
.Height
);
5263 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5265 ret
= GetRgnBox(hrgn
, &rc
);
5266 ok(ret
== COMPLEXREGION
, "expected COMPLEXREGION, got %d\n", ret
);
5267 ok((rc
.left
== -27 && rc
.top
== 8 && rc
.right
== -2 && rc
.bottom
== 21) ||
5268 /* rounding under Wine is slightly different */
5269 (rc
.left
== -28 && rc
.top
== 9 && rc
.right
== -2 && rc
.bottom
== 21) /* Wine */,
5270 "expected (-27,8)-(-2,21), got %s\n", wine_dbgstr_rect(&rc
));
5273 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5275 ret
= GetRgnBox(hrgn
, &rc
);
5276 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5277 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5278 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5289 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 4);
5291 expectf(-11.862979, ptf
[0].X
);
5292 expectf(7.806488, ptf
[0].Y
);
5293 expectf(-18.725958, ptf
[1].X
);
5294 expectf(20.612976, ptf
[1].Y
);
5295 expectf(-2.487981, ptf
[2].X
);
5296 expectf(15.925477, ptf
[2].Y
);
5297 expectf(-28.100956, ptf
[3].X
);
5298 expectf(12.493987, ptf
[3].Y
);
5300 status
= GdipGetRegionHRgn(region100x100
, NULL
, &hrgn
);
5302 ret
= GetRgnBox(hrgn
, &rc
);
5303 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5304 ok(rc
.left
== 210 && rc
.top
== 420 && rc
.right
== 410 && rc
.bottom
== 820,
5305 "expected 210,420-410,820, got %s\n", wine_dbgstr_rect(&rc
));
5308 status
= GdipGetRegionHRgn(region100x100
, graphics
, &hrgn
);
5310 ret
= GetRgnBox(hrgn
, &rc
);
5311 ok(ret
== COMPLEXREGION
, "expected COMPLEXREGION, got %d\n", ret
);
5312 ok((rc
.left
== 4500 && rc
.top
== 351 && rc
.right
== 8728 && rc
.bottom
== 3407) ||
5313 /* rounding under Wine is slightly different */
5314 (rc
.left
== 4499 && rc
.top
== 351 && rc
.right
== 8728 && rc
.bottom
== 3407) /* Wine */,
5315 "expected (4500,351)-(8728,3407), got %s\n", wine_dbgstr_rect(&rc
));
5326 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 4);
5328 expectf(-1055.021484, ptf
[0].X
);
5329 expectf(-70.595329, ptf
[0].Y
);
5330 expectf(-1455.063232, ptf
[1].X
);
5331 expectf(375.708435, ptf
[1].Y
);
5332 expectf(-768.521484, ptf
[2].X
);
5333 expectf(177.520981, ptf
[2].Y
);
5334 expectf(-1741.563110, ptf
[3].X
);
5335 expectf(127.592125, ptf
[3].Y
);
5337 GdipDeleteMatrix(matrix
);
5338 GdipDeleteRegion(region
);
5339 GdipDeleteRegion(region100x100
);
5340 GdipDeleteGraphics(graphics
);
5344 static void test_clipping_2(void)
5349 GpGraphics
*graphics
;
5359 hdc
= CreateCompatibleDC(0);
5360 status
= GdipCreateFromHDC(hdc
, &graphics
);
5363 status
= GdipGetPageUnit(graphics
, &unit
);
5365 expect(UnitDisplay
, unit
);
5367 GdipSetPageUnit(graphics
, UnitInch
);
5369 status
= GdipCreateRegion(®ion
);
5371 status
= GdipSetEmpty(region
);
5373 rect
.X
= rect
.Y
= 100.0;
5374 rect
.Width
= rect
.Height
= 100.0;
5375 status
= GdipCombineRegionRect(region
, &rect
, CombineModeUnion
);
5377 status
= GdipSetClipRegion(graphics
, region
, CombineModeReplace
);
5380 status
= GdipGetClip(graphics
, region
);
5382 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5384 ret
= GetRgnBox(hrgn
, &rc
);
5385 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5386 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5387 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5389 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5391 ret
= GetRgnBox(hrgn
, &rc
);
5392 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5393 ok(rc
.left
== 9600 && rc
.top
== 9600 && rc
.right
== 19200 && rc
.bottom
== 19200,
5394 "expected 9600,9600-19200,19200, got %s\n", wine_dbgstr_rect(&rc
));
5401 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5403 expectf(100.0, ptf
[0].X
);
5404 expectf(100.0, ptf
[0].Y
);
5405 expectf(200.0, ptf
[1].X
);
5406 expectf(200.0, ptf
[1].X
);
5408 GdipSetPageUnit(graphics
, UnitPoint
);
5410 status
= GdipGetClip(graphics
, region
);
5412 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5414 ret
= GetRgnBox(hrgn
, &rc
);
5415 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5416 ok((rc
.left
== 7200 && rc
.top
== 7200 && rc
.right
== 14400 && rc
.bottom
== 14400) ||
5417 broken(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200) /* before Win7 */,
5418 "expected 7200,7200-14400,14400, got %s\n", wine_dbgstr_rect(&rc
));
5420 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5422 ret
= GetRgnBox(hrgn
, &rc
);
5423 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5424 ok((rc
.left
== 9600 && rc
.top
== 9600 && rc
.right
== 19200 && rc
.bottom
== 19200) ||
5425 broken(rc
.left
== 134 && rc
.top
== 134 && rc
.right
== 267 && rc
.bottom
== 267) /* before Win7 */,
5426 "expected 9600,9600-19200,19200, got %s\n", wine_dbgstr_rect(&rc
));
5433 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5435 if (fabs(ptf
[0].X
- 7200.0) < 0.001)
5436 ok(ptf
[0].X
== 7200.0 && ptf
[0].Y
== 7200.0 && ptf
[1].X
== 14400.0 && ptf
[1].Y
== 14400.0,
5437 "expected 7200.0,7200.0-14400.0,14400.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
5438 else /* before Win7 */
5440 ok(broken(fabs(ptf
[0].X
- 100.0) < 0.001), "expected 100.0, got %f\n", ptf
[0].X
);
5441 ok(broken(fabs(ptf
[0].Y
- 100.0) < 0.001), "expected 100.0, got %f\n", ptf
[0].Y
);
5442 ok(broken(fabs(ptf
[1].X
- 200.0) < 0.001), "expected 200.0, got %f\n", ptf
[1].X
);
5443 ok(broken(fabs(ptf
[1].Y
- 200.0) < 0.001), "expected 200.0, got %f\n", ptf
[1].Y
);
5446 GdipDeleteRegion(region
);
5448 GdipSetPageUnit(graphics
, UnitPixel
);
5450 status
= GdipCreateRegion(®ion
);
5452 status
= GdipSetEmpty(region
);
5454 rect
.X
= rect
.Y
= 100.0;
5455 rect
.Width
= rect
.Height
= 100.0;
5456 status
= GdipCombineRegionRect(region
, &rect
, CombineModeUnion
);
5458 status
= GdipSetClipRegion(graphics
, region
, CombineModeReplace
);
5461 status
= GdipGetClip(graphics
, region
);
5463 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5465 ret
= GetRgnBox(hrgn
, &rc
);
5466 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5467 ok((rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200) ||
5468 broken(rc
.left
== 2 && rc
.top
== 2 && rc
.right
== 3 && rc
.bottom
== 3) /* before Win7 */,
5469 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5471 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5473 ret
= GetRgnBox(hrgn
, &rc
);
5474 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5475 ok((rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200) ||
5476 broken(rc
.left
== 2 && rc
.top
== 2 && rc
.right
== 3 && rc
.bottom
== 3) /* before Win7 */,
5477 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5484 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5486 if (fabs(ptf
[0].X
- 100.0) < 0.001)
5487 ok(ptf
[0].X
== 100.0 && ptf
[0].Y
== 100.0 && ptf
[1].X
== 200.0 && ptf
[1].Y
== 200.0,
5488 "expected 100.0,100.0-200.0,200.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
5489 else /* before Win7 */
5491 ok(broken(fabs(ptf
[0].X
- 1.041667) < 0.001), "expected 1.041667, got %f\n", ptf
[0].X
);
5492 ok(broken(fabs(ptf
[0].Y
- 1.041667) < 0.001), "expected 1.041667, got %f\n", ptf
[0].Y
);
5493 ok(broken(fabs(ptf
[1].X
- 2.083333) < 0.001), "expected 2.083333, got %f\n", ptf
[1].X
);
5494 ok(broken(fabs(ptf
[1].Y
- 2.083333) < 0.001), "expected 2.083333, got %f\n", ptf
[1].Y
);
5497 GdipSetPageUnit(graphics
, UnitPoint
);
5499 status
= GdipGetClip(graphics
, region
);
5501 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5503 ret
= GetRgnBox(hrgn
, &rc
);
5504 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5505 ok((rc
.left
== 75 && rc
.top
== 75 && rc
.right
== 150 && rc
.bottom
== 150) ||
5506 broken(rc
.left
== 2 && rc
.top
== 2 && rc
.right
== 3 && rc
.bottom
== 3) /* before Win7 */,
5507 "expected 75,75-150,150, got %s\n", wine_dbgstr_rect(&rc
));
5509 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5511 ret
= GetRgnBox(hrgn
, &rc
);
5512 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5513 ok((rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200) ||
5514 broken(rc
.left
== 2 && rc
.top
== 2 && rc
.right
== 3 && rc
.bottom
== 3) /* before Win7 */,
5515 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5522 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5524 if (fabs(ptf
[0].X
- 75.0) < 0.001)
5525 ok(ptf
[0].X
== 75.0 && ptf
[0].Y
== 75.0 && ptf
[1].X
== 150.0 && ptf
[1].Y
== 150.0,
5526 "expected 75.0,75.0-150.0,150.0, got %f,%f-%f,%f\n", ptf
[0].X
, ptf
[0].Y
, ptf
[1].X
, ptf
[1].Y
);
5527 else /* before Win7 */
5529 ok(broken(fabs(ptf
[0].X
- 1.041667) < 0.001), "expected 1.041667, got %f\n", ptf
[0].X
);
5530 ok(broken(fabs(ptf
[0].Y
- 1.041667) < 0.001), "expected 1.041667, got %f\n", ptf
[0].Y
);
5531 ok(broken(fabs(ptf
[1].X
- 2.083333) < 0.001), "expected 2.083333, got %f\n", ptf
[1].X
);
5532 ok(broken(fabs(ptf
[1].Y
- 2.083333) < 0.001), "expected 2.083333, got %f\n", ptf
[1].Y
);
5535 status
= GdipCreateMatrix(&matrix
);
5537 status
= GdipTranslateMatrix(matrix
, 10.0, 10.0, MatrixOrderAppend
);
5539 status
= GdipSetWorldTransform(graphics
, matrix
);
5541 GdipDeleteMatrix(matrix
);
5543 status
= GdipGetClip(graphics
, region
);
5545 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5547 ret
= GetRgnBox(hrgn
, &rc
);
5548 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5549 ok(rc
.left
== 65 && rc
.top
== 65 && rc
.right
== 140 && rc
.bottom
== 140,
5550 "expected 65,65-140,140, got %s\n", wine_dbgstr_rect(&rc
));
5552 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5554 ret
= GetRgnBox(hrgn
, &rc
);
5555 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5556 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5557 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5564 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5566 expectf(65.0, ptf
[0].X
);
5567 expectf(65.0, ptf
[0].Y
);
5568 expectf(140.0, ptf
[1].X
);
5569 expectf(140.0, ptf
[1].X
);
5571 status
= GdipCreateMatrix(&matrix
);
5573 status
= GdipScaleMatrix(matrix
, 0.25, 0.5, MatrixOrderAppend
);
5575 status
= GdipSetWorldTransform(graphics
, matrix
);
5577 GdipDeleteMatrix(matrix
);
5579 status
= GdipGetClip(graphics
, region
);
5581 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5583 ret
= GetRgnBox(hrgn
, &rc
);
5584 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5585 ok(rc
.left
== 300 && rc
.top
== 150 && rc
.right
== 600 && rc
.bottom
== 300,
5586 "expected 300,150-600,300, got %s\n", wine_dbgstr_rect(&rc
));
5588 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5590 ret
= GetRgnBox(hrgn
, &rc
);
5591 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5592 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5593 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5600 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5602 expectf(300.0, ptf
[0].X
);
5603 expectf(150.0, ptf
[0].Y
);
5604 expectf(600.0, ptf
[1].X
);
5605 expectf(300.0, ptf
[1].Y
);
5607 status
= GdipSetPageScale(graphics
, 2.0);
5610 status
= GdipGetClip(graphics
, region
);
5612 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5614 ret
= GetRgnBox(hrgn
, &rc
);
5615 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5616 ok((rc
.left
== 150 && rc
.top
== 75 && rc
.right
== 300 && rc
.bottom
== 150) ||
5617 broken(rc
.left
== 300 && rc
.top
== 150 && rc
.right
== 600 && rc
.bottom
== 300) /* before Win7 */,
5618 "expected 150,75-300,150, got %s\n", wine_dbgstr_rect(&rc
));
5620 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5622 ret
= GetRgnBox(hrgn
, &rc
);
5623 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5624 ok((rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200) ||
5625 broken(rc
.left
== 200 && rc
.top
== 200 && rc
.right
== 400 && rc
.bottom
== 400) /* before Win7 */,
5626 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5633 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 2);
5635 if (fabs(ptf
[0].X
- 150.0) < 0.001)
5637 expectf(150.0, ptf
[0].X
);
5638 expectf(75.0, ptf
[0].Y
);
5639 expectf(300.0, ptf
[1].X
);
5640 expectf(150.0, ptf
[1].Y
);
5642 else /* before Win7 */
5644 ok(broken(fabs(ptf
[0].X
- 300.0) < 0.001), "expected 300.0, got %f\n", ptf
[0].X
);
5645 ok(broken(fabs(ptf
[0].Y
- 150.0) < 0.001), "expected 150.0, got %f\n", ptf
[0].Y
);
5646 ok(broken(fabs(ptf
[1].X
- 600.0) < 0.001), "expected 600.0, got %f\n", ptf
[1].X
);
5647 ok(broken(fabs(ptf
[1].Y
- 300.0) < 0.001), "expected 300.0, got %f\n", ptf
[1].Y
);
5650 status
= GdipCreateMatrix(&matrix
);
5652 status
= GdipRotateMatrix(matrix
, 45.0, MatrixOrderAppend
);
5654 status
= GdipSetWorldTransform(graphics
, matrix
);
5656 GdipDeleteMatrix(matrix
);
5658 status
= GdipGetClip(graphics
, region
);
5660 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5662 ret
= GetRgnBox(hrgn
, &rc
);
5663 ok(ret
== COMPLEXREGION
, "expected COMPLEXREGION, got %d\n", ret
);
5664 ok((rc
.left
== 54 && rc
.top
== -26 && rc
.right
== 107 && rc
.bottom
== 27) ||
5665 /* rounding under Wine is slightly different */
5666 (rc
.left
== 53 && rc
.top
== -26 && rc
.right
== 106 && rc
.bottom
== 27) /* Wine */,
5667 "expected 54,-26-107,27, got %s\n", wine_dbgstr_rect(&rc
));
5669 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5671 ret
= GetRgnBox(hrgn
, &rc
);
5672 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5673 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5674 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5685 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 4);
5687 expectf(53.033016, ptf
[0].X
);
5688 expectf(0.0, ptf
[0].Y
);
5689 expectf(106.066032, ptf
[1].X
);
5690 expectf(0.0, ptf
[1].Y
);
5691 expectf(79.549522, ptf
[2].X
);
5692 expectf(-26.516510, ptf
[2].Y
);
5693 expectf(79.549522, ptf
[3].X
);
5694 expectf(26.516508, ptf
[3].Y
);
5696 status
= GdipCreateMatrix(&matrix
);
5698 status
= GdipRotateMatrix(matrix
, -45.0, MatrixOrderAppend
);
5700 status
= GdipSetWorldTransform(graphics
, matrix
);
5702 GdipDeleteMatrix(matrix
);
5704 status
= GdipGetClip(graphics
, region
);
5706 status
= GdipGetRegionHRgn(region
, NULL
, &hrgn
);
5708 ret
= GetRgnBox(hrgn
, &rc
);
5709 ok(ret
== COMPLEXREGION
, "expected COMPLEXREGION, got %d\n", ret
);
5710 ok((rc
.left
== -26 && rc
.top
== 54 && rc
.right
== 27 && rc
.bottom
== 107) ||
5711 /* rounding under Wine is slightly different */
5712 (rc
.left
== -27 && rc
.top
== 54 && rc
.right
== 27 && rc
.bottom
== 106) /* Wine */,
5713 "expected -26,54-27,107, got %s\n", wine_dbgstr_rect(&rc
));
5715 status
= GdipGetRegionHRgn(region
, graphics
, &hrgn
);
5717 ret
= GetRgnBox(hrgn
, &rc
);
5718 ok(ret
== SIMPLEREGION
, "expected SIMPLEREGION, got %d\n", ret
);
5719 ok(rc
.left
== 100 && rc
.top
== 100 && rc
.right
== 200 && rc
.bottom
== 200,
5720 "expected 100,100-200,200, got %s\n", wine_dbgstr_rect(&rc
));
5731 status
= GdipTransformPoints(graphics
, CoordinateSpaceWorld
, CoordinateSpaceDevice
, ptf
, 4);
5733 expectf(0.0, ptf
[0].X
);
5734 expectf(53.033005, ptf
[0].Y
);
5735 expectf(0.0, ptf
[1].X
);
5736 expectf(106.066010, ptf
[1].Y
);
5737 expectf(26.516491, ptf
[2].X
);
5738 expectf(79.549507, ptf
[2].Y
);
5739 expectf(-26.516520, ptf
[3].X
);
5740 expectf(79.549500, ptf
[3].Y
);
5742 GdipDeleteRegion(region
);
5743 GdipDeleteGraphics(graphics
);
5748 static void test_GdipFillRectangles(void)
5751 GpGraphics
*graphics
= NULL
;
5752 GpBrush
*brush
= NULL
;
5753 HDC hdc
= GetDC( hwnd
);
5754 GpRectF rects
[2] = {{0,0,10,10}, {10,10,10,10}};
5756 ok(hdc
!= NULL
, "Expected HDC to be initialized\n");
5758 status
= GdipCreateFromHDC(hdc
, &graphics
);
5760 ok(graphics
!= NULL
, "Expected graphics to be initialized\n");
5762 status
= GdipCreateSolidFill((ARGB
)0xffff00ff, (GpSolidFill
**)&brush
);
5764 ok(brush
!= NULL
, "Expected brush to be initialized\n");
5766 status
= GdipFillRectangles(NULL
, brush
, rects
, 2);
5767 expect(InvalidParameter
, status
);
5769 status
= GdipFillRectangles(graphics
, NULL
, rects
, 2);
5770 expect(InvalidParameter
, status
);
5772 status
= GdipFillRectangles(graphics
, brush
, NULL
, 2);
5773 expect(InvalidParameter
, status
);
5775 status
= GdipFillRectangles(graphics
, brush
, rects
, 0);
5776 expect(InvalidParameter
, status
);
5778 status
= GdipFillRectangles(graphics
, brush
, rects
, -1);
5779 expect(InvalidParameter
, status
);
5781 status
= GdipFillRectangles(graphics
, brush
, rects
, 1);
5784 status
= GdipFillRectangles(graphics
, brush
, rects
, 2);
5787 GdipDeleteBrush(brush
);
5788 GdipDeleteGraphics(graphics
);
5790 ReleaseDC(hwnd
, hdc
);
5793 static void test_GdipGetVisibleClipBounds_memoryDC(void)
5802 GpGraphics
* graphics
= NULL
;
5806 ok(GetClientRect(hwnd
, &rect
), "GetClientRect should have succeeded\n");
5807 width
= rect
.right
- rect
.left
;
5808 height
= rect
.bottom
- rect
.top
;
5811 hdc
= CreateCompatibleDC ( dc
);
5812 bmp
= CreateCompatibleBitmap ( dc
, width
, height
);
5813 old
= SelectObject (hdc
, bmp
);
5815 /*change the window origin is the key test point*/
5816 SetWindowOrgEx (hdc
, rect
.left
+10, rect
.top
+10, &pt
);
5818 status
= GdipCreateFromHDC(hdc
, &graphics
);
5821 status
= GdipGetVisibleClipBoundsI(graphics
, &boundRect
);
5824 ok(boundRect
.X
==rect
.left
+10 &&
5825 boundRect
.Y
==rect
.top
+10 &&
5826 boundRect
.Width
==width
&&
5827 boundRect
.Height
==height
, "Expected GdipGetVisibleClipBoundsI ok\n");
5829 status
= GdipSetClipRectI(graphics
, 0, 0, width
, height
, CombineModeReplace
);
5832 status
= GdipGetVisibleClipBoundsI(graphics
, &boundRect
);
5835 ok(boundRect
.X
==rect
.left
+10 &&
5836 boundRect
.Y
==rect
.top
+10 &&
5837 boundRect
.Width
==width
-10 &&
5838 boundRect
.Height
==height
-10, "Expected GdipGetVisibleClipBoundsI ok\n");
5840 GdipDeleteGraphics(graphics
);
5842 SelectObject (hdc
, old
);
5845 ReleaseDC(hwnd
, dc
);
5848 START_TEST(graphics
)
5850 struct GdiplusStartupInput gdiplusStartupInput
;
5851 ULONG_PTR gdiplusToken
;
5854 memset( &class, 0, sizeof(class) );
5855 class.lpszClassName
= "gdiplus_test";
5856 class.style
= CS_HREDRAW
| CS_VREDRAW
;
5857 class.lpfnWndProc
= DefWindowProcA
;
5858 class.hInstance
= GetModuleHandleA(0);
5859 class.hIcon
= LoadIconA(0, (LPCSTR
)IDI_APPLICATION
);
5860 class.hCursor
= LoadCursorA(0, (LPCSTR
)IDC_ARROW
);
5861 class.hbrBackground
= (HBRUSH
)(COLOR_WINDOW
+ 1);
5862 RegisterClassA( &class );
5863 hwnd
= CreateWindowA( "gdiplus_test", "graphics test", WS_OVERLAPPEDWINDOW
| WS_VISIBLE
,
5864 CW_USEDEFAULT
, CW_USEDEFAULT
, 200, 200, 0, 0, GetModuleHandleA(0), 0 );
5865 ok(hwnd
!= NULL
, "Expected window to be created\n");
5867 gdiplusStartupInput
.GdiplusVersion
= 1;
5868 gdiplusStartupInput
.DebugEventCallback
= NULL
;
5869 gdiplusStartupInput
.SuppressBackgroundThread
= 0;
5870 gdiplusStartupInput
.SuppressExternalCodecs
= 0;
5872 GdiplusStartup(&gdiplusToken
, &gdiplusStartupInput
, NULL
);
5876 test_measured_extra_space();
5877 test_measure_string();
5878 test_font_height_scaling();
5880 test_pen_thickness();
5881 test_GdipMeasureString();
5882 test_constructor_destructor();
5883 test_save_restore();
5884 test_GdipFillClosedCurve2();
5885 test_GdipFillClosedCurve2I();
5886 test_GdipDrawBezierI();
5888 test_GdipDrawArcI();
5889 test_GdipDrawCurve();
5890 test_GdipDrawCurveI();
5891 test_GdipDrawCurve2();
5892 test_GdipDrawCurve2I();
5893 test_GdipDrawCurve3();
5894 test_GdipDrawCurve3I();
5895 test_GdipDrawLineI();
5896 test_GdipDrawLinesI();
5897 test_GdipDrawImagePointsRect();
5898 test_GdipFillClosedCurve();
5899 test_GdipFillClosedCurveI();
5900 test_GdipDrawString();
5901 test_GdipGetNearestColor();
5902 test_GdipGetVisibleClipBounds();
5903 test_GdipIsVisiblePoint();
5904 test_GdipIsVisibleRect();
5905 test_Get_Release_DC();
5906 test_BeginContainer2();
5907 test_transformpoints();
5908 test_get_set_clip();
5911 test_textcontrast();
5912 test_fromMemoryBitmap();
5913 test_string_functions();
5914 test_get_set_interpolation();
5915 test_get_set_textrenderinghint();
5916 test_getdc_scaled();
5918 test_bitmapfromgraphics();
5919 test_GdipFillRectangles();
5920 test_GdipGetVisibleClipBounds_memoryDC();
5922 GdiplusShutdown(gdiplusToken
);
5923 DestroyWindow( hwnd
);