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里的主窗口

相关推荐
reg18315 小时前
一款完美适配mobile、pad、web三端的博客网站UI解决方案
ui
容器( ु⁎ᴗ_ᴗ⁎)ु.。oO1 天前
Magentic-ui项目相关整理
开发语言·javascript·ui
界面开发小八哥2 天前
界面控件DevExpress WPF v24.2新版亮点:报表等组件功能升级
ui·.net·wpf·界面控件·devexpress·ui开发
共享ui设计和前端开发3 天前
数字孪生在UI前端的应用:从理论到实践
ui
艾学习3 天前
浅谈为windows7平台打包基于pyside6的UI程序
ui
蓝胖子的多啦A梦3 天前
搭建前端项目 Vue+element UI引入 步骤 (超详细)
前端·vue.js·ui
蔡蓝3 天前
设计模式-状态模式
ui·设计模式·状态模式
sunshine_程序媛3 天前
在Vue2项目中引入ElementUI详细步骤
前端·ui·elementui·前端框架·vue
海上彼尚4 天前
Vue3 PC端 UI组件库我更推荐Naive UI
前端·vue.js·ui
大千AI助手4 天前
5分钟玩转Swagger UI:Docker部署+静态化实战
ui·docker·容器·swagger·swaggerui