赞
踩
auto refBuilder = Gtk::Builder::create_from_file("path/to/you/xml"); //或者干脆写一个函数 Glib::RefPtr<Gtk::Builder> BuilderInit() { // Load the GtkBuilder file and instantiate its widgets: auto refBuilder = Gtk::Builder::create_from_file(); try { refBuilder->add_from_file("K:\\VM_Shared\\temp1.ui"); } catch (const Glib::FileError& ex) { std::cerr << "FileError: " << ex.what() << std::endl; return nullptr; } catch (const Glib::MarkupError& ex) { std::cerr << "MarkupError: " << ex.what() << std::endl; return nullptr; } catch (const Gtk::BuilderError& ex) { std::cerr << "BuilderError: " << ex.what() << std::endl; return nullptr; } return refBuilder; }
//这里的mainWindow 在Cambalache的 属性 Object id 条目中指定
refBuilder->get_widget<Gtk::Window>("mainWindow");
//获取的是一个实体的指针, 已经存在 并且具有在ui设计器里的父子关系
可以看看这个例子
https://blog.csdn.net/Computer_Tech/article/details/135970006
需要获取最上层的对象然后 set_child(最上层的对象)
或者app->add_window(window) 这是两种方法
//官网例子常见的
auto app = Gtk::Application::create("org.gtkmm.example");
app->make_window_and_run<ExampleWindow>(argc, argv);
这种就在ExampleWindow的构造函数中set_child(最上层的对象)
这个对象不能是GtkWindow 如果是, 将报错:
gtk_window_set_child: assertion ‘child == NULL || priv->child == child || gtk_widget_get_parent (child) == NULL’ failed
因为ExampleWindow自身就是主窗口
#include "test.h" //在test里面用extern声明 在这里先提前定义为nullptr Glib::RefPtr<Gtk::Application> my_app = nullptr; void on_app_activate() { ExampleWindow init; } int main(int argc, char* argv[]) { my_app = Gtk::Application::create("org.gtkmm.example"); my_app->signal_activate().connect([] () { on_app_activate(); }); return my_app->run(argc, argv); }
在ExampleWindow的构造函数中
mainWinodw = refBuilder->get_widget<Gtk::Window>("mainWindow");
my_app->add_window(*mainWinodw);
mainWinodw->set_visible(true);
可以完全用ui里的主窗口
这里的ExampleWindow就相当于一个功能型桥接类
可以看看这个例子:
多 split 窗口 in Gtkmm4
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。