[gtk+/wip/colorchooser-v2: 47/77] color-swatch: allow styling the "active badge"
- From: Cosimo Cecchi <cosimoc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/colorchooser-v2: 47/77] color-swatch: allow styling the "active badge"
- Date: Thu, 9 Feb 2012 21:30:16 +0000 (UTC)
commit 7d0818d0c1f2768a7b6f117ae9b7b3a4b729e94c
Author: Cosimo Cecchi <cosimoc gnome org>
Date: Wed Feb 8 16:30:29 2012 -0500
color-swatch: allow styling the "active badge"
Instead of calling gtk_render_check() there, just render a symbolic
icon, falling back to a built-in one if the icon is not available.
Also, add a style class for the active badge on the swatch:
"color-active-badge".
gtk/gtkcolorswatch.c | 66 ++++++++++++++++++++++++++++++++++----------------
1 files changed, 45 insertions(+), 21 deletions(-)
---
diff --git a/gtk/gtkcolorswatch.c b/gtk/gtkcolorswatch.c
index cc7ccf9..884397f 100644
--- a/gtk/gtkcolorswatch.c
+++ b/gtk/gtkcolorswatch.c
@@ -113,8 +113,10 @@ swatch_draw (GtkWidget *widget,
gdouble width, height;
GtkStyleContext *context;
GtkStateFlags state;
- GdkRGBA bg;
+ GtkIconTheme *theme;
+ GtkIconInfo *icon_info = NULL;
+ theme = gtk_icon_theme_get_default ();
context = gtk_widget_get_style_context (widget);
state = gtk_widget_get_state_flags (widget);
width = gtk_widget_get_allocated_width (widget);
@@ -182,35 +184,57 @@ swatch_draw (GtkWidget *widget,
if (swatch->priv->icon)
{
- GdkPixbuf *pixbuf;
- GtkIconTheme *theme;
- theme = gtk_icon_theme_get_default ();
- pixbuf = gtk_icon_theme_load_icon (theme, "list-add-symbolic", 16,
- GTK_ICON_LOOKUP_GENERIC_FALLBACK
- | GTK_ICON_LOOKUP_USE_BUILTIN,
- NULL);
-
- gtk_render_icon (context, cr, pixbuf,
- (width - gdk_pixbuf_get_width (pixbuf)) / 2,
- (height - gdk_pixbuf_get_height (pixbuf)) / 2);
- g_object_unref (pixbuf);
+ icon_info = gtk_icon_theme_lookup_icon (theme, "list-add-symbolic", 16,
+ GTK_ICON_LOOKUP_GENERIC_FALLBACK
+ | GTK_ICON_LOOKUP_USE_BUILTIN);
}
- else if (swatch->priv->selected)
+ else if (swatch->priv->selected)
{
+ GdkRGBA bg, border;
+ GtkBorder border_width;
+ GIcon *gicon;
+
+ gtk_style_context_add_class (context, "color-active-badge");
gtk_style_context_get_background_color (context, state, &bg);
+ gtk_style_context_get_border_color (context, state, &border);
+ gtk_style_context_get_border (context, state, &border_width);
+
cairo_new_sub_path (cr);
cairo_arc (cr, width / 2, height / 2, 10, 0, 2 * G_PI);
cairo_close_path (cr);
gdk_cairo_set_source_rgba (cr, &bg);
cairo_fill_preserve (cr);
- if (INTENSITY (swatch->priv->color.red, swatch->priv->color.green, swatch->priv->color.blue) > 0.5)
- cairo_set_source_rgba (cr, 0., 0., 0., 0.4);
- else
- cairo_set_source_rgba (cr, 1., 1., 1., 0.4);
- cairo_set_line_width (cr, 2);
+
+ gdk_cairo_set_source_rgba (cr, &border);
+ cairo_set_line_width (cr, border_width.left);
cairo_stroke (cr);
- gtk_style_context_set_state (context, state | GTK_STATE_FLAG_ACTIVE);
- gtk_render_check (context, cr, width / 2 - 5, height / 2 - 5, 10, 10);
+
+ gicon = g_themed_icon_new ("object-select-symbolic");
+ /* fallback for themes that don't have object-select-symbolic */
+ g_themed_icon_append_name (G_THEMED_ICON (gicon), "gtk-apply");
+
+ icon_info = gtk_icon_theme_lookup_by_gicon (theme, gicon, 16,
+ GTK_ICON_LOOKUP_GENERIC_FALLBACK
+ | GTK_ICON_LOOKUP_USE_BUILTIN);
+ g_object_unref (gicon);
+ }
+
+ if (icon_info != NULL)
+ {
+ GdkPixbuf *pixbuf;
+
+ pixbuf = gtk_icon_info_load_symbolic_for_context (icon_info, context,
+ NULL, NULL);
+
+ if (pixbuf != NULL)
+ {
+ gtk_render_icon (context, cr, pixbuf,
+ (width - gdk_pixbuf_get_width (pixbuf)) / 2,
+ (height - gdk_pixbuf_get_height (pixbuf)) / 2);
+ g_object_unref (pixbuf);
+ }
+
+ gtk_icon_info_free (icon_info);
}
cairo_restore (cr);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]