~ubuntu-branches/ubuntu/quantal/pixman/quantal-security

« back to all changes in this revision

Viewing changes to demos/clip-test.c

  • Committer: Bazaar Package Importer
  • Author(s): Cyril Brulebois
  • Date: 2011-04-29 17:53:12 UTC
  • mfrom: (1.4.2 upstream) (2.1.7 sid)
  • Revision ID: james.westby@ubuntu.com-20110429175312-2558yyetu8b762yk
Tags: 0.21.8-1
* New upstream release.
* As seen in the upstream announcement: “When this version of pixman is
  used with the git version of the X server, trapezoid rendering will be
  corrupted. This is a known bug in the X server.”
* This new release should fix the FTBFS on big endian machines, tests
  were failing due to missing swapping (Closes: #622211).

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
#include <stdio.h>
 
2
#include <stdlib.h>
 
3
#include "pixman.h"
 
4
#include "gtk-utils.h"
 
5
 
 
6
#define WIDTH 200
 
7
#define HEIGHT 200
 
8
    
 
9
static pixman_image_t *
 
10
create_solid_bits (uint32_t pixel)
 
11
{
 
12
    uint32_t *pixels = malloc (WIDTH * HEIGHT * 4);
 
13
    int i;
 
14
    
 
15
    for (i = 0; i < WIDTH * HEIGHT; ++i)
 
16
        pixels[i] = pixel;
 
17
 
 
18
    return pixman_image_create_bits (PIXMAN_a8r8g8b8,
 
19
                                     WIDTH, HEIGHT, 
 
20
                                     pixels,
 
21
                                     WIDTH * 4);
 
22
}
 
23
 
 
24
int
 
25
main (int argc, char **argv)
 
26
{
 
27
    pixman_image_t *gradient_img;
 
28
    pixman_image_t *src_img, *dst_img;
 
29
    pixman_gradient_stop_t stops[2] =
 
30
        {
 
31
            { pixman_int_to_fixed (0), { 0xffff, 0x0000, 0x0000, 0xffff } },
 
32
            { pixman_int_to_fixed (1), { 0xffff, 0xffff, 0x0000, 0xffff } }
 
33
        };
 
34
#if 0
 
35
    pixman_point_fixed_t p1 = { 0, 0 };
 
36
    pixman_point_fixed_t p2 = { pixman_int_to_fixed (WIDTH),
 
37
                                pixman_int_to_fixed (HEIGHT) };
 
38
#endif
 
39
    pixman_point_fixed_t c_inner;
 
40
    pixman_point_fixed_t c_outer;
 
41
    pixman_fixed_t r_inner;
 
42
    pixman_fixed_t r_outer;
 
43
    pixman_region32_t clip_region;
 
44
    pixman_transform_t trans = {
 
45
        { { pixman_double_to_fixed (1.3), pixman_double_to_fixed (0), pixman_double_to_fixed (-0.5), },
 
46
          { pixman_double_to_fixed (0), pixman_double_to_fixed (1), pixman_double_to_fixed (-0.5), },
 
47
          { pixman_double_to_fixed (0), pixman_double_to_fixed (0), pixman_double_to_fixed (1.0) } 
 
48
        }
 
49
    };
 
50
    
 
51
    src_img = create_solid_bits (0xff0000ff);
 
52
    
 
53
    c_inner.x = pixman_double_to_fixed (100.0);
 
54
    c_inner.y = pixman_double_to_fixed (100.0);
 
55
    c_outer.x = pixman_double_to_fixed (100.0);
 
56
    c_outer.y = pixman_double_to_fixed (100.0);
 
57
    r_inner = 0;
 
58
    r_outer = pixman_double_to_fixed (100.0);
 
59
    
 
60
    gradient_img = pixman_image_create_radial_gradient (&c_inner, &c_outer,
 
61
                                                        r_inner, r_outer,
 
62
                                                        stops, 2);
 
63
 
 
64
#if 0
 
65
    gradient_img = pixman_image_create_linear_gradient  (&p1, &p2,
 
66
                                                         stops, 2);
 
67
    
 
68
#endif
 
69
 
 
70
    pixman_image_composite (PIXMAN_OP_OVER, gradient_img, NULL, src_img,
 
71
                            0, 0, 0, 0, 0, 0, WIDTH, HEIGHT);
 
72
    
 
73
    pixman_region32_init_rect (&clip_region, 50, 0, 100, 200);
 
74
    pixman_image_set_clip_region32 (src_img, &clip_region);
 
75
    pixman_image_set_source_clipping (src_img, TRUE);
 
76
    pixman_image_set_has_client_clip (src_img, TRUE);
 
77
    pixman_image_set_transform (src_img, &trans);
 
78
    pixman_image_set_repeat (src_img, PIXMAN_REPEAT_NORMAL);
 
79
    
 
80
    dst_img = create_solid_bits (0xffff0000);
 
81
    pixman_image_composite (PIXMAN_OP_OVER, src_img, NULL, dst_img,
 
82
                            0, 0, 0, 0, 0, 0, WIDTH, HEIGHT);
 
83
    
 
84
 
 
85
#if 0
 
86
    printf ("0, 0: %x\n", src[0]);
 
87
    printf ("10, 10: %x\n", src[10 * 10 + 10]);
 
88
    printf ("w, h: %x\n", src[(HEIGHT - 1) * 100 + (WIDTH - 1)]);
 
89
#endif
 
90
    
 
91
    show_image (dst_img);
 
92
    
 
93
    pixman_image_unref (gradient_img);
 
94
    pixman_image_unref (src_img);
 
95
    
 
96
    return 0;
 
97
}