]> Pileus Git - ~andy/gtk/blob - gtk/gtkcellarea.h
Distribute portions of GtkCellArea:render() background_area argument to cells
[~andy/gtk] / gtk / gtkcellarea.h
1 /* gtkcellarea.h
2  *
3  * Copyright (C) 2010 Openismus GmbH
4  *
5  * Authors:
6  *      Tristan Van Berkom <tristanvb@openismus.com>
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Library General Public
10  * License as published by the Free Software Foundation; either
11  * version 2 of the License, or (at your option) any later version.
12  *
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Library General Public License for more details.
17  *
18  * You should have received a copy of the GNU Library General Public
19  * License along with this library; if not, write to the
20  * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
21  * Boston, MA 02111-1307, USA.
22  */
23
24 #if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
25 #error "Only <gtk/gtk.h> can be included directly."
26 #endif
27
28 #ifndef __GTK_CELL_AREA_H__
29 #define __GTK_CELL_AREA_H__
30
31 #include <gtk/gtkcellrenderer.h>
32 #include <gtk/gtkwidget.h>
33 #include <gtk/gtktreemodel.h>
34
35 G_BEGIN_DECLS
36
37 #define GTK_TYPE_CELL_AREA                (gtk_cell_area_get_type ())
38 #define GTK_CELL_AREA(obj)                (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_CELL_AREA, GtkCellArea))
39 #define GTK_CELL_AREA_CLASS(klass)        (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_CELL_AREA, GtkCellAreaClass))
40 #define GTK_IS_CELL_AREA(obj)     (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_CELL_AREA))
41 #define GTK_IS_CELL_AREA_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_CELL_AREA))
42 #define GTK_CELL_AREA_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_CELL_AREA, GtkCellAreaClass))
43
44 typedef struct _GtkCellArea              GtkCellArea;
45 typedef struct _GtkCellAreaClass         GtkCellAreaClass;
46 typedef struct _GtkCellAreaPrivate       GtkCellAreaPrivate;
47 typedef struct _GtkCellAreaIter          GtkCellAreaIter;
48
49 /**
50  * GtkCellCallback:
51  * @renderer: the cell renderer to operate on
52  * @data: user-supplied data
53  *
54  * The type of the callback functions used for iterating over
55  * the cell renderers of a #GtkCellArea, see gtk_cell_area_forall().
56  */
57 typedef void    (*GtkCellCallback)     (GtkCellRenderer  *renderer,
58                                         gpointer          data);
59
60
61 struct _GtkCellArea
62 {
63   GInitiallyUnowned parent_instance;
64
65   GtkCellAreaPrivate *priv;
66 };
67
68 struct _GtkCellAreaClass
69 {
70   GInitiallyUnownedClass parent_class;
71
72   /* vtable - not signals */
73
74   /* Basic methods */
75   void               (* add)                             (GtkCellArea             *area,
76                                                           GtkCellRenderer         *renderer);
77   void               (* remove)                          (GtkCellArea             *area,
78                                                           GtkCellRenderer         *renderer);
79   void               (* forall)                          (GtkCellArea             *area,
80                                                           GtkCellCallback          callback,
81                                                           gpointer                 callback_data);
82   void               (* get_cell_allocation)             (GtkCellArea             *area,
83                                                           GtkCellAreaIter         *iter,
84                                                           GtkWidget               *widget,
85                                                           GtkCellRenderer         *renderer,
86                                                           const GdkRectangle      *cell_area,
87                                                           GdkRectangle            *allocation);
88   gint               (* event)                           (GtkCellArea             *area,
89                                                           GtkCellAreaIter         *iter,
90                                                           GtkWidget               *widget,
91                                                           GdkEvent                *event,
92                                                           const GdkRectangle      *cell_area,
93                                                           GtkCellRendererState     flags);
94   void               (* render)                          (GtkCellArea             *area,
95                                                           GtkCellAreaIter         *iter,
96                                                           GtkWidget               *widget,
97                                                           cairo_t                 *cr,
98                                                           const GdkRectangle      *background_area,
99                                                           const GdkRectangle      *cell_area,
100                                                           GtkCellRendererState     flags,
101                                                           gboolean                 paint_focus);
102
103   /* Geometry */
104   GtkCellAreaIter   *(* create_iter)                     (GtkCellArea             *area);
105   GtkSizeRequestMode (* get_request_mode)                (GtkCellArea             *area);
106   void               (* get_preferred_width)             (GtkCellArea             *area,
107                                                           GtkCellAreaIter         *iter,
108                                                           GtkWidget               *widget,
109                                                           gint                    *minimum_size,
110                                                           gint                    *natural_size);
111   void               (* get_preferred_height_for_width)  (GtkCellArea             *area,
112                                                           GtkCellAreaIter         *iter,
113                                                           GtkWidget               *widget,
114                                                           gint                     width,
115                                                           gint                    *minimum_height,
116                                                           gint                    *natural_height);
117   void               (* get_preferred_height)            (GtkCellArea             *area,
118                                                           GtkCellAreaIter         *iter,
119                                                           GtkWidget               *widget,
120                                                           gint                    *minimum_size,
121                                                           gint                    *natural_size);
122   void               (* get_preferred_width_for_height)  (GtkCellArea             *area,
123                                                           GtkCellAreaIter         *iter,
124                                                           GtkWidget               *widget,
125                                                           gint                     height,
126                                                           gint                    *minimum_width,
127                                                           gint                    *natural_width);
128
129   /* Cell Properties */
130   void               (* set_cell_property)               (GtkCellArea             *area,
131                                                           GtkCellRenderer         *renderer,
132                                                           guint                    property_id,
133                                                           const GValue            *value,
134                                                           GParamSpec              *pspec);
135   void               (* get_cell_property)               (GtkCellArea             *area,
136                                                           GtkCellRenderer         *renderer,
137                                                           guint                    property_id,
138                                                           GValue                  *value,
139                                                           GParamSpec              *pspec);
140
141   /* Focus */
142   gboolean           (* can_focus)                       (GtkCellArea             *area);
143   gboolean           (* focus)                           (GtkCellArea             *area,
144                                                           GtkDirectionType         direction);
145   gboolean           (* activate)                        (GtkCellArea             *area,
146                                                           GtkCellAreaIter         *iter,
147                                                           GtkWidget               *widget,
148                                                           const GdkRectangle      *cell_area,
149                                                           GtkCellRendererState     flags);
150
151
152   /* Padding for future expansion */
153   void (*_gtk_reserved1) (void);
154   void (*_gtk_reserved2) (void);
155   void (*_gtk_reserved3) (void);
156   void (*_gtk_reserved4) (void);
157   void (*_gtk_reserved5) (void);
158   void (*_gtk_reserved6) (void);
159   void (*_gtk_reserved7) (void);
160   void (*_gtk_reserved8) (void);
161 };
162
163 GType                 gtk_cell_area_get_type                       (void) G_GNUC_CONST;
164
165 /* Basic methods */
166 void                  gtk_cell_area_add                            (GtkCellArea          *area,
167                                                                     GtkCellRenderer      *renderer);
168 void                  gtk_cell_area_remove                         (GtkCellArea          *area,
169                                                                     GtkCellRenderer      *renderer);
170 gboolean              gtk_cell_area_has_renderer                   (GtkCellArea          *area,
171                                                                     GtkCellRenderer      *renderer);
172 void                  gtk_cell_area_forall                         (GtkCellArea          *area,
173                                                                     GtkCellCallback       callback,
174                                                                     gpointer              callback_data);
175 void                  gtk_cell_area_get_cell_allocation            (GtkCellArea          *area,
176                                                                     GtkCellAreaIter      *iter,
177                                                                     GtkWidget            *widget,
178                                                                     GtkCellRenderer      *renderer,
179                                                                     const GdkRectangle   *cell_area,
180                                                                     GdkRectangle         *allocation);
181 gint                  gtk_cell_area_event                          (GtkCellArea          *area,
182                                                                     GtkCellAreaIter      *iter,
183                                                                     GtkWidget            *widget,
184                                                                     GdkEvent             *event,
185                                                                     const GdkRectangle   *cell_area,
186                                                                     GtkCellRendererState  flags);
187 void                  gtk_cell_area_render                         (GtkCellArea          *area,
188                                                                     GtkCellAreaIter      *iter,
189                                                                     GtkWidget            *widget,
190                                                                     cairo_t              *cr,
191                                                                     const GdkRectangle   *background_area,
192                                                                     const GdkRectangle   *cell_area,
193                                                                     GtkCellRendererState  flags,
194                                                                     gboolean              paint_focus);
195 void                  gtk_cell_area_set_style_detail               (GtkCellArea          *area,
196                                                                     const gchar          *detail);
197 G_CONST_RETURN gchar *gtk_cell_area_get_style_detail               (GtkCellArea          *area);
198
199 /* Geometry */
200 GtkCellAreaIter      *gtk_cell_area_create_iter                    (GtkCellArea        *area);
201 GtkSizeRequestMode    gtk_cell_area_get_request_mode               (GtkCellArea        *area);
202 void                  gtk_cell_area_get_preferred_width            (GtkCellArea        *area,
203                                                                     GtkCellAreaIter    *iter,
204                                                                     GtkWidget          *widget,
205                                                                     gint               *minimum_size,
206                                                                     gint               *natural_size);
207 void                  gtk_cell_area_get_preferred_height_for_width (GtkCellArea        *area,
208                                                                     GtkCellAreaIter    *iter,
209                                                                     GtkWidget          *widget,
210                                                                     gint                width,
211                                                                     gint               *minimum_height,
212                                                                     gint               *natural_height);
213 void                  gtk_cell_area_get_preferred_height           (GtkCellArea        *area,
214                                                                     GtkCellAreaIter    *iter,
215                                                                     GtkWidget          *widget,
216                                                                     gint               *minimum_size,
217                                                                     gint               *natural_size);
218 void                  gtk_cell_area_get_preferred_width_for_height (GtkCellArea        *area,
219                                                                     GtkCellAreaIter    *iter,
220                                                                     GtkWidget          *widget,
221                                                                     gint                height,
222                                                                     gint               *minimum_width,
223                                                                     gint               *natural_width);
224 G_CONST_RETURN gchar *gtk_cell_area_get_current_path_string        (GtkCellArea        *area);
225
226
227 /* Attributes */
228 void                  gtk_cell_area_apply_attributes               (GtkCellArea        *area,
229                                                                     GtkTreeModel       *tree_model,
230                                                                     GtkTreeIter        *iter,
231                                                                     gboolean            is_expander,
232                                                                     gboolean            is_expanded);
233 void                  gtk_cell_area_attribute_connect              (GtkCellArea        *area,
234                                                                     GtkCellRenderer    *renderer,
235                                                                     const gchar        *attribute,
236                                                                     gint                column); 
237 void                  gtk_cell_area_attribute_disconnect           (GtkCellArea        *area,
238                                                                     GtkCellRenderer    *renderer,
239                                                                     const gchar        *attribute);
240
241 /* Cell Properties */
242 void                  gtk_cell_area_class_install_cell_property    (GtkCellAreaClass   *aclass,
243                                                                     guint               property_id,
244                                                                     GParamSpec         *pspec);
245 GParamSpec*           gtk_cell_area_class_find_cell_property       (GtkCellAreaClass   *aclass,
246                                                                     const gchar        *property_name);
247 GParamSpec**          gtk_cell_area_class_list_cell_properties     (GtkCellAreaClass   *aclass,
248                                                                     guint                   *n_properties);
249 void                  gtk_cell_area_add_with_properties            (GtkCellArea        *area,
250                                                                     GtkCellRenderer    *renderer,
251                                                                     const gchar     *first_prop_name,
252                                                                     ...) G_GNUC_NULL_TERMINATED;
253 void                  gtk_cell_area_cell_set                       (GtkCellArea        *area,
254                                                                     GtkCellRenderer    *renderer,
255                                                                     const gchar        *first_prop_name,
256                                                                     ...) G_GNUC_NULL_TERMINATED;
257 void                  gtk_cell_area_cell_get                       (GtkCellArea        *area,
258                                                                     GtkCellRenderer    *renderer,
259                                                                     const gchar        *first_prop_name,
260                                                                     ...) G_GNUC_NULL_TERMINATED;
261 void                  gtk_cell_area_cell_set_valist                (GtkCellArea        *area,
262                                                                     GtkCellRenderer    *renderer,
263                                                                     const gchar        *first_property_name,
264                                                                     va_list             var_args);
265 void                  gtk_cell_area_cell_get_valist                (GtkCellArea        *area,
266                                                                     GtkCellRenderer    *renderer,
267                                                                     const gchar        *first_property_name,
268                                                                     va_list             var_args);
269 void                  gtk_cell_area_cell_set_property              (GtkCellArea        *area,
270                                                                     GtkCellRenderer    *renderer,
271                                                                     const gchar        *property_name,
272                                                                     const GValue       *value);
273 void                  gtk_cell_area_cell_get_property              (GtkCellArea        *area,
274                                                                     GtkCellRenderer    *renderer,
275                                                                     const gchar        *property_name,
276                                                                     GValue             *value);
277
278 #define GTK_CELL_AREA_WARN_INVALID_CHILD_PROPERTY_ID(object, property_id, pspec) \
279   G_OBJECT_WARN_INVALID_PSPEC ((object), "cell property id", (property_id), (pspec))
280
281
282 /* Focus */
283 gboolean              gtk_cell_area_can_focus                      (GtkCellArea         *area);
284 gboolean              gtk_cell_area_focus                          (GtkCellArea         *area,
285                                                                     GtkDirectionType     direction);
286 gboolean              gtk_cell_area_activate                       (GtkCellArea         *area,
287                                                                     GtkCellAreaIter     *iter,
288                                                                     GtkWidget           *widget,
289                                                                     const GdkRectangle  *cell_area,
290                                                                     GtkCellRendererState flags);
291 void                  gtk_cell_area_set_focus_cell                 (GtkCellArea          *area,
292                                                                     GtkCellRenderer      *renderer);
293 GtkCellRenderer      *gtk_cell_area_get_focus_cell                 (GtkCellArea          *area);
294
295
296 /* Focus siblings */
297 void                  gtk_cell_area_add_focus_sibling              (GtkCellArea          *area,
298                                                                     GtkCellRenderer      *renderer,
299                                                                     GtkCellRenderer      *sibling);
300 void                  gtk_cell_area_remove_focus_sibling           (GtkCellArea          *area,
301                                                                     GtkCellRenderer      *renderer,
302                                                                     GtkCellRenderer      *sibling);
303 gboolean              gtk_cell_area_is_focus_sibling               (GtkCellArea          *area,
304                                                                     GtkCellRenderer      *renderer,
305                                                                     GtkCellRenderer      *sibling);
306 G_CONST_RETURN GList *gtk_cell_area_get_focus_siblings             (GtkCellArea          *area,
307                                                                     GtkCellRenderer      *renderer);
308 GtkCellRenderer      *gtk_cell_area_get_focus_from_sibling         (GtkCellArea          *area,
309                                                                     GtkCellRenderer      *renderer);
310
311 /* Cell Activation/Editing */
312 void                  gtk_cell_area_set_edited_cell                (GtkCellArea          *area,
313                                                                     GtkCellRenderer      *renderer);
314 GtkCellRenderer      *gtk_cell_area_get_edited_cell                (GtkCellArea          *area);
315 void                  gtk_cell_area_set_edit_widget                (GtkCellArea          *area,
316                                                                     GtkCellEditable      *editable);
317 GtkCellEditable      *gtk_cell_area_get_edit_widget                (GtkCellArea          *area);
318 gboolean              gtk_cell_area_activate_cell                  (GtkCellArea          *area,
319                                                                     GtkWidget            *widget,
320                                                                     GtkCellRenderer      *renderer,
321                                                                     GdkEvent             *event,
322                                                                     const GdkRectangle   *cell_area,
323                                                                     GtkCellRendererState  flags);
324 void                  gtk_cell_area_stop_editing                   (GtkCellArea          *area,
325                                                                     gboolean              canceled);
326
327 /* Margins */
328 gint                  gtk_cell_area_get_cell_margin_left           (GtkCellArea        *area);
329 void                  gtk_cell_area_set_cell_margin_left           (GtkCellArea        *area,
330                                                                     gint                margin);
331 gint                  gtk_cell_area_get_cell_margin_right          (GtkCellArea        *area);
332 void                  gtk_cell_area_set_cell_margin_right          (GtkCellArea        *area,
333                                                                     gint                margin);
334 gint                  gtk_cell_area_get_cell_margin_top            (GtkCellArea        *area);
335 void                  gtk_cell_area_set_cell_margin_top            (GtkCellArea        *area,
336                                                                     gint                margin);
337 gint                  gtk_cell_area_get_cell_margin_bottom         (GtkCellArea        *area);
338 void                  gtk_cell_area_set_cell_margin_bottom         (GtkCellArea        *area,
339                                                                     gint                margin);
340
341 /* Functions for area implementations */
342
343 /* Distinguish the inner cell area from the whole requested area including margins */
344 void                  gtk_cell_area_inner_cell_area                (GtkCellArea        *area,
345                                                                     const GdkRectangle *cell_area,
346                                                                     GdkRectangle       *inner_cell_area);
347
348 /* Request the size of a cell while respecting the cell margins (requests are margin inclusive) */
349 void                  gtk_cell_area_request_renderer               (GtkCellArea        *area,
350                                                                     GtkCellRenderer    *renderer,
351                                                                     GtkOrientation      orientation,
352                                                                     GtkWidget          *widget,
353                                                                     gint                for_size,
354                                                                     gint               *minimum_size,
355                                                                     gint               *natural_size);
356
357 G_END_DECLS
358
359 #endif /* __GTK_CELL_AREA_H__ */