Dear ImGui: Bloat-free Graphical User interface for C++ with minimal dependencies
Go to file
omar b420a51541 Update README.md
Fixed typos, reworded sentence.
2014-09-02 10:59:14 +01:00
examples Fixes to allow clean 1-pixel thick lines in more use cases. PixelCenterOffset not the same as previously! 2014-08-28 14:52:10 +01:00
extra_fonts Using spaces instead of tab for web readability 2014-08-30 20:06:53 +01:00
web Added screenshot for web 2014-08-20 17:46:49 +01:00
.gitignore Git ignore imgui.ini files 2014-08-11 14:46:04 +01:00
imconfig.h Minor tweaks to "Memory override" pull request 2014-08-31 12:02:22 +01:00
imgui.cpp Minor tweaks to "Memory override" pull request 2014-08-31 12:02:22 +01:00
imgui.h Minor tweaks to "Memory override" pull request 2014-08-31 12:02:22 +01:00
LICENSE Initial release 2014-08-10 21:58:11 +01:00
README.md Update README.md 2014-09-02 10:59:14 +01:00
stb_textedit.h stb_textedit 1.4 fix signed/unsigned warnings 2014-08-20 10:43:08 +01:00

ImGui

ImGui is a bloat-free graphical user interface library for C++. It outputs vertex buffers that you can render in your 3D-pipeline enabled application. It is portable, renderer agnostic and carries minimal amount of dependencies (only 3 files are needed). It is based on an "immediate" graphical user interface paradigm which allows you to build simple user interfaces with ease.

ImGui is designed to enable fast iteration and allow programmers to create "content creation" or "debug" tools (as opposed to tools for the average end-user). It favors simplicity and thus lacks certain features normally found in more high-level libraries, such as string localisation.

ImGui is particularly suited to integration in 3D applications, fullscreen applications, embedded applications, games, or any applications on consoles platforms where operating system features are non-standard.

After ImGui is setup in your engine, you can use it like in this example:

screenshot of sample code alongside its output with ImGui

ImGui outputs vertex buffers and simple command-lists that you can render in your application. Because it doesn't know or touch graphics state directly, you can call ImGui commands anywhere in your code (e.g. in the middle of a running algorithm, or in the middle of your own rendering process). Refer to the sample applications in the examples/ folder for instructions on how to integrate ImGui with your existing codebase.

screenshot 1 screenshot 2 screenshot 3 screenshot 4

References

The Immediate Mode GUI paradigm may at first appear unusual to some users. This is mainly because "Retained Mode" GUIs have been so widespread and predominant. The following links can give you a better understanding about how Immediate Mode GUIs works.

Frequently Asked Question

How do you use ImGui on a platform that may not have a mouse and keyboard?

I recommend using Synergy. With the uSynergy.c micro client running you can seamlessly use your PC input devices from a video game console or a tablet. ImGui was also designed to function with touch inputs if you increase the padding of widgets to compensate for the lack of precision of touch devices, but it is recommended you use a mouse to allow optimising for screen real-estate.

I integrated ImGui in my engine and the text or lines are blurry..

  • Try adjusting ImGui::GetIO().PixelCenterOffset to 0.0f or 0.5f.
  • In your Render function, try translating your projection matrix by (0.5f,0.5f) or (0.375f,0.375f).

Can you create elaborate/serious tools with ImGui?

Yes. I have written data browsers, debuggers, profilers and all sort of non-trivial tools with the library. There's no reason you cannot, and in my experience the simplicity of the API is very empowering. However note that ImGui is programmer centric and the immediate-mode GUI paradigm might requires a bit of adaptation before you can realize its full potential.

Can you reskin the look of ImGui?

Yes, you can alter the look of the interface to some degree: changing colors, sizes and padding, font. However, as ImGui is designed and optimised to create debug tools, the amount of skinning you can apply is limited. There is only so much you can stray away from the default look and feel of the interface. The example below uses modified settings to create a more compact UI with different colors:

skinning screenshot 1

Credits

Developed by Omar Cornut. The library was developed with the support of Media Molecule and first used internally on the game Tearaway.

Embeds proggy_clean font by Tristan Grimmer (also MIT license).

Inspiration, feedback, and testing: Casey Muratori, Atman Binstock, Mikko Mononen, Emmanuel Briney, Stefan Kamoda, Anton Mikhailov, Matt Willis. Thanks!

License

ImGui is licensed under the MIT License, see LICENSE for more information.