1 #include "../test/utils.h" 2 #include "gtk-utils.h" 3 4 #define SIZE 128 5 #define GRADIENTS_PER_ROW 7 6 #define NUM_ROWS ((NUM_GRADIENTS + GRADIENTS_PER_ROW - 1) / GRADIENTS_PER_ROW) 7 #define WIDTH (SIZE * GRADIENTS_PER_ROW) 8 #define HEIGHT (SIZE * NUM_ROWS) 9 #define NUM_GRADIENTS 35 10 11 #define double_to_color(x) \ 12 (((uint32_t) ((x)*65536)) - (((uint32_t) ((x)*65536)) >> 16)) 13 14 #define PIXMAN_STOP(offset,r,g,b,a) \ 15 { pixman_double_to_fixed (offset), \ 16 { \ 17 double_to_color (r), \ 18 double_to_color (g), \ 19 double_to_color (b), \ 20 double_to_color (a) \ 21 } \ 22 } 23 24 25 static const pixman_gradient_stop_t stops[] = { 26 PIXMAN_STOP (0.25, 1, 0, 0, 0.7), 27 PIXMAN_STOP (0.5, 1, 1, 0, 0.7), 28 PIXMAN_STOP (0.75, 0, 1, 0, 0.7), 29 PIXMAN_STOP (1.0, 0, 0, 1, 0.7) 30 }; 31 32 #define NUM_STOPS (sizeof (stops) / sizeof (stops[0])) 33 34 static pixman_image_t * 35 create_conical (int index) 36 { 37 pixman_point_fixed_t c; 38 double angle; 39 40 c.x = pixman_double_to_fixed (0); 41 c.y = pixman_double_to_fixed (0); 42 43 angle = (0.5 / NUM_GRADIENTS + index / (double)NUM_GRADIENTS) * 720 - 180; 44 45 return pixman_image_create_conical_gradient ( 46 &c, pixman_double_to_fixed (angle), stops, NUM_STOPS); 47 } 48 49 int 50 main (int argc, char **argv) 51 { 52 pixman_transform_t transform; 53 pixman_image_t *src_img, *dest_img; 54 int i; 55 56 enable_divbyzero_exceptions (); 57 58 dest_img = pixman_image_create_bits (PIXMAN_a8r8g8b8, 59 WIDTH, HEIGHT, 60 NULL, 0); 61 62 draw_checkerboard (dest_img, 25, 0xffaaaaaa, 0xff888888); 63 64 pixman_transform_init_identity (&transform); 65 66 pixman_transform_translate (NULL, &transform, 67 pixman_double_to_fixed (0.5), 68 pixman_double_to_fixed (0.5)); 69 70 pixman_transform_scale (NULL, &transform, 71 pixman_double_to_fixed (SIZE), 72 pixman_double_to_fixed (SIZE)); 73 pixman_transform_translate (NULL, &transform, 74 pixman_double_to_fixed (0.5), 75 pixman_double_to_fixed (0.5)); 76 77 for (i = 0; i < NUM_GRADIENTS; i++) 78 { 79 int column = i % GRADIENTS_PER_ROW; 80 int row = i / GRADIENTS_PER_ROW; 81 82 src_img = create_conical (i); 83 pixman_image_set_repeat (src_img, PIXMAN_REPEAT_NORMAL); 84 85 pixman_image_set_transform (src_img, &transform); 86 87 pixman_image_composite32 ( 88 PIXMAN_OP_OVER, src_img, NULL,dest_img, 89 0, 0, 0, 0, column * SIZE, row * SIZE, 90 SIZE, SIZE); 91 92 pixman_image_unref (src_img); 93 } 94 95 show_image (dest_img); 96 97 pixman_image_unref (dest_img); 98 99 return 0; 100 } 101