Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pthom/hello_imgui
Hello, Dear ImGui: unleash your creativity in app development and prototyping
https://github.com/pthom/hello_imgui
android cpp creative-coding cross-platform emscripten gui hello-world imgui immediate-gui ios linux metal mobile opengl osx research windows
Last synced: 5 days ago
JSON representation
Hello, Dear ImGui: unleash your creativity in app development and prototyping
- Host: GitHub
- URL: https://github.com/pthom/hello_imgui
- Owner: pthom
- License: mit
- Created: 2020-06-07T01:24:52.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2025-01-16T12:49:57.000Z (about 1 month ago)
- Last Synced: 2025-02-07T22:09:17.229Z (12 days ago)
- Topics: android, cpp, creative-coding, cross-platform, emscripten, gui, hello-world, imgui, immediate-gui, ios, linux, metal, mobile, opengl, osx, research, windows
- Language: C++
- Homepage: https://pthom.github.io/hello_imgui
- Size: 40.6 MB
- Stars: 716
- Watchers: 16
- Forks: 103
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: Changelog.md
- License: LICENSE
Awesome Lists containing this project
README
_See the [HelloImGui documentation website](https://pthom.github.io/hello_imgui/) for API, usage and build instructions._
**OpenGL**
[data:image/s3,"s3://crabby-images/6f1bf/6f1bf0098a26a77a61bccf8bd434fdb7c45eb303" alt="Win_Mac_Linux"](https://github.com/pthom/hello_imgui/actions/workflows/Win_Mac_Linux.yml)
[data:image/s3,"s3://crabby-images/575b8/575b8f85bf05f4d8dc97423f1f3694e895f232f5" alt="MinGW"](https://github.com/pthom/hello_imgui/actions/workflows/MinGW.yml)**Mobile and web**
[data:image/s3,"s3://crabby-images/d4639/d46390e900327ee8b4e0e4ad45cb212fc31eda15" alt="iOS"](https://github.com/pthom/hello_imgui/actions/workflows/iOS.yml)
[data:image/s3,"s3://crabby-images/f3715/f371507ec51d6842b1535c9b900566c0ec53d08e" alt="Android"](https://github.com/pthom/hello_imgui/actions/workflows/Android.yml)
[data:image/s3,"s3://crabby-images/24f25/24f259b208869dde165aa99d9a4530dda39cb9c3" alt="Emscripten"](https://github.com/pthom/hello_imgui/actions/workflows/Emscripten.yml)**Alternate rendering backends**
[data:image/s3,"s3://crabby-images/357f9/357f9afca01d454ad046b7732179d0b725556923" alt="Metal"](https://github.com/pthom/hello_imgui/actions/workflows/Metal.yml)
[data:image/s3,"s3://crabby-images/c5fed/c5fed826cb38f5eaa2f0192aad88a07c5746c328" alt="Vulkan"](https://github.com/pthom/hello_imgui/actions/workflows/Vulkan.yml)
[data:image/s3,"s3://crabby-images/33408/334087c69262a124d697db41b6e3627e7ee2d892" alt="DirectX"](https://github.com/pthom/hello_imgui/actions/workflows/DirectX.yml)**Misc**
[data:image/s3,"s3://crabby-images/3379b/3379b607014d1880a3c81ff5601460b47ee116cf" alt="TestEngine"](https://github.com/pthom/hello_imgui/actions/workflows/TestEngine.yml)
[data:image/s3,"s3://crabby-images/17edd/17eddca504c27c5f22074f0d78ed9dde39508cfb" alt="Automate"](https://github.com/pthom/hello_imgui/actions/workflows/Automate.yml)
[data:image/s3,"s3://crabby-images/813b5/813b596cc8aea3b89c44c284e5d50c725fcf8086" alt="StarterTemplate"](https://github.com/pthom/hello_imgui/actions/workflows/StarterTemplate.yml)**Vcpkg**
[data:image/s3,"s3://crabby-images/b0a23/b0a23fa3979e484d7ff01fec5aeac074d9ec7ae1" alt="VcpkgDeps"](https://github.com/pthom/hello_imgui/actions/workflows/VcpkgDeps.yml)
[data:image/s3,"s3://crabby-images/72051/7205186c238b264f93c9bc7fb20b100c35c2b481" alt="VcpkgPackage"](https://github.com/pthom/hello_imgui/actions/workflows/VcpkgPackage.yml)# Hello ImGui
Hello ImGui is a library designed to make multiplatform app development as simple as writing a "Hello World" program, built on top of [Dear ImGui](https://github.com/ocornut/imgui).
Its flexibility makes it suited for complex applications, as well as for simple prototypes; allowing you to focus on the creative aspects of your projects.
## Features
**Multiplatform utilities**
* Seamlessly multiplatform: supports Linux, Windows, macOS, iOS, Android, and Emscripten with minimal setup (1 line of CMake code)
* Asset embedding across all platforms (no code required)
* Effortless app customization, including app icons and names for mobile platforms (no code required)
* Universal application icon customization, extending to mobile and macOS (no code required)**Dear ImGui Tweaks**
* Power Save mode: optimize performance by reducing FPS when idle
* High DPI support: automatically scales UI to match screen DPI on any platform.
* Enhanced layout handling: dockable windows and multiple layouts for complex UIs
* Window geometry utilities: autosize application window, restore app window position
* Theme tweaking: extensive list of additional themes
* Support for movable and resizable borderless windows
* Advanced font support: icons, emojis and colored fonts
* Integration with ImGui Test Engine: automate and test your apps
* Save user settings: window position, layout, opened windows, theme, user defined custom settings
* Easily add a custom 3D background to your app**Backends**
* Available platform backends: SDL2, Glfw3
* Available rendering backends: OpenGL3, Metal, Vulkan, DirectX## Demos & real world apps
### Motto
The minimum code to start developing a GUI app should be... minimal. Here is a multiplatform Hello World in 7 lines.
*6 lines of C++*
```cpp
#include "hello_imgui/hello_imgui.h"
int main(int , char *[]) {
HelloImGui::Run(
[]{ ImGui::Text("Hello, world!"); }, // Gui code
"Hello!", true); // Window title + Window size auto
}
```*1 line of CMake*
```cmake
hello_imgui_add_app(hello_world hello_world.cpp)
```### Advanced layout
The docking demo show how to handle complex layouts, use themes, store user settings, reduce FPS and CPU usage when idling, load fonts and icons, and much more
data:image/s3,"s3://crabby-images/c3939/c39390dab23222d6053a8ac7e42c628b6351db62" alt=""
[Online demo](https://traineq.org/ImGuiBundle/emscripten/bin/demo_docking.html) - [Source](https://github.com/pthom/hello_imgui/blob/master/src/hello_imgui_demos/hello_imgui_demodocking/hello_imgui_demodocking.main.cpp) - Video tutorial: [how to handle multiple complex layouts](https://www.youtube.com/watch?v=XKxmz__F4ow)
### Custom 3D background
How to use a custom 3D background in your app
data:image/s3,"s3://crabby-images/2e452/2e452e4deccf9a751259ab34b40a8fc7128974cb" alt=""
[Online demo](https://traineq.org/ImGuiBundle/emscripten/bin/demo_custom_background.html) - [Source](https://github.com/pthom/hello_imgui/blob/master/src/hello_imgui_demos/hello_custom_background/hello_custom_background.main.cpp)
### ImGui Manual
[ImGui Manual](https://pthom.github.io/imgui_manual_online/manual/imgui_manual.html) is an interactive Manual for Dear ImGui, built with Hello ImGui.
[data:image/s3,"s3://crabby-images/dc1ec/dc1ec73cf5f3eded97185272850244f546cd290b" alt=""](https://pthom.github.io/imgui_manual_online/manual/imgui_manual.html)
[Online manual](https://pthom.github.io/imgui_manual_online/manual/imgui_manual.html) -
[Source](https://github.com/pthom/imgui_manual)### RPN Calculator
[RPN Calculator](https://pthom.github.io/imgui_rpn_calculator/) is a simple RPN calculator, built, built to demonstrate how easy a multiplatform app can be built with Hello ImGui.
data:image/s3,"s3://crabby-images/6f15a/6f15aff571ac9f87def85570dc9688d3e73ad606" alt=""
[Online demo](https://traineq.org/HelloImGui/rpn/rpn_calculator.html) - [Source](https://github.com/pthom/rpn_calculator/) - [Video tutorial](https://www.youtube.com/watch?v=dArP4lBnOr8)
### Starter template
[The starter template](https://github.com/pthom/hello_imgui_template) will get you started in 5 minutes, and shows how to embed assets, customize the app icon (etc.), on all platforms.### Dear ImGui Bundle
[Dear ImGui Bundle](https://pthom.github.io/imgui_bundle/), a full-fledged library, built on top of Hello ImGui, provides lots of additional widgets ([imgui](https://github.com/ocornut/imgui.git), [implot](https://github.com/epezent/implot), [imgui-node-editor](https://github.com/thedmd/imgui-node-editor), [ImFileDialog](https://github.com/pthom/ImFileDialog.git), [ImGuiColorTextEdit](https://github.com/BalazsJako/ImGuiColorTextEdit), [imgui_md](https://github.com/mekhontsev/imgui_md.git)), as well as complete python bindings.
[online interactive demo](https://traineq.org/ImGuiBundle/emscripten/bin/demo_imgui_bundle.html) - [Source for C++ demos](https://github.com/pthom/imgui_bundle/tree/main/bindings/imgui_bundle/demos_cpp) - [Source for Python demos](https://github.com/pthom/imgui_bundle/tree/main/bindings/imgui_bundle/demos_python)
### Theme tweaking
How to use the theme tweaking utilities provided by Hello ImGui
[Online video tutorial](https://www.youtube.com/watch?v=4f_-3DDcAZk)
---
## About
### Credits
Hello ImGui is based on [Dear ImGui](https://github.com/ocornut/imgui) (MIT License), by Omar Cornut. Portions use [ImGui Test Engine](https://github.com/ocornut/imgui_test_engine), which is governed by a [specific license](https://github.com/ocornut/imgui_test_engine/blob/main/imgui_test_engine/LICENSE.txt)
Portions of this software use the [FreeType Project](https://www.freetype.org), [plutosvg](https://github.com/sammycage/plutosvg) (MIT License), [GLFW](https://www.glfw.org/) (zlib/libpng license), [SDL](https://www.libsdl.org/) (zlib license).
### License
Hello ImGui is licensed under the MIT License, see [LICENSE](https://github.com/pthom/hello_imgui/blob/master/LICENSE)
### Contribute
Quality contributions are welcome!
### Support the project
Hello ImGui is a free and open source project, and its development and maintenance require considerable efforts.
If you find it valuable for your work – especially in a commercial enterprise or a research setting – please consider supporting its development by [making a donation](https://www.paypal.com/donate/?hosted_button_id=SHJ68RVDKURZA). Thank you!
# More info
_See the [HelloImGui documentation website](https://pthom.github.io/hello_imgui/) for API, usage and build instructions._