Fri Mar 25 22:39:30 2005 John Ellis <johne@verizon.net>
[geeqie.git] / src / pixbuf-renderer.h
1 /*
2  * GQview
3  * (C) 2005 John Ellis
4  *
5  * Author: John Ellis
6  *
7  * This software is released under the GNU General Public License (GNU GPL).
8  * Please read the included file COPYING for more information.
9  * This software comes with no warranty of any kind, use at your own risk!
10  */
11
12 #ifndef PIXBUF_RENDERER_H
13 #define PIXBUF_RENDERER_H
14
15 #include <gtk/gtkeventbox.h>
16 #include <gtk/gtkwindow.h>
17
18
19 #define TYPE_PIXBUF_RENDERER            (pixbuf_renderer_get_type())
20 #define PIXBUF_RENDERER(obj)            (G_TYPE_CHECK_INSTANCE_CAST((obj), TYPE_PIXBUF_RENDERER, PixbufRenderer))
21 #define PIXBUF_RENDERER_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST((klass), TYPE_PIXBUF_RENDERER, PixbufRendererClass))
22 #define IS_PIXBUF_RENDERER(obj)         (G_TYPE_CHECK_INSTANCE_TYPE((obj), TYPE_PIXBUF_RENDERER))
23 #define IS_PIXBUF_RENDERER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), TYPE_PIXBUF_RENDERER))
24 #define PIXBUF_RENDERER_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS((obj), TYPE_PIXBUF_RENDERER, PixbufRendererClass))
25
26
27 typedef struct _PixbufRenderer PixbufRenderer;
28 typedef struct _PixbufRendererClass PixbufRendererClass;
29
30
31 typedef gint (* PixbufRendererTileRequestFunc)(PixbufRenderer *pr, gint x, gint y,
32                                                gint width, gint height, GdkPixbuf *pixbuf, gpointer user_data);
33 typedef void (* PixbufRendererTileDisposeFunc)(PixbufRenderer *pr, gint x, gint y,
34                                                gint width, gint height, GdkPixbuf *pixbuf, gpointer user_data);
35 typedef enum {
36         PR_SCROLL_RESET_TOPLEFT = 0,
37         PR_SCROLL_RESET_CENTER,
38         PR_SCROLL_RESET_NOCHANGE
39 } PixbufRendererScrollResetType;
40
41 struct _PixbufRenderer
42 {
43         GtkEventBox eventbox;
44
45         gint image_width;       /* image actual dimensions (pixels) */
46         gint image_height;
47
48         GdkPixbuf *pixbuf;
49
50         gint window_width;      /* allocated size of window (drawing area) */
51         gint window_height;
52
53         gint x_offset;          /* offset of image start (non-zero when image < window) */
54         gint y_offset;
55
56         gint vis_width;         /* dimensions of visible part of image */
57         gint vis_height;
58
59         gint width;             /* size of scaled image (result) */
60         gint height;
61
62         gint x_scroll;          /* scroll offset of image (into width, height to start drawing) */
63         gint y_scroll;
64
65         gdouble zoom_min;
66         gdouble zoom_max;
67         gdouble zoom;           /* zoom we want (0 is auto) */
68         gdouble scale;          /* zoom we got (should never be 0) */
69
70         GdkInterpType zoom_quality;
71         gboolean zoom_2pass;
72         gboolean zoom_expand;
73
74         GdkRgbDither dither_quality;
75
76         PixbufRendererScrollResetType scroll_reset;
77
78         gboolean has_frame;
79
80         GtkWidget *parent_window;       /* resize parent_window when image dimensions change */
81
82         gboolean window_fit;
83         gboolean window_limit;
84         gint window_limit_size;
85
86         gint tile_cache_max;            /* max mb to use for offscreen buffer */
87
88         /*< private >*/
89
90         gint tile_width;
91         gint tile_height;
92         gint tile_cols;         /* count of tile columns */
93         GList *tiles;           /* list of buffer tiles */
94         gint tile_cache_size;   /* allocated size of pixmaps/pixbufs */
95         GList *draw_queue;      /* list of areas to redraw */
96         GList *draw_queue_2pass;/* list when 2 pass is enabled */
97
98         gint draw_idle_id;
99         gint draw_idle_high;    /* current idle_id has high priority */
100
101         gboolean in_drag;
102         gint drag_last_x;
103         gint drag_last_y;
104         gint drag_moved;
105
106         gboolean source_tiles_enabled;
107         gint source_tiles_cache_size;
108
109         GList *source_tiles;    /* list of active source tiles */
110         gint source_tile_width;
111         gint source_tile_height;
112
113         PixbufRendererTileRequestFunc func_tile_request;
114         PixbufRendererTileDisposeFunc func_tile_dispose;
115
116         gpointer func_tile_data;
117
118         gboolean delay_flip;
119         gboolean loading;
120         gboolean complete;
121
122         gint scroller_id;
123         gint scroller_overlay;
124         gint scroller_x;
125         gint scroller_y;
126         gint scroller_xpos;
127         gint scroller_ypos;
128         gint scroller_xinc;
129         gint scroller_yinc;
130
131         GList *overlay_list;    
132 };
133
134 struct _PixbufRendererClass
135 {
136         GtkEventBoxClass parent_class;
137
138         void (* zoom)           (PixbufRenderer *pr, gdouble zoom);
139         void (* clicked)        (PixbufRenderer *pr, GdkEventButton *event);
140         void (* scroll_notify)  (PixbufRenderer *pr);
141
142         void (* render_complete)(PixbufRenderer *pr);
143 };
144
145
146 GType pixbuf_renderer_get_type (void);
147
148 PixbufRenderer *pixbuf_renderer_new(void);
149
150 void pixbuf_renderer_set_parent(PixbufRenderer *pr, GtkWindow *window);
151 GtkWindow *pixbuf_renderer_get_parent(PixbufRenderer *pr);
152
153 /* display a pixbuf */
154
155 void pixbuf_renderer_set_pixbuf(PixbufRenderer *pr, GdkPixbuf *pixbuf, gdouble zoom);
156 GdkPixbuf *pixbuf_renderer_get_pixbuf(PixbufRenderer *pr);
157
158 /* display an on-request array of pixbuf tiles */
159
160 void pixbuf_renderer_set_tiles(PixbufRenderer *pr, gint width, gint height,
161                                gint tile_width, gint tile_height, gint cache_size,
162                                PixbufRendererTileRequestFunc func_request,
163                                PixbufRendererTileDisposeFunc func_dispose,
164                                gpointer user_data,
165                                gdouble zoom);
166 gint pixbuf_renderer_get_tiles(PixbufRenderer *pr);
167
168 /* move image data from source to pr, source is then set to NULL image */
169
170 void pixbuf_renderer_move(PixbufRenderer *pr, PixbufRenderer *source);
171
172 /* update region of existing image */
173
174 void pixbuf_renderer_area_changed(PixbufRenderer *pr, gint x, gint y, gint width, gint height);
175
176 /* scrolling */
177
178 void pixbuf_renderer_scroll(PixbufRenderer *pr, gint x, gint y);
179 void pixbuf_renderer_scroll_to_point(PixbufRenderer *pr, gint x, gint y,
180                                      gdouble x_align, gdouble y_align);
181
182 /* zoom */
183
184 void pixbuf_renderer_zoom_adjust(PixbufRenderer *pr, gdouble increment);
185 void pixbuf_renderer_zoom_adjust_at_point(PixbufRenderer *pr, gdouble increment, gint x, gint y);
186
187 void pixbuf_renderer_zoom_set(PixbufRenderer *pr, gdouble zoom);
188 gdouble pixbuf_renderer_zoom_get(PixbufRenderer *pr);
189 gdouble pixbuf_renderer_zoom_get_scale(PixbufRenderer *pr);
190
191 void pixbuf_renderer_zoom_set_limits(PixbufRenderer *pr, gdouble min, gdouble max);
192
193 /* sizes */
194
195 gint pixbuf_renderer_get_image_size(PixbufRenderer *pr, gint *width, gint *height);
196 gint pixbuf_renderer_get_scaled_size(PixbufRenderer *pr, gint *width, gint *height);
197
198 /* region of image in pixel coordinates */
199 gint pixbuf_renderer_get_visible_rect(PixbufRenderer *pr, GdkRectangle *rect);
200
201 /* actual size of the PixbufRenderer window minus borders,
202  * x and y are the scroll offset and include zoom factor.
203  */
204 gint pixbuf_renderer_get_virtual_rect(PixbufRenderer *pr, GdkRectangle *rect);
205
206 /* background color */
207
208 void pixbuf_renderer_set_color(PixbufRenderer *pr, GdkColor *color);
209 void pixbuf_renderer_set_black(PixbufRenderer *pr, gint black);
210
211 /* overlay */
212
213 gint pixbuf_renderer_overlay_add(PixbufRenderer *pr, GdkPixbuf *pixbuf, gint x, gint y,
214                                  gint relative, gint always);
215 void pixbuf_renderer_overlay_set(PixbufRenderer *pr, gint id, GdkPixbuf *pixbuf, gint x, gint y);
216 gint pixbuf_renderer_overlay_get(PixbufRenderer *pr, gint id, GdkPixbuf **pixbuf, gint *x, gint *y);
217 void pixbuf_renderer_overlay_remove(PixbufRenderer *pr, gint id);
218
219
220 #endif
221