如何使用 css 代码单独设置 gtk 小部件的样式

问题描述 投票:0回答:1

在这个GTK+将字体更改为旋转按钮和这个为什么CSS样式没有应用于GTK+代码?问题之后,我开始了解如何将CSS样式应用于GTK代码,但仍然有很多令人困惑的细节.

这是我创建两个按钮和三个标签的代码:

测试.c

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

static void
activate (GtkApplication *app,
          gpointer        user_data)
{

  GtkWidget *window = gtk_application_window_new (app);;
  GtkWidget *button_01 = gtk_button_new_with_label("This is button 01");
  GtkWidget *button_02 = gtk_button_new_with_label("This is button 02");
  GtkWidget *label0 = gtk_label_new("hello 0");
  GtkWidget *label1 = gtk_label_new("hello 1");
  GtkWidget *label2 = gtk_label_new("hello 2");
  GtkWidget * main_box = gtk_box_new (GTK_ORIENTATION_VERTICAL, 25);

  GtkCssProvider *cssProvider = gtk_css_provider_new();
  gtk_css_provider_load_from_path(cssProvider, "theme.css", NULL);
  gtk_style_context_add_provider_for_screen(gdk_screen_get_default(),
                               GTK_STYLE_PROVIDER(cssProvider),
                               GTK_STYLE_PROVIDER_PRIORITY_USER);

  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), label0);
  gtk_container_add (GTK_CONTAINER (main_box), label1);
  gtk_container_add (GTK_CONTAINER (main_box), label2);
  gtk_container_add (GTK_CONTAINER (main_box), button_02);

  g_signal_connect(window, "destroy", G_CALLBACK(gtk_main_quit), NULL);
  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 文件:

主题.css

GtkWindow {
    font: Comic Sans 12
}

.button {
  color: green;
}

代码工作正常,因为所有字体都已更改并且所有按钮都是红色的。我想要做的是单独设置每个小部件的样式,例如使 label0 显示为红色,label1 显示为绿色,label 2 显示为蓝色。

根据这些示例GTK+ CSS概述:GTK+ 3参考手册,这应该可以解决问题:

label#label0 {
  color: red;
}
label#label1 {
  color: green;
}
label#label2 {
  color: blue;
}

但显然事实并非如此,这意味着我错过了那里的一些东西。

任何有关如何使用 css 代码单独设置小部件样式的帮助将不胜感激。

css c gtk gtk3
1个回答
13
投票

CSS 文件不知道您为程序中的变量指定的名称。您必须使用

gtk_widget_set_name()
来命名小部件。

© www.soinside.com 2019 - 2024. All rights reserved.