Blame demos/conical-test.c

Packit 030a23
#include "../test/utils.h"
Packit 030a23
#include "gtk-utils.h"
Packit 030a23
Packit 030a23
#define SIZE 128
Packit 030a23
#define GRADIENTS_PER_ROW 7
Packit 030a23
#define NUM_ROWS ((NUM_GRADIENTS + GRADIENTS_PER_ROW - 1) / GRADIENTS_PER_ROW)
Packit 030a23
#define WIDTH (SIZE * GRADIENTS_PER_ROW)
Packit 030a23
#define HEIGHT (SIZE * NUM_ROWS)
Packit 030a23
#define NUM_GRADIENTS 35
Packit 030a23
Packit 030a23
#define double_to_color(x)					\
Packit 030a23
    (((uint32_t) ((x)*65536)) - (((uint32_t) ((x)*65536)) >> 16))
Packit 030a23
Packit 030a23
#define PIXMAN_STOP(offset,r,g,b,a)		\
Packit 030a23
    { pixman_double_to_fixed (offset),		\
Packit 030a23
	{					\
Packit 030a23
	    double_to_color (r),		\
Packit 030a23
		double_to_color (g),		\
Packit 030a23
		double_to_color (b),		\
Packit 030a23
		double_to_color (a)		\
Packit 030a23
	}					\
Packit 030a23
    }
Packit 030a23
Packit 030a23
Packit 030a23
static const pixman_gradient_stop_t stops[] = {
Packit 030a23
    PIXMAN_STOP (0.25,       1, 0, 0, 0.7),
Packit 030a23
    PIXMAN_STOP (0.5,        1, 1, 0, 0.7),
Packit 030a23
    PIXMAN_STOP (0.75,       0, 1, 0, 0.7),
Packit 030a23
    PIXMAN_STOP (1.0,        0, 0, 1, 0.7)
Packit 030a23
};
Packit 030a23
Packit 030a23
#define NUM_STOPS (sizeof (stops) / sizeof (stops[0]))
Packit 030a23
Packit 030a23
static pixman_image_t *
Packit 030a23
create_conical (int index)
Packit 030a23
{
Packit 030a23
    pixman_point_fixed_t c;
Packit 030a23
    double angle;
Packit 030a23
Packit 030a23
    c.x = pixman_double_to_fixed (0);
Packit 030a23
    c.y = pixman_double_to_fixed (0);
Packit 030a23
Packit 030a23
    angle = (0.5 / NUM_GRADIENTS + index / (double)NUM_GRADIENTS) * 720 - 180;
Packit 030a23
Packit 030a23
    return pixman_image_create_conical_gradient (
Packit 030a23
	&c, pixman_double_to_fixed (angle), stops, NUM_STOPS);
Packit 030a23
}
Packit 030a23
Packit 030a23
int
Packit 030a23
main (int argc, char **argv)
Packit 030a23
{
Packit 030a23
    pixman_transform_t transform;
Packit 030a23
    pixman_image_t *src_img, *dest_img;
Packit 030a23
    int i;
Packit 030a23
Packit 030a23
    enable_divbyzero_exceptions ();
Packit 030a23
Packit 030a23
    dest_img = pixman_image_create_bits (PIXMAN_a8r8g8b8,
Packit 030a23
					 WIDTH, HEIGHT,
Packit 030a23
					 NULL, 0);
Packit 030a23
 
Packit 030a23
    draw_checkerboard (dest_img, 25, 0xffaaaaaa, 0xff888888);
Packit 030a23
Packit 030a23
    pixman_transform_init_identity (&transform);
Packit 030a23
Packit 030a23
    pixman_transform_translate (NULL, &transform,
Packit 030a23
				pixman_double_to_fixed (0.5),
Packit 030a23
				pixman_double_to_fixed (0.5));
Packit 030a23
Packit 030a23
    pixman_transform_scale (NULL, &transform,
Packit 030a23
			    pixman_double_to_fixed (SIZE),
Packit 030a23
			    pixman_double_to_fixed (SIZE));
Packit 030a23
    pixman_transform_translate (NULL, &transform,
Packit 030a23
				pixman_double_to_fixed (0.5),
Packit 030a23
				pixman_double_to_fixed (0.5));
Packit 030a23
Packit 030a23
    for (i = 0; i < NUM_GRADIENTS; i++)
Packit 030a23
    {
Packit 030a23
	int column = i % GRADIENTS_PER_ROW;
Packit 030a23
	int row = i / GRADIENTS_PER_ROW;
Packit 030a23
Packit 030a23
	src_img = create_conical (i); 
Packit 030a23
	pixman_image_set_repeat (src_img, PIXMAN_REPEAT_NORMAL);
Packit 030a23
   
Packit 030a23
	pixman_image_set_transform (src_img, &transform);
Packit 030a23
	
Packit 030a23
	pixman_image_composite32 (
Packit 030a23
	    PIXMAN_OP_OVER, src_img, NULL,dest_img,
Packit 030a23
	    0, 0, 0, 0, column * SIZE, row * SIZE,
Packit 030a23
	    SIZE, SIZE);
Packit 030a23
	
Packit 030a23
	pixman_image_unref (src_img);
Packit 030a23
    }
Packit 030a23
Packit 030a23
    show_image (dest_img);
Packit 030a23
Packit 030a23
    pixman_image_unref (dest_img);
Packit 030a23
Packit 030a23
    return 0;
Packit 030a23
}