1 /* GTK - The GIMP Toolkit
2 * Copyright (C) 2010 Carlos Garnacho <carlosg@gnome.org>
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library. If not, see <http://www.gnu.org/licenses/>.
18 #if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
19 #error "Only <gtk/gtk.h> can be included directly."
22 #ifndef __GTK_THEMING_ENGINE_H__
23 #define __GTK_THEMING_ENGINE_H__
25 #include <glib-object.h>
28 #include <gtk/gtkstylecontext.h>
29 #include <gtk/gtkwidgetpath.h>
30 #include <gtk/gtkenums.h>
34 #define GTK_TYPE_THEMING_ENGINE (gtk_theming_engine_get_type ())
35 #define GTK_THEMING_ENGINE(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GTK_TYPE_THEMING_ENGINE, GtkThemingEngine))
36 #define GTK_THEMING_ENGINE_CLASS(c) (G_TYPE_CHECK_CLASS_CAST ((c), GTK_TYPE_THEMING_ENGINE, GtkThemingEngineClass))
37 #define GTK_IS_THEMING_ENGINE(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GTK_TYPE_THEMING_ENGINE))
38 #define GTK_IS_THEMING_ENGINE_CLASS(c) (G_TYPE_CHECK_CLASS_TYPE ((c), GTK_TYPE_THEMING_ENGINE))
39 #define GTK_THEMING_ENGINE_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GTK_TYPE_THEMING_ENGINE, GtkThemingEngineClass))
41 typedef struct _GtkThemingEngine GtkThemingEngine;
42 typedef struct GtkThemingEnginePrivate GtkThemingEnginePrivate;
43 typedef struct _GtkThemingEngineClass GtkThemingEngineClass;
45 struct _GtkThemingEngine
47 GObject parent_object;
48 GtkThemingEnginePrivate *priv;
52 * GtkThemingEngineClass
53 * @parent_class: The parent class.
54 * @render_line: Renders a line between two points.
55 * @render_background: Renders the background area of a widget region.
56 * @render_frame: Renders the frame around a widget area.
57 * @render_frame_gap: Renders the frame around a widget area with a gap in it.
58 * @render_extension: Renders a extension to a box, usually a notebook tab.
59 * @render_check: Renders a checkmark, as in #GtkCheckButton.
60 * @render_option: Renders an option, as in #GtkRadioButton.
61 * @render_arrow: Renders an arrow pointing to a certain direction.
62 * @render_expander: Renders an element what will expose/expand part of
63 * the UI, as in #GtkExpander.
64 * @render_focus: Renders the focus indicator.
65 * @render_layout: Renders a #PangoLayout
66 * @render_slider: Renders a slider control, as in #GtkScale.
67 * @render_handle: Renders a handle to drag UI elements, as in #GtkPaned.
68 * @render_activity: Renders an area displaying activity, such as in #GtkSpinner,
70 * @render_icon_pixbuf: Renders an icon as a #GdkPixbuf.
71 * @render_icon: Renders an icon given as a #GdkPixbuf.
73 * Base class for theming engines.
75 struct _GtkThemingEngineClass
77 GObjectClass parent_class;
79 void (* render_line) (GtkThemingEngine *engine,
85 void (* render_background) (GtkThemingEngine *engine,
91 void (* render_frame) (GtkThemingEngine *engine,
97 void (* render_frame_gap) (GtkThemingEngine *engine,
103 GtkPositionType gap_side,
106 void (* render_extension) (GtkThemingEngine *engine,
112 GtkPositionType gap_side);
113 void (* render_check) (GtkThemingEngine *engine,
119 void (* render_option) (GtkThemingEngine *engine,
125 void (* render_arrow) (GtkThemingEngine *engine,
131 void (* render_expander) (GtkThemingEngine *engine,
137 void (* render_focus) (GtkThemingEngine *engine,
143 void (* render_layout) (GtkThemingEngine *engine,
147 PangoLayout *layout);
148 void (* render_slider) (GtkThemingEngine *engine,
154 GtkOrientation orientation);
155 void (* render_handle) (GtkThemingEngine *engine,
161 void (* render_activity) (GtkThemingEngine *engine,
168 GdkPixbuf * (* render_icon_pixbuf) (GtkThemingEngine *engine,
169 const GtkIconSource *source,
171 void (* render_icon) (GtkThemingEngine *engine,
178 gpointer padding[15];
181 GType gtk_theming_engine_get_type (void) G_GNUC_CONST;
183 /* function implemented in gtkcsscustomproperty.c */
184 void gtk_theming_engine_register_property (const gchar *name_space,
185 GtkStylePropertyParser parse_func,
188 void gtk_theming_engine_get_property (GtkThemingEngine *engine,
189 const gchar *property,
192 void gtk_theming_engine_get_valist (GtkThemingEngine *engine,
195 void gtk_theming_engine_get (GtkThemingEngine *engine,
197 ...) G_GNUC_NULL_TERMINATED;
199 void gtk_theming_engine_get_style_property (GtkThemingEngine *engine,
200 const gchar *property_name,
202 void gtk_theming_engine_get_style_valist (GtkThemingEngine *engine,
204 void gtk_theming_engine_get_style (GtkThemingEngine *engine,
207 gboolean gtk_theming_engine_lookup_color (GtkThemingEngine *engine,
208 const gchar *color_name,
211 const GtkWidgetPath * gtk_theming_engine_get_path (GtkThemingEngine *engine);
213 gboolean gtk_theming_engine_has_class (GtkThemingEngine *engine,
214 const gchar *style_class);
215 gboolean gtk_theming_engine_has_region (GtkThemingEngine *engine,
216 const gchar *style_region,
217 GtkRegionFlags *flags);
219 GtkStateFlags gtk_theming_engine_get_state (GtkThemingEngine *engine);
220 gboolean gtk_theming_engine_state_is_running (GtkThemingEngine *engine,
224 GtkTextDirection gtk_theming_engine_get_direction (GtkThemingEngine *engine);
226 GtkJunctionSides gtk_theming_engine_get_junction_sides (GtkThemingEngine *engine);
228 /* Helper functions */
229 void gtk_theming_engine_get_color (GtkThemingEngine *engine,
232 void gtk_theming_engine_get_background_color (GtkThemingEngine *engine,
235 void gtk_theming_engine_get_border_color (GtkThemingEngine *engine,
239 void gtk_theming_engine_get_border (GtkThemingEngine *engine,
242 void gtk_theming_engine_get_padding (GtkThemingEngine *engine,
245 void gtk_theming_engine_get_margin (GtkThemingEngine *engine,
249 const PangoFontDescription * gtk_theming_engine_get_font (GtkThemingEngine *engine,
250 GtkStateFlags state);
252 GtkThemingEngine * gtk_theming_engine_load (const gchar *name);
254 GdkScreen * gtk_theming_engine_get_screen (GtkThemingEngine *engine);
258 #endif /* __GTK_THEMING_ENGINE_H__ */