-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test: check if cairo_in_fill() is reporting false positives for empty…
… trapezoids. cairo_in_fill() may report true if a query point lands on an edge of an empty trapezoid.
- Loading branch information
M Joonas Pihlaja
committed
Dec 6, 2006
1 parent
00d7b6a
commit e94e0a1
Showing
4 changed files
with
92 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
/* | ||
* Copyright © 2006 M Joonas Pihlaja | ||
* | ||
* Permission to use, copy, modify, distribute, and sell this software | ||
* and its documentation for any purpose is hereby granted without | ||
* fee, provided that the above copyright notice appear in all copies | ||
* and that both that copyright notice and this permission notice | ||
* appear in supporting documentation, and that the name of Joonas Pihlaja | ||
* not be used in advertising or publicity pertaining to distribution | ||
* of the software without specific, written prior permission. | ||
* Joonas Pihlaja makes no representations about the suitability of this | ||
* software for any purpose. It is provided "as is" without express | ||
* or implied warranty. | ||
* | ||
* JOONAS PIHLAJA DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, | ||
* INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN | ||
* NO EVENT SHALL JOONAS PIHLAJA BE LIABLE FOR ANY SPECIAL, INDIRECT OR | ||
* CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS | ||
* OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, | ||
* NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN | ||
* CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||
* | ||
* Author: M Joonas Pihlaja <jpihlaja@cc.helsinki.fi> | ||
*/ | ||
|
||
/* Bug history | ||
* | ||
* 2006-12-05 M Joonas Pihlaja <jpihlaja@cc.helsinki.fi> | ||
* | ||
* The cairo_in_fill () function can sometimes produce false | ||
* positives when the tessellator produces empty trapezoids | ||
* and the query point lands exactly on a trapezoid edge. | ||
*/ | ||
|
||
#include "cairo-test.h" | ||
|
||
static cairo_test_draw_function_t draw; | ||
|
||
cairo_test_t test = { | ||
"in-fill-empty-trapezoid", | ||
"Tests that the tessellator doesn't produce obviously empty trapezoids", | ||
10, 10, | ||
draw | ||
}; | ||
|
||
static cairo_test_status_t | ||
draw (cairo_t *cr_orig, int width, int height) | ||
{ | ||
int x,y; | ||
cairo_surface_t *surf = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, width, height); | ||
cairo_t *cr = cairo_create (surf); | ||
cairo_set_source_rgb (cr_orig, 1, 0, 0); | ||
|
||
/* Empty horizontal trapezoid. */ | ||
cairo_move_to (cr, 0, height/3); | ||
cairo_line_to (cr, width, height/3); | ||
cairo_close_path (cr); | ||
|
||
/* Empty non-horizontal trapezoid #1. */ | ||
cairo_move_to (cr, 0, 0); | ||
cairo_line_to (cr, width, height/2); | ||
cairo_close_path (cr); | ||
|
||
/* Empty non-horizontal trapezoid #2 intersecting #1. */ | ||
cairo_move_to (cr, 0, height/2); | ||
cairo_line_to (cr, width, 0); | ||
cairo_close_path (cr); | ||
|
||
/* Point sample the tessellated path. The x and y starting offsets | ||
* are chosen to hit the nasty bits while still being able to do a | ||
* relatively sparse sampling. */ | ||
for (y = 0; y < height; y++) { | ||
for (x = 0; x < width; x++) { | ||
if (cairo_in_fill (cr, x, y)) { | ||
cairo_rectangle(cr_orig, x, y, 1, 1); | ||
cairo_fill (cr_orig); | ||
} | ||
} | ||
} | ||
cairo_destroy (cr); | ||
cairo_surface_destroy (surf); | ||
return CAIRO_TEST_SUCCESS; | ||
} | ||
|
||
int | ||
main (void) | ||
{ | ||
return cairo_test (&test); | ||
} |