0

0

C++怎么使用Dear ImGui创建图形用户界面_C++GUI开发与Dear ImGui使用

裘德小鎮的故事

裘德小鎮的故事

发布时间:2025-11-09 10:21:04

|

1017人浏览过

|

来源于php中文网

原创

首先集成Dear ImGui源码并选择对应图形API的绑定文件,接着初始化上下文与后端,然后在主循环中调用NewFrame和Render绘制UI,通过Begin/End定义窗口,使用内置控件创建交互元素,最终实现轻量级即时模式界面。

c++怎么使用dear imgui创建图形用户界面_c++gui开发与dear imgui使用

Dear ImGui 是一个高效的立即模式图形用户界面库,特别适合用于游戏开发工具调试和实时控制面板等场景。它不依赖复杂的窗口系统,而是与你的渲染后端(如 OpenGL、DirectX)集成,让你能快速构建轻量级 UI。以下是 C++ 中使用 Dear ImGui 创建 GUI 的基本流程和关键要点。

集成 Dear ImGui 到 C++ 项目

要使用 Dear ImGui,需先将其源码集成到项目中:

  • GitHub 仓库 下载 ImGui 源码
  • 将核心文件(imgui.cpp、imgui.h、imgui_draw.cpp、imgui_widgets.cpp 等)加入编译
  • 根据你使用的图形 API,选择并集成对应的绑定文件,例如:
    • OpenGL: 使用 examples/imgui_impl_opengl3.* 和 imgui_impl_glfw.*(若用 GLFW)
    • DirectX: 使用 imgui_impl_dx11.* 等
  • 确保已正确链接 OpenGL、GLFW 或 DirectX 相关库

初始化 ImGui 上下文与后端

在主程序启动图形上下文后,初始化 ImGui:

// 初始化示例(基于 GLFW + OpenGL3)
IMGUI_CHECKVERSION();
ImGui::CreateContext();
ImGuiIO& io = ImGui::GetIO(); (void)io;
ImGui::StyleColorsDark();

ImGui_ImplGlfw_InitForOpenGL(window, true);
ImGui_ImplOpenGL3_Init("#version 130");

这一步创建了 ImGui 的上下文,并连接输入系统(键盘、鼠标)和渲染后端。

立即学习C++免费学习笔记(深入)”;

在主循环中使用 ImGui 构建界面

在每一帧的渲染循环中插入 ImGui 的调用:

巧文书
巧文书

巧文书是一款AI写标书、AI写方案的产品。通过自研的先进AI大模型,精准解析招标文件,智能生成投标内容。

下载
ImGui_ImplOpenGL3_NewFrame();
ImGui_ImplGlfw_NewFrame();
ImGui::NewFrame();

// 创建窗口和控件
ImGui::Begin("调试面板");
ImGui::Text("当前帧率: %.1f FPS", io.Framerate);
ImGui::SliderFloat("亮度", &brightness, 0.0f, 1.0f);
ImGui::ColorEdit3("颜色", (float*)&color);
if (ImGui::Button("重置")) { /* 处理逻辑 */ }
ImGui::End();

ImGui::Render();
ImGui_ImplOpenGL3_RenderDrawData(ImGui::GetDrawData());

所有 UI 元素都写在 ImGui::Begin()ImGui::End() 之间。控件状态直接与变量绑定,无需事件回调。

常用控件与布局技巧

ImGui 提供丰富的内置控件:

  • 文本显示: ImGui::Text(), ImGui::LabelText()
  • 按钮: ImGui::Button(), ImGui::SmallButton()
  • 输入框: ImGui::InputFloat(), ImGui::InputInt(), ImGui::InputText()
  • 滑块: ImGui::SliderFloat(), ImGui::SliderInt()
  • 复选框: ImGui::Checkbox()
  • 下拉菜单: ImGui::Combo()

使用 ImGui::SameLine() 让元素同行排列ImGui::Spacing() 添加空白,ImGui::Separator() 插入分隔线,可实现简单布局。

基本上就这些。只要图形环境搭建好,UI 编写非常直观。注意每次帧开始调用 NewFrame(),结束时渲染 DrawData。调试工具、参数调节器这类需求,用 ImGui 几乎零成本就能实现。

相关专题

更多
css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

551

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

92

2025.10.23

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

702

2023.08.22

javascriptvoid(o)怎么解决
javascriptvoid(o)怎么解决

javascriptvoid(o)的解决办法:1、检查语法错误;2、确保正确的执行环境;3、检查其他代码的冲突;4、使用事件委托;5、使用其他绑定方式;6、检查外部资源等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

171

2023.11.23

java中void的含义
java中void的含义

本专题整合了Java中void的相关内容,阅读专题下面的文章了解更多详细内容。

89

2025.11.27

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

115

2025.12.24

拼豆图纸在线生成器
拼豆图纸在线生成器

拼豆图纸生成器有PixelBeads在线版、BeadGen和“豆图快转”;推荐通过pixelbeads.online或搜索“beadgen free online”直达官网,避开需注册的诱导页面。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

84

2025.12.24

俄罗斯搜索引擎yandex官方入口地址(最新版)
俄罗斯搜索引擎yandex官方入口地址(最新版)

Yandex官方入口网址是https://yandex.com。用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

553

2025.12.24

JavaScript ES6新特性
JavaScript ES6新特性

ES6是JavaScript的根本性升级,引入let/const实现块级作用域、箭头函数解决this绑定问题、解构赋值与模板字符串简化数据处理、对象简写与模块化提升代码可读性与组织性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

155

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 5.2万人学习

C 教程
C 教程

共75课时 | 3.6万人学习

C++教程
C++教程

共115课时 | 9.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号