自定义GTK小部件的背景呈现为纯黑色

时间:2012-09-03 13:54:52

标签: c gtk gtk3

我正在尝试在GTK 3中创建一个自定义小部件。我注意到绘图问题只出现在某些GTK主题中,而所有其他主题都很有效。我通过调用gtk_render_background()将问题缩小到绘制背景的代码。对于某些主题,背景以纯黑色呈现,但这不是主题的默认背景颜色。下面是我的绘图功能的简化版本。

static void gtk_databox_ruler_draw_ticks(GtkDataboxRuler *ruler)
{
    GtkWidget *widget;
    GtkStateFlags state;
    cairo_t *cr;
    GtkStyleContext *style_context;
    gint width, height;

    if (!gtk_widget_is_drawable(GTK_WIDGET(ruler))) {
        return;
    }

    widget = GTK_WIDGET(ruler);
    state = gtk_widget_get_state_flags(widget);
    style_context = gtk_widget_get_style_context(widget);

    gtk_style_context_save(style_context);
    gtk_style_context_add_class(style_context, GTK_STYLE_CLASS_DEFAULT);
    gtk_style_context_set_state(style_context, state);

    /* <test-code> */
    GdkRGBA test;
    gtk_style_context_get_background_color(style_context, gtk_widget_get_state_flags(widget), &test);
    /* </test-code> */

    width = gtk_widget_get_allocated_width(widget);
    height = gtk_widget_get_allocated_height(widget);

    cr = cairo_create(ruler->priv->backing_surface);

    gtk_render_background(style_context, cr, 0, 0, width, height);

    gtk_style_context_restore(style_context);
    cairo_destroy(cr);
}

我添加了一些测试代码来查询背景颜色并在gdb中设置断点:

使用Ubuntu的Ambiance主题时:

(gdb) print test
$1: test = {red = 0.94901960784313721, green = 0.94509803921568625, 
  blue = 0.94117647058823528, alpha = 1}

使用Ubuntu的HighContrast主题时:

(gdb) print test
$1: test = {red = 0, green = 0, blue = 0, alpha = 0}

我现在想知道我是否以错误的方式使用新的GtkStyleContext,或者主题是否被破坏。我怎样才能缩小问题的根源?

如果有人能指出我对GtkStyleContext的一个很好的介绍,我也很感激。官方API文档对于理解基本概念没有多大帮助。

3 个答案:

答案 0 :(得分:5)

经过一年多的时间,我不得不再次研究这个问题,因为当使用GTK3默认(内置)样式时也会发生这种情况,即当我的程序在没有主题等的系统上使用时。安装。

看起来问题的根源是某些GTK主题为“默认情况”定义背景颜色而其他主题没有。

GTK3 default theme

…
* {
  color: @fg_color;
  border-color: shade (@bg_color, 0.6);
  padding: 2px;
  -GtkWindow-resize-grip-width: 0;
  -GtkWindow-resize-grip-height: 0;
  -GtkWindow-decoration-button-layout: 'icon:minimize,maximize,close';
}

GtkWindow, .button, .slider {
  background-color: @bg_color;
}
…

Adwaita主题:

…
* {
    /* inherit the color from parent by default */
    color: inherit;
    background-color: @theme_bg_color;
}
…

要绘制背景,我只需选择一个在所有(大多数)主题中定义背景颜色的窗口小部件类。我使用按钮类:

gtk_style_context_add_class(style_context, GTK_STYLE_CLASS_BUTTON); 

答案 1 :(得分:2)

您使用的是什么版本的Ubuntu和GTK3?

也许您需要致电gtk_style_context_set_junction_sides()

您可能也对GTK的开发人员之一Benjamin Otte感兴趣。 How GTK styling works,也可以GTK+3 Styling

答案 2 :(得分:1)

这里的部分内容可能会越来越多,不一定会有一种背景颜色。

根据https://developer.gnome.org/gtk3/stable/GtkStyleContext.html#gtk-style-context-get-background-color的文档:

“这个函数远没有它看起来那么有用,它不应该用在新编写的代码中.CSS没有”背景颜色“的概念,因为背景可以是图像,渐变,或任何其他图案包括纯色。“