gtkmm 与 Cambalache 与 Gtk::Builder (新手向)_

文章目录

前言

  • 新手刚刚使用时的笔记

Cambalache检查Xml

  • 窗口右键inspect UI Definition切换到Xml视图, 可以全选复制粘贴到你的ui文件里, Cambalache 只能保存为.cmb工程文件, 导出也不知道导出到哪

.cpp文件如何写才能显示UI

  • 首先creat

    cpp 复制代码
    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;
    }
  • 获取ui里的对象

    cpp 复制代码
    //这里的mainWindow 在Cambalache的 属性 Object id 条目中指定
    refBuilder->get_widget<Gtk::Window>("mainWindow");
    //获取的是一个实体的指针, 已经存在 并且具有在ui设计器里的父子关系
  • 显示
    需要获取最上层的对象然后 set_child(最上层的对象)
    或者app->add_window(window) 这是两种方法

  • 第一种

    cpp 复制代码
    //官网例子常见的
    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

  • 第二种

    cpp 复制代码
    #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的构造函数中

    cpp 复制代码
    mainWinodw = refBuilder->get_widget<Gtk::Window>("mainWindow");
    my_app->add_window(*mainWinodw);
    mainWinodw->set_visible(true);

    可以完全用ui里的主窗口

相关推荐
xiaoshuaishuai81 小时前
C# Avalonia UI的ItemControl
开发语言·ui·c#
条tiao条3 小时前
鸿蒙 ArkTS 多线程完全指南:告别 UI 卡顿,从 TaskPool 到 Worker
ui·华为·harmonyos
ZC跨境爬虫12 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
ZC跨境爬虫1 天前
跟着 MDN 学CSS day_44:响应式设计——让网页适配所有屏幕的完整指南
前端·css·ui·html·tensorflow
ZC跨境爬虫1 天前
跟着 MDN 学CSS day_43:CSS布局挑战——从浮动到弹性盒与栅格的综合实践
前端·css·ui·html·tensorflow
夜空孤狼啸1 天前
Vue Data UI:这不是图表库,是数据可视化 UI 平台
vue.js·ui·信息可视化
ZC跨境爬虫2 天前
跟着 MDN 学CSS day_37:(从文档流到粘性定位的底层原理)
前端·javascript·css·ui·html
G_dou_2 天前
Flutter三方库适配OpenHarmony【compass】罗盘 UI 项目完整实战
flutter·ui
ZC跨境爬虫2 天前
跟着 MDN 学CSS day_40:(Flexbox实战技能测试)
前端·css·ui·html·tensorflow
ZC跨境爬虫2 天前
跟着 MDN 学CSS day_36:(float、clear与BFC深度解析)
前端·javascript·css·ui·交互