【问题标题】:Why is CSS style not being applied to GTK+ code?为什么 CSS 样式没有应用于 GTK+ 代码?
【发布时间】:2017-11-04 18:46:18
【问题描述】:

我开始摆弄 GTK+,直到我尝试修改一个旋转按钮小部件:

GTK+ change font to spin button

我不太明白答案,但我开始寻找 CSS 并尝试代码示例。最后,经过一些谷歌搜索和复制/粘贴代码,尤其是从这里 how to set a specific css class to a widget in gtk3? (c) ,这是我设法做到的,没有语法或其他错误:

test.c

#include <gtk/gtk.h>
#include <string.h>  

static void
activate (GtkApplication *app, gpointer user_data) {
  GtkStyleContext *context;
  GtkWidget *button_01;
  GtkWidget *button_02;
  button_01 = gtk_button_new_with_label("This is a simple button");
  button_02 = gtk_button_new_with_label("This is a stylish button");
  context = gtk_widget_get_style_context(button_02);
  gtk_style_context_add_class(context, "my_style");

  GtkWidget *window;
  GtkWidget * main_box;

  window = gtk_application_window_new (app);
  main_box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 25);

  gtk_box_set_homogeneous (GTK_BOX (main_box), TRUE);
  gtk_container_add (GTK_CONTAINER (window), main_box);
  gtk_container_add (GTK_CONTAINER (main_box), button_01);
  gtk_container_add (GTK_CONTAINER (main_box), button_02);

  gtk_widget_show_all (window);
}

int main (int argc, char **argv) {
  GtkApplication *app;
  int status;

  app = gtk_application_new ("org.gtk.example", G_APPLICATION_FLAGS_NONE);
  g_signal_connect (app, "activate", G_CALLBACK (activate), NULL);
  status = g_application_run (G_APPLICATION (app), argc, argv);
  g_object_unref (app);

  return status;
}

这是 CSS 文件:

my_style.css

.my_style{
    background: #669999;
    text-shadow: 1px 1px 5px black;
    border-radius: 3px;
    box-shadow: 0px 0px 5px black;
}

如果有人编译上面的代码,会出现一个包含两个按钮的窗口,根据 css 文件,一个按钮是时尚的。 然而,这两个按钮似乎都是默认样式,好像 my_style.css 文件被忽略了一样。

如果有人可以提供帮助,将不胜感激。

【问题讨论】:

  • 您的文件确实被忽略了,因为您没有指示您的程序加载它...
  • 查看 GtkStyleContextGtkCssProvider 以加载并添加到您的应用程序。
  • 我为 GTKSpinButton 制作了 9 个超过 4 小时的视频。 Starting with Tutorial 64

标签: css c gtk


【解决方案1】:

应用程序可以通过调用 gtk_css_provider_load_from_file() 或 gtk_css_provider_load_from_resource() 并使用 gtk_style_context_add_provider() 或 gtk_style_context_add_provider_for_screen() 来使 GTK+ 解析特定的 CSS 样式表。以下对象用于实现样式:

  • GtkStyleContext 是一个对象,用于存储影响由 GtkWidgetPath 定义的小部件的样式信息。为了构造最终的样式信息,GtkStyleContext 从所有附加的 GtkStyleProvider 中查询信息。

  • GtkCssProvider 是一个实现 GtkStyleProvider 接口的对象。 GtkStyleProvider 用于向 GtkStyleContext 提供样式信息

  • GtkCssProvider 是一个实现 GtkStyleProvider 接口的对象。它能够解析类似 CSS 的输入以设置小部件的样式。

更多信息https://developer.gnome.org/gtk3/stable/GtkCssProvider.html

代码如下:

#include <gtk/gtk.h>

static void
activate (GtkApplication *app, gpointer user_data) {
  GtkStyleContext *context;
  GtkWidget *button_01;
  GtkWidget *button_02;
  button_01 = gtk_button_new_with_label("This is a simple button");
  button_02 = gtk_button_new_with_label("This is a stylish button");

  context = gtk_widget_get_style_context (button_02);

  GtkCssProvider *provider = gtk_css_provider_new ();

  gtk_css_provider_load_from_path (provider,
    "my_style.css", NULL);

  GtkWidget *window;
  GtkWidget *box;

  window = gtk_application_window_new (app);
  box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 25);

  gtk_style_context_add_provider (context,
                                    GTK_STYLE_PROVIDER(provider),
                                    GTK_STYLE_PROVIDER_PRIORITY_USER);

  gtk_box_set_homogeneous (GTK_BOX (box), TRUE);
  gtk_container_add (GTK_CONTAINER (window), box);
  gtk_container_add (GTK_CONTAINER (box), button_01);
  gtk_container_add (GTK_CONTAINER (box), button_02);

  gtk_widget_show_all (window);
}

int main (int argc, char **argv) {
  GtkApplication *app;
  int status;

  app = gtk_application_new ("org.gtk.example", G_APPLICATION_FLAGS_NONE);
  g_signal_connect (app, "activate", G_CALLBACK (activate), NULL);
  status = g_application_run (G_APPLICATION (app), argc, argv);
  g_object_unref (app);

  return status;
}

CSS 选择器简称为“按钮”,代码如下:

button {
    background: #669999;
    text-shadow: 1px 1px 5px black;
    border-radius: 3px;
    box-shadow: 0px 0px 5px black;
}

button:hover {
  background: #3085a9;
}

【讨论】:

    【解决方案2】:

    对于 2020 年搜索的任何人来说,这是一个 sn-p。可能有一个快捷方式,但只有当我为每个按钮设置不同的提供程序和上下文时,它才对我有用。将按钮添加到您的布局中即可查看。

    GtkWidget *open, *plot, *save; //Buttons
    
    GtkStyleContext *openContext, *plotContext, *saveContext; //attach css to buttons
    
    GtkCssProvider *openProvider, *plotProvider, *saveProvider;//link to Css file
    
    //Initialize buttons
        open = gtk_button_new_with_label("open\n");
        plot = gtk_button_new_with_label("plot\n");
        save = gtk_button_new_with_label("save\n");
        //Initialize buttons
    
        //Initialize contexts
    openContext = gtk_widget_get_style_context(open);
    plotContext = gtk_widget_get_style_context(plot);
    saveContext = gtk_widget_get_style_context(save);
        //Initialize contexts
    
        //Initialize providers
    openProvider = gtk_css_provider_new();
    plotProvider = gtk_css_provider_new();
    saveProvider = gtk_css_provider_new();
        //Initialize providers
    //Add context providers and attach CSS
    gtk_style_context_add_provider(openContext, GTK_STYLE_PROVIDER(openProvider),                               GTK_STYLE_PROVIDER_PRIORITY_USER);
    
    gtk_style_context_add_provider(plotContext, GTK_STYLE_PROVIDER(plotProvider),                                   GTK_STYLE_PROVIDER_PRIORITY_USER);
    
    gtk_style_context_add_provider(saveContext, GTK_STYLE_PROVIDER(saveProvider),                                   GTK_STYLE_PROVIDER_PRIORITY_USER);
        
    gtk_style_context_add_class(openContext, "open");
    gtk_style_context_add_class(plotContext, "plot");
    gtk_style_context_add_class(saveContext, "save");
        //Add context providers and attach CSS
    
    
    //add buttons to your GTKgrid or whatever layout
    

    //这些是与我的程序在同一目录中的单独的 CSS 文件

    //openStyles.css
    .open{
      background: #669999;
        text-shadow: 1px 1px 5px black;
        border-radius: 3px;
        box-shadow: 0px 0px 5px black;
    }
    .open:hover{
      background: #889898;
        text-shadow: 1px 1px 5px black;
        border-radius: 3px;
        box-shadow: 0px 0px 5px black;
    }
    //openStyles.css
    
    //plotStyles.css
    .plot{
      background: #666699;
        text-shadow: 1px 1px 5px black;
        border-radius: 3px;
        box-shadow: 0px 0px 5px black;
    }
    .plot:hover{
      background: #889898;
        text-shadow: 1px 1px 5px black;
        border-radius: 3px;
        box-shadow: 0px 0px 5px black;
    }
    //plotStyles.css
    
    //saveStyles.css
    .save{
      background: #669999;
        text-shadow: 1px 1px 5px black;
        border-radius: 3px;
        box-shadow: 0px 0px 5px black;
    }
    .save:hover{
      background: #889898;
        text-shadow: 1px 1px 5px black;
        border-radius: 3px;
        box-shadow: 0px 0px 5px black;
    }
    //saveStyles.css
    

    【讨论】:

    • 不建议最终用户将样式提供程序添加到单个小部件,因为结果通常不是他们所期望的。是什么问题阻止您将其添加到默认屏幕/显示中?我可能猜想您正在尝试选择像 GtkLabel { [...] } 这样的小部件类型,但该语法已经过时,现在是 label { [...] } 或 C 小部件文档中记录的任何其他 CSS 节点/选择器。
    猜你喜欢
    • 1970-01-01
    • 2013-05-06
    • 2020-10-04
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-12-14
    • 1970-01-01
    • 2021-02-02
    相关资源
    最近更新 更多