[gtk+/gtk-style-context: 29/276] GtkThemingEngine: Add vmethod to render checkboxes.
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gtk-style-context: 29/276] GtkThemingEngine: Add vmethod to render checkboxes.
- Date: Sat, 23 Oct 2010 18:57:32 +0000 (UTC)
commit d25a20eddd3c2d1ec7c26a1b4b7261641fd212e7
Author: Carlos Garnacho <carlosg gnome org>
Date: Sat Mar 20 14:17:40 2010 +0100
GtkThemingEngine: Add vmethod to render checkboxes.
gtk/gtkthemingengine.c | 81 ++++++++++++++++++++++++++++++++++++++++++++++++
gtk/gtkthemingengine.h | 7 ++++
2 files changed, 88 insertions(+), 0 deletions(-)
---
diff --git a/gtk/gtkthemingengine.c b/gtk/gtkthemingengine.c
index a705f9f..82613ff 100644
--- a/gtk/gtkthemingengine.c
+++ b/gtk/gtkthemingengine.c
@@ -36,6 +36,13 @@ struct GtkThemingEnginePrivate
#define GTK_THEMING_ENGINE_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), GTK_TYPE_THEMING_ENGINE, GtkThemingEnginePrivate))
+static void gtk_theming_engine_render_check (GtkThemingEngine *engine,
+ cairo_t *cr,
+ gdouble x,
+ gdouble y,
+ gdouble width,
+ gdouble height);
+
G_DEFINE_TYPE (GtkThemingEngine, gtk_theming_engine, G_TYPE_OBJECT)
@@ -66,6 +73,8 @@ gtk_theming_engine_class_init (GtkThemingEngineClass *klass)
{
GObjectClass *object_class = G_OBJECT_CLASS (klass);
+ klass->render_check = gtk_theming_engine_render_check;
+
g_type_class_add_private (object_class, sizeof (GtkThemingEnginePrivate));
}
@@ -297,5 +306,77 @@ gtk_theming_engine_load (const gchar *name)
return engine;
}
+/* Paint method implementations */
+static void
+gtk_theming_engine_render_check (GtkThemingEngine *engine,
+ cairo_t *cr,
+ gdouble x,
+ gdouble y,
+ gdouble width,
+ gdouble height)
+{
+ GdkColor *fg_color, *base_color, *text_color;
+ const GtkWidgetPath *path;
+ GtkStateFlags flags;
+ GtkStateType state;
+
+ flags = gtk_theming_engine_get_state (engine);
+ path = gtk_theming_engine_get_path (engine);
+ cairo_save (cr);
+
+ if (flags & GTK_STATE_FLAG_PRELIGHT)
+ state = GTK_STATE_PRELIGHT;
+ else
+ state = GTK_STATE_NORMAL;
+
+ gtk_theming_engine_get (engine, state,
+ "foreground-color", &fg_color,
+ "base-color", &base_color,
+ "text-color", &text_color,
+ NULL);
+
+ if (!gtk_widget_path_has_parent (path, GTK_TYPE_MENU))
+ {
+ cairo_set_line_width (cr, 1);
+
+ cairo_rectangle (cr,
+ x + 0.5, y + 0.5,
+ width - 1, height - 1);
+
+ gdk_cairo_set_source_color (cr, base_color);
+ cairo_fill_preserve (cr);
+
+ if (gtk_widget_path_has_parent (path, GTK_TYPE_TREE_VIEW))
+ gdk_cairo_set_source_color (cr, text_color);
+ else
+ gdk_cairo_set_source_color (cr, fg_color);
+
+ cairo_stroke (cr);
+ }
+
+ cairo_set_line_width (cr, 1.5);
+ gdk_cairo_set_source_color (cr, text_color);
+
+ if (gtk_theming_engine_is_state_set (engine, GTK_STATE_INCONSISTENT))
+ {
+ cairo_move_to (cr, x + (width * 0.2), y + (height / 2));
+ cairo_line_to (cr, x + (width * 0.8), y + (height / 2));
+ }
+ else if (gtk_theming_engine_is_state_set (engine, GTK_STATE_ACTIVE))
+ {
+ cairo_move_to (cr, x + (width * 0.2), y + (height / 2));
+ cairo_line_to (cr, x + (width * 0.4), y + (height * 0.8));
+ cairo_line_to (cr, x + (width * 0.8), y + (height * 0.2));
+ }
+
+ cairo_stroke (cr);
+
+ cairo_restore (cr);
+
+ gdk_color_free (fg_color);
+ gdk_color_free (base_color);
+ gdk_color_free (text_color);
+}
+
#define __GTK_THEMING_ENGINE_C__
#include "gtkaliasdef.c"
diff --git a/gtk/gtkthemingengine.h b/gtk/gtkthemingengine.h
index b17c6e1..7bba3fb 100644
--- a/gtk/gtkthemingengine.h
+++ b/gtk/gtkthemingengine.h
@@ -48,6 +48,13 @@ struct GtkThemingEngine
struct GtkThemingEngineClass
{
GObjectClass parent_class;
+
+ void (* render_check) (GtkThemingEngine *engine,
+ cairo_t *cr,
+ gdouble x,
+ gdouble y,
+ gdouble width,
+ gdouble height);
};
GType gtk_theming_engine_get_type (void) G_GNUC_CONST;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]