pattern-getters.c 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279
  1. /* -*- Mode: c; c-basic-offset: 4; indent-tabs-mode: t; tab-width: 8; -*- */
  2. /*
  3. * Copyright © 2005 Mozilla Corporation, Inc.
  4. *
  5. * Permission to use, copy, modify, distribute, and sell this software
  6. * and its documentation for any purpose is hereby granted without
  7. * fee, provided that the above copyright notice appear in all copies
  8. * and that both that copyright notice and this permission notice
  9. * appear in supporting documentation, and that the name of
  10. * Mozilla Corporation not be used in advertising or publicity pertaining to
  11. * distribution of the software without specific, written prior
  12. * permission. Mozilla Corporation makes no representations about the
  13. * suitability of this software for any purpose. It is provided "as
  14. * is" without express or implied warranty.
  15. *
  16. * MOZILLA CORPORATION DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS
  17. * SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
  18. * FITNESS, IN NO EVENT SHALL MOZILLA CORPORATION BE LIABLE FOR ANY SPECIAL,
  19. * INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER
  20. * RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
  21. * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
  22. * IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  23. *
  24. * Author: Vladimir Vukicevic <vladimir@pobox.com>
  25. */
  26. #include "cairo-test.h"
  27. #include <stdlib.h>
  28. #define CHECK_SUCCESS do { \
  29. if (status) { \
  30. cairo_pattern_destroy (pat); \
  31. return cairo_test_status_from_status (ctx, status); \
  32. } \
  33. } while (0)
  34. static int
  35. double_buf_equal (const cairo_test_context_t *ctx, double *a, double *b, int nc)
  36. {
  37. int i;
  38. for (i = 0; i < nc; i++) {
  39. if (!CAIRO_TEST_DOUBLE_EQUALS(a[i],b[i])) {
  40. cairo_test_log (ctx, "Error: doubles not equal: %g, %g\n",
  41. a[i], b[i]);
  42. return 0;
  43. }
  44. }
  45. return 1;
  46. }
  47. static cairo_test_status_t
  48. draw (cairo_t *cr, int width, int height)
  49. {
  50. const cairo_test_context_t *ctx = cairo_test_get_context (cr);
  51. cairo_status_t status;
  52. cairo_pattern_t *pat;
  53. /* Test pattern_get_rgba */
  54. {
  55. double r, g, b, a;
  56. pat = cairo_pattern_create_rgba (0.2, 0.3, 0.4, 0.5);
  57. status = cairo_pattern_get_rgba (pat, &r, &g, &b, &a);
  58. CHECK_SUCCESS;
  59. if (!CAIRO_TEST_DOUBLE_EQUALS(r,0.2) ||
  60. !CAIRO_TEST_DOUBLE_EQUALS(g,0.3) ||
  61. !CAIRO_TEST_DOUBLE_EQUALS(b,0.4) ||
  62. !CAIRO_TEST_DOUBLE_EQUALS(a,0.5)) {
  63. cairo_test_log (ctx, "Error: cairo_pattern_get_rgba returned unexepcted results: %g, %g, %g, %g\n",
  64. r, g, b, a);
  65. cairo_pattern_destroy (pat);
  66. return CAIRO_TEST_FAILURE;
  67. }
  68. cairo_pattern_destroy (pat);
  69. }
  70. /* Test pattern_get_surface */
  71. {
  72. cairo_surface_t *surf;
  73. pat = cairo_pattern_create_for_surface (cairo_get_target (cr));
  74. status = cairo_pattern_get_surface (pat, &surf);
  75. CHECK_SUCCESS;
  76. if (surf != cairo_get_target (cr)) {
  77. cairo_test_log (ctx, "Error: cairo_pattern_get_resurface returned wrong surface\n");
  78. cairo_pattern_destroy (pat);
  79. return CAIRO_TEST_FAILURE;
  80. }
  81. cairo_pattern_destroy (pat);
  82. }
  83. /* Test get_color_stops & linear_get_points */
  84. {
  85. int i;
  86. double x0, y0, x1, y1;
  87. double expected_values[15] = { 0.0, 0.2, 0.4, 0.2, 1.0,
  88. 0.5, 0.4, 0.5, 0.2, 0.5,
  89. 1.0, 0.2, 0.4, 0.5, 0.2 };
  90. double new_buf[15];
  91. pat = cairo_pattern_create_linear (1.0, 2.0, 3.0, 4.0);
  92. for (i = 0; i < 3; i++) {
  93. cairo_pattern_add_color_stop_rgba (pat,
  94. expected_values[i*5+0],
  95. expected_values[i*5+1],
  96. expected_values[i*5+2],
  97. expected_values[i*5+3],
  98. expected_values[i*5+4]);
  99. }
  100. status = cairo_pattern_get_linear_points (pat, &x0, &y0, &x1, &y1);
  101. CHECK_SUCCESS;
  102. if (!CAIRO_TEST_DOUBLE_EQUALS(x0,1.0) ||
  103. !CAIRO_TEST_DOUBLE_EQUALS(y0,2.0) ||
  104. !CAIRO_TEST_DOUBLE_EQUALS(x1,3.0) ||
  105. !CAIRO_TEST_DOUBLE_EQUALS(y1,4.0))
  106. {
  107. cairo_pattern_destroy (pat);
  108. return CAIRO_TEST_FAILURE;
  109. }
  110. status = cairo_pattern_get_color_stop_count (pat, &i);
  111. CHECK_SUCCESS;
  112. if (i != 3) {
  113. cairo_pattern_destroy (pat);
  114. return CAIRO_TEST_FAILURE;
  115. }
  116. for (i = 0; i < 3; i++) {
  117. status = cairo_pattern_get_color_stop_rgba (pat, i,
  118. &new_buf[i*5+0],
  119. &new_buf[i*5+1],
  120. &new_buf[i*5+2],
  121. &new_buf[i*5+3],
  122. &new_buf[i*5+4]);
  123. CHECK_SUCCESS;
  124. }
  125. status = cairo_pattern_get_color_stop_rgba (pat, 5, NULL, NULL, NULL, NULL, NULL);
  126. if (status != CAIRO_STATUS_INVALID_INDEX) {
  127. cairo_pattern_destroy (pat);
  128. return CAIRO_TEST_FAILURE;
  129. }
  130. if (!double_buf_equal (ctx, new_buf, expected_values,
  131. ARRAY_LENGTH (expected_values)) != 0)
  132. {
  133. cairo_pattern_destroy (pat);
  134. return CAIRO_TEST_FAILURE;
  135. }
  136. cairo_pattern_destroy (pat);
  137. }
  138. /* Test radial_get_circles */
  139. {
  140. double a, b, c, d, e, f;
  141. pat = cairo_pattern_create_radial (1, 2, 3,
  142. 4, 5, 6);
  143. status = cairo_pattern_get_radial_circles (pat, &a, &b, &c, &d, &e, &f);
  144. CHECK_SUCCESS;
  145. if (!CAIRO_TEST_DOUBLE_EQUALS(a,1.0) ||
  146. !CAIRO_TEST_DOUBLE_EQUALS(b,2.0) ||
  147. !CAIRO_TEST_DOUBLE_EQUALS(c,3.0) ||
  148. !CAIRO_TEST_DOUBLE_EQUALS(d,4.0) ||
  149. !CAIRO_TEST_DOUBLE_EQUALS(e,5.0) ||
  150. !CAIRO_TEST_DOUBLE_EQUALS(f,6.0))
  151. {
  152. cairo_pattern_destroy (pat);
  153. return CAIRO_TEST_FAILURE;
  154. }
  155. cairo_pattern_destroy (pat);
  156. }
  157. /* Test mesh getters */
  158. {
  159. unsigned int count;
  160. int i;
  161. pat = cairo_pattern_create_mesh ();
  162. status = cairo_mesh_pattern_get_patch_count (pat, &count);
  163. CHECK_SUCCESS;
  164. if (count != 0) {
  165. cairo_pattern_destroy (pat);
  166. return CAIRO_TEST_FAILURE;
  167. }
  168. cairo_mesh_pattern_begin_patch (pat);
  169. cairo_mesh_pattern_move_to (pat, 0, 0);
  170. cairo_mesh_pattern_line_to (pat, 0, 3);
  171. cairo_mesh_pattern_line_to (pat, 3, 3);
  172. cairo_mesh_pattern_line_to (pat, 3, 0);
  173. status = cairo_mesh_pattern_get_patch_count (pat, &count);
  174. CHECK_SUCCESS;
  175. if (count != 0) {
  176. cairo_pattern_destroy (pat);
  177. return CAIRO_TEST_FAILURE;
  178. }
  179. cairo_mesh_pattern_end_patch (pat);
  180. status = cairo_mesh_pattern_get_patch_count (pat, &count);
  181. CHECK_SUCCESS;
  182. if (count != 1) {
  183. cairo_pattern_destroy (pat);
  184. return CAIRO_TEST_FAILURE;
  185. }
  186. for (i = 0; i < 4; i++) {
  187. double cp_x[4] = { 1, 1, 2, 2 };
  188. double cp_y[4] = { 1, 2, 2, 1 };
  189. double x, y;
  190. status = cairo_mesh_pattern_get_control_point (pat, 0, i, &x, &y);
  191. CHECK_SUCCESS;
  192. if (!CAIRO_TEST_DOUBLE_EQUALS(x,cp_x[i]) ||
  193. !CAIRO_TEST_DOUBLE_EQUALS(y,cp_y[i]))
  194. {
  195. cairo_pattern_destroy (pat);
  196. return CAIRO_TEST_FAILURE;
  197. }
  198. }
  199. cairo_mesh_pattern_begin_patch (pat);
  200. cairo_mesh_pattern_move_to (pat, 0, 0);
  201. cairo_mesh_pattern_line_to (pat, 1, 0);
  202. cairo_mesh_pattern_line_to (pat, 1, 1);
  203. cairo_mesh_pattern_set_corner_color_rgb (pat, 0, 1, 1, 1);
  204. cairo_mesh_pattern_end_patch (pat);
  205. for (i = 0; i < 4; i++) {
  206. double corner_color[4] = { 1, 0, 0, 1 };
  207. double a, r, g, b;
  208. status = cairo_mesh_pattern_get_corner_color_rgba (pat, 1, i,
  209. &r, &g, &b, &a);
  210. CHECK_SUCCESS;
  211. if (!CAIRO_TEST_DOUBLE_EQUALS(a,corner_color[i]) ||
  212. !CAIRO_TEST_DOUBLE_EQUALS(r,corner_color[i]) ||
  213. !CAIRO_TEST_DOUBLE_EQUALS(g,corner_color[i]) ||
  214. !CAIRO_TEST_DOUBLE_EQUALS(b,corner_color[i]))
  215. {
  216. cairo_pattern_destroy (pat);
  217. return CAIRO_TEST_FAILURE;
  218. }
  219. }
  220. cairo_pattern_destroy (pat);
  221. }
  222. cairo_set_source_rgb (cr, 0, 1, 0);
  223. cairo_paint (cr);
  224. return CAIRO_TEST_SUCCESS;
  225. }
  226. CAIRO_TEST (pattern_getters,
  227. "Tests calls to pattern getter functions",
  228. "pattern, api", /* keywords */
  229. NULL, /* requirements */
  230. 1, 1,
  231. NULL, draw)