为什么 CSS 样式没有应用于 GTK+ 代码?
Why is CSS style not being applied to GTK+ code?
我开始摆弄 GTK+,直到我尝试修改旋转按钮小部件:
GTK+ change font to spin button
我不太明白答案,但我开始寻找 CSS 并尝试代码示例。最后,经过一些谷歌搜索和复制/粘贴代码,特别是从这里 ,这就是我在没有句法或其他错误的情况下设法做到的:
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;
}
如果有人编译上面的代码,会出现一个包含两个按钮的 window,根据 css 文件,一个按钮是时尚的。 然而,这两个按钮似乎都是默认样式,就好像 my_style.css 文件被忽略了一样。
如果有人能提供帮助,将不胜感激。
应用程序可以通过调用 gtk_css_provider_load_from_file() 或 gtk_css_provider_load_from_resource() 并使用 [=44= 添加提供者来使 GTK+ 解析特定的 CSS 样式 sheet ]() 或 gtk_style_context_add_provider_for_screen()。以下对象用于实现样式:
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',代码如下:
button {
background: #669999;
text-shadow: 1px 1px 5px black;
border-radius: 3px;
box-shadow: 0px 0px 5px black;
}
button:hover {
background: #3085a9;
}
这是供任何人在 2020 年进行搜索的摘要。可能有一个快捷方式,但它仅在我为每个按钮设置不同的提供程序和上下文时对我有用。将按钮添加到您的布局中以查看。
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
我开始摆弄 GTK+,直到我尝试修改旋转按钮小部件:
GTK+ change font to spin button
我不太明白答案,但我开始寻找 CSS 并尝试代码示例。最后,经过一些谷歌搜索和复制/粘贴代码,特别是从这里
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;
}
如果有人编译上面的代码,会出现一个包含两个按钮的 window,根据 css 文件,一个按钮是时尚的。 然而,这两个按钮似乎都是默认样式,就好像 my_style.css 文件被忽略了一样。
如果有人能提供帮助,将不胜感激。
应用程序可以通过调用 gtk_css_provider_load_from_file() 或 gtk_css_provider_load_from_resource() 并使用 [=44= 添加提供者来使 GTK+ 解析特定的 CSS 样式 sheet ]() 或 gtk_style_context_add_provider_for_screen()。以下对象用于实现样式:
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',代码如下:
button {
background: #669999;
text-shadow: 1px 1px 5px black;
border-radius: 3px;
box-shadow: 0px 0px 5px black;
}
button:hover {
background: #3085a9;
}
这是供任何人在 2020 年进行搜索的摘要。可能有一个快捷方式,但它仅在我为每个按钮设置不同的提供程序和上下文时对我有用。将按钮添加到您的布局中以查看。
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