css - 如何在 GTK Vala 中实现 CSS 样式?

标签 css import gtk vala

我正在尝试在 GTK 中为我的标签添加 CSS 样式,但我不知道如何设置文件。我目前在开头添加了一个包含,但出现此错误:

Include error

我也不知道我是否正确地实现了这个,这对 GTK 编程来说非常新。有人可以帮我正确设置它以实现 CSS 吗?

#include<gtk/gtk.h>
public class MyApp : Gtk.Application {

  public MyApp() {
        Object (
              application_id: "com.github.omerntosi.gtkHangman",
              flags: ApplicationFlags.FLAGS_NONE
        );
  }

  protected override void activate() {
        var main_window = new Gtk.ApplicationWindow(this);
        main_window.set_default_size(1000,800);
        main_window.title = "GTK Hangman";

        var grid = new Gtk.Grid();
        grid.orientation = Gtk.Orientation.VERTICAL;
        grid.row_spacing = 6;

        var topHalf = new Gtk.Grid();
        topHalf.orientation = Gtk.Orientation.HORIZONTAL;
        grid.row_spacing = 6;

        var man = new Gtk.Image();
        man.set_from_file("../src/img/placeholder-500x350.png");
        topHalf.add(man);

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

        var sol = new Gtk.Label("____ ______");
        sol.set_use_markup(true);
        topHalf.add(sol);

        grid.add(topHalf);
        main_window.add(grid);
        main_window.show_all();
  }

  public static int main(string[] args) {
        var app = new MyApp();
        return app.run(args);
  }
}

最佳答案

你在同一个文件中混合了 Vala 和 C,我已经将 C 部分翻译成 Vala:

  • 删除了 #include指令。
  • 将带有 Gtk.CssProvider 的 C 代码从 C 移植到 Vala

结果如下:

public class MyApp : Gtk.Application {

  public MyApp() {
        Object (
              application_id: "com.github.omerntosi.gtkHangman",
              flags: ApplicationFlags.FLAGS_NONE
        );
  }

  protected override void activate() {
        var main_window = new Gtk.ApplicationWindow(this);
        main_window.set_default_size(1000,800);
        main_window.title = "GTK Hangman";

        var grid = new Gtk.Grid();
        grid.orientation = Gtk.Orientation.VERTICAL;
        grid.row_spacing = 6;

        var topHalf = new Gtk.Grid();
        topHalf.orientation = Gtk.Orientation.HORIZONTAL;
        grid.row_spacing = 6;

        var man = new Gtk.Image();
        man.set_from_file("../src/img/placeholder-500x350.png");
        topHalf.add(man);

        Gtk.CssProvider css_provider = new Gtk.CssProvider ();
        css_provider.load_from_path ("style.css");
        Gtk.StyleContext.add_provider_for_screen (Gdk.Screen.get_default (), css_provider, Gtk.STYLE_PROVIDER_PRIORITY_USER);

        var sol = new Gtk.Label("____ ______");
        sol.set_use_markup(true);
        topHalf.add(sol);

        grid.add(topHalf);
        main_window.add(grid);
        main_window.show_all();
  }

  public static int main(string[] args) {
        var app = new MyApp();
        return app.run(args);
  }
}

--pkg gtk+-3.0 编译.这将修复有关缺少 gtk.h 等的编译器消息。如果没有,则您没有正确安装 GTK+ 3.0 header (apt-get install libgtk-3-dev 包)。

Vala 正在使用 pkg-config引擎盖下的工具将 CFLAGS 和 LDFLAGS 添加到将 Vala 源文件编译为二进制文件所采取的 C 编译步骤。

生成的 C 文件将自动具有 #include <gtk/gtk.h> , 因为它是在 vala 编译器附带的 gtk+-3.0.vapi 文件中指定的。

没有资源文件我无法测试它,但经过这些更改后它在这里编译得很好。

还有一个警告,因为代码没有捕捉到 GLib.Error某个地方,但你应该能够自己解决这个问题。

这里还有另一个关于如何在 Vala 中使用 CSS 的代码示例:

https://stackoverflow.com/a/28465993/426242

关于css - 如何在 GTK Vala 中实现 CSS 样式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49470281/

相关文章:

css calc 表达式未通过 w3cvalidator 验证并且在现实生活中也不起作用

swift - framework 的 "import"和 framework 的 "linking"有什么区别?

c - 如何使gtk的gtk_window_set_position起作用?

python - 如何用 pygtk 显示 MessageBox?

python - 为什么我自建的 PyGObject 在导入 Gtk 或 Gdk 时会出现段错误?

javascript - 拉伸(stretch) <img> 以适合整个屏幕,而不保持宽高比且没有滚动条

javascript - iPad 锁定方向为横向

javascript - 有人可以告诉我从字符串中删除特定内联 CSS 样式的最佳方法吗?

sql-server-2005 - 将 csv 文件导入 SQL Server Management Studio - 无可用表

javascript - 如何在 TypeScript 中导入 KnockOut 4?