]> Pileus Git - ~andy/gtk/blob - gdk-pixbuf/gdk-pixbuf.c
Added translation to the rotate
[~andy/gtk] / gdk-pixbuf / gdk-pixbuf.c
1 /*
2  * gdk-pixbuf.c: Resource management.
3  *
4  * Authors:
5  *    Miguel de Icaza (miguel@gnu.org)
6  *    Mark Crichton (crichton@gimp.org)
7  */
8 #include <config.h>
9 #include <glib.h>
10 #include <math.h>
11 #include <libart_lgpl/art_misc.h>
12 #include <libart_lgpl/art_rgb_affine.h>
13 #include <libart_lgpl/art_alphagamma.h>
14 #include "gdk-pixbuf.h"
15
16
17 void
18 gdk_pixbuf_destroy (GdkPixBuf *pixbuf)
19 {
20      art_pixbuf_free (pixbuf->art_pixbuf);
21      g_free (pixbuf);
22 }
23
24 void
25 gdk_pixbuf_ref (GdkPixBuf *pixbuf)
26 {
27      g_return_if_fail (pixbuf != NULL);
28      
29      pixbuf->ref_count++;
30 }
31
32 void
33 gdk_pixbuf_unref (GdkPixBuf *pixbuf)
34 {
35     g_return_if_fail (pixbuf != NULL);
36     g_return_if_fail (pixbuf->ref_count == 0);
37     
38     pixbuf->ref_count--;
39     if (pixbuf->ref_count)
40         gdk_pixbuf_destroy (pixbuf);
41 }
42
43 GdkPixBuf *
44 gdk_pixbuf_scale (GdkPixBuf *pixbuf, gint w, gint h)
45 {
46     GdkPixBuf *spb;
47     art_u8 *pixels;
48     gint rowstride;
49     double affine[6];
50     ArtAlphaGamma *alphagamma;
51     ArtPixBuf *art_pixbuf = NULL;
52
53     alphagamma = NULL;
54
55     affine[1] = affine[2] = affine[4] = affine[5] = 0;
56     
57     
58     affine[0] = w / (double)(pixbuf->art_pixbuf->width);
59     affine[3] = h / (double)(pixbuf->art_pixbuf->height);
60
61     /*    rowstride = w * pixbuf->art_pixbuf->n_channels; */
62     rowstride = w * 3;
63
64     pixels = art_alloc (h * rowstride);
65     art_rgb_pixbuf_affine( pixels, 0, 0, w, h, rowstride,
66                            pixbuf->art_pixbuf,
67                            affine, ART_FILTER_NEAREST, alphagamma);
68
69     if (pixbuf->art_pixbuf->has_alpha)
70       /* should be rgba */
71       art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); 
72     else 
73       art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); 
74
75     art_pixbuf_free (pixbuf->art_pixbuf);
76     pixbuf->art_pixbuf = art_pixbuf;
77
78     return pixbuf;
79 }
80
81 GdkPixBuf *
82 gdk_pixbuf_rotate (GdkPixBuf *pixbuf, gdouble angle)
83 {
84      GdkPixBuf *rotate;
85      art_u8 *pixels;
86      gint rowstride, w, h;
87      gdouble rad;
88      double rot[6], trans[6], affine[6];
89      ArtAlphaGamma *alphagamma = NULL;
90      ArtPixBuf *art_pixbuf = NULL;
91
92      w = pixbuf->art_pixbuf->width;
93      h = pixbuf->art_pixbuf->height;
94
95      rad = (M_PI * angle / 180.0);
96
97      rot[0] = cos(rad);
98      rot[1] = sin(rad);
99      rot[2] = -sin(rad);
100      rot[3] = cos(rad);
101      rot[4] = rot[5] = 0;
102
103      trans[0] = trans[3] = 1;
104      trans[1] = trans[2] = 0;
105      trans[4] = (double)w / 2.0;
106      trans[5] = 0;
107
108      art_affine_multiply(affine, rot, trans);
109
110      g_print("Affine: %e %e %e %e %e %e\n", affine[0], affine[1], affine[2],
111              affine[3], affine[4], affine[5]);
112
113      /* rowstride = w * pixbuf->art_pixbuf->n_channels; */
114      rowstride = w * 3;
115
116      pixels = art_alloc (h * rowstride);
117      art_rgb_pixbuf_affine (pixels, 0, 0, w, h, rowstride,
118                             pixbuf->art_pixbuf,
119                             affine, ART_FILTER_NEAREST, alphagamma);
120      if (pixbuf->art_pixbuf->has_alpha)
121           /* should be rgba */
122           art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); 
123      else 
124           art_pixbuf = art_pixbuf_new_rgb(pixels, w, h, rowstride); 
125
126      art_pixbuf_free (pixbuf->art_pixbuf);
127      pixbuf->art_pixbuf = art_pixbuf;
128
129      return pixbuf;
130 }