SVI f5825b7a0e Добавление вендоринга há 3 anos atrás
..
.gitignore f5825b7a0e Добавление вендоринга há 3 anos atrás
.go.mod.swp f5825b7a0e Добавление вендоринга há 3 anos atrás
Assert.go f5825b7a0e Добавление вендоринга há 3 anos atrás
BackendFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
CONTRIBUTING.md f5825b7a0e Добавление вендоринга há 3 anos atrás
ColorEditFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
ColorPickerFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
ComboFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
Conditions.go f5825b7a0e Добавление вендоринга há 3 anos atrás
ConfigFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
Context.go f5825b7a0e Добавление вендоринга há 3 anos atrás
DragDrop.go f5825b7a0e Добавление вендоринга há 3 anos atrás
DragDropWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
DragDropWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawCommand.go f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawCommandWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawCommandWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawData.go f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawDataWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawDataWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawList.go f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawListWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
DrawListWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
FocusFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
Font.go f5825b7a0e Добавление вендоринга há 3 anos atrás
FontAtlas.go f5825b7a0e Добавление вендоринга há 3 anos atrás
FontAtlasWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
FontAtlasWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
FontConfig.go f5825b7a0e Добавление вендоринга há 3 anos atrás
FontConfigWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
FontConfigWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
FontGlyphRangesBuilderWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
FontGlyphRangesBuilderWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
FontGlyphRnagesBuilder.go f5825b7a0e Добавление вендоринга há 3 anos atrás
FontWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
FontWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
GlyphRanges.go f5825b7a0e Добавление вендоринга há 3 anos atrás
HoveredFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
IO.go f5825b7a0e Добавление вендоринга há 3 anos atrás
IOWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
IOWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
InputText.go f5825b7a0e Добавление вендоринга há 3 anos atrás
InputTextCallbackDataWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
InputTextCallbackDataWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
Keys.go f5825b7a0e Добавление вендоринга há 3 anos atrás
LICENSE.txt f5825b7a0e Добавление вендоринга há 3 anos atrás
ListClipper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
ListClipper.go f5825b7a0e Добавление вендоринга há 3 anos atrás
ListClipper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
MouseCursorFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
PlatformGlfw.go f5825b7a0e Добавление вендоринга há 3 anos atrás
PlatformInterface.go f5825b7a0e Добавление вендоринга há 3 anos atrás
README.md f5825b7a0e Добавление вендоринга há 3 anos atrás
RendererInterface.go f5825b7a0e Добавление вендоринга há 3 anos atrás
RendererOpenGL3.go f5825b7a0e Добавление вендоринга há 3 anos atrás
SelectableFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
Style.go f5825b7a0e Добавление вендоринга há 3 anos atrás
StyleWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
StyleWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
TabBarFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
TabItemFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
Table.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
Table.go f5825b7a0e Добавление вендоринга há 3 anos atrás
Table.h f5825b7a0e Добавление вендоринга há 3 anos atrás
TextEditor.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
TextEditor.go f5825b7a0e Добавление вендоринга há 3 anos atrás
TextEditor.h f5825b7a0e Добавление вендоринга há 3 anos atrás
TextEditorWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
TextEditorWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
TextureID.go f5825b7a0e Добавление вендоринга há 3 anos atrás
TreeNodeFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
Vectors.go f5825b7a0e Добавление вендоринга há 3 anos atrás
WindowFlags.go f5825b7a0e Добавление вендоринга há 3 anos atrás
WrapperConverter.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
WrapperConverter.go f5825b7a0e Добавление вендоринга há 3 anos atrás
WrapperConverter.h f5825b7a0e Добавление вендоринга há 3 anos atrás
doc.go f5825b7a0e Добавление вендоринга há 3 anos atrás
imconfig.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui.go f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imguiWrappedHeader.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imguiWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imguiWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imguiWrapperTypes.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_demo.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_draw.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_internal.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_markdown.go f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_markdown.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_markdown_wrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_markdown_wrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_memory_editor.go f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_memory_editor.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_memory_editor_wrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_memory_editor_wrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_tables.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imgui_widgets.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imnodes.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imnodes.go f5825b7a0e Добавление вендоринга há 3 anos atrás
imnodes.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imnodesWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imnodesWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imnodes_internal.h f5825b7a0e Добавление вендоринга há 3 anos atrás
implot.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
implot.go f5825b7a0e Добавление вендоринга há 3 anos atrás
implot.h f5825b7a0e Добавление вендоринга há 3 anos atrás
implotWrapper.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
implotWrapper.h f5825b7a0e Добавление вендоринга há 3 anos atrás
implotWrapperTypes.h f5825b7a0e Добавление вендоринга há 3 anos atrás
implot_demo.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
implot_internal.h f5825b7a0e Добавление вендоринга há 3 anos atrás
implot_items.cpp f5825b7a0e Добавление вендоринга há 3 anos atrás
imstb_rectpack.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imstb_textedit.h f5825b7a0e Добавление вендоринга há 3 anos atrás
imstb_truetype.h f5825b7a0e Добавление вендоринга há 3 anos atrás

README.md

Dear ImGui for Go

Go Doc Go Report Card GolangCI

This library is a Go wrapper for Dear ImGui.

This wrapper started as a special-purpose wrapper for use within InkyBlackness. However, it is self-contained and can be used for other purposes as well.

This wrapper is

  • hand-crafted, for Go
  • documented
  • versioned
  • with ported examples in a separate repository (see below)

Screenshot from example

API naming

Names of types and functions follow closely those of Dear ImGui.

For functions that have optional parameters, the following schema is applied:

  • There is the "verbose" variant, followed by the letter V, such as ButtonV(id string, size Vec2) bool
  • Next to it there is the "idiomatic" variant, without any optional parameter, such as Button(id string) bool.
  • The idiomatic variant calls the verbose variant with the default values for the optional parameters. Functions that don't have optional parameters don't come in a verbose variant.

The Dear ImGui functions IO() and Style() have been renamed to be CurrentIO() and CurrentStyle(). This was done because their returned types have the same name, causing a name clash. With the Current prefix, they also better describe what they return.

API philosophy

This library does not intend to export all the functions of the wrapped Dear ImGui. The following filter applies as a rule of thumb:

  • Functions marked as "obsolete" are not available. (The corresponding C code isn't even compiled - disabled by define)
  • "Shortcut" Functions, which combine language features and/or other Dear ImGui functions, are not available. Prime example are the Text*() functions for instance: Text formatting should be done with fmt.Sprintf(), and style formatting with the corresponding Push/Pop functions.
  • Functions that are not needed by InkyBlackness are ignored. This doesn't mean that they can't be in the wrapper, they are simply not a priority. Feel free to propose an implementation or make a pull request, respecting the previous points :)

Version philosophy

This library does not mirror the versions of the wrapped Dear ImGui. The semantic versioning of this wrapper is defined as:

  • Major changes: (Breaking) changes in API or behaviour. Typically done through changes in Dear ImGui.
  • Minor changes: Extensions in API. Typically done through small version increments of Dear ImGui and/or exposing further features in a compatible way.
  • Patch changes: Bug fixes - either in the wrapper or the wrapped Dear ImGui, given that the API & behaviour remains the same.

At the moment, this library uses version 1.79 of Dear ImGui.

Examples

A separate repository was created to host ported examples and reference implementations. See repository inkyblackness/imgui-go-examples.

It contains reference implementations for libraries such as GLFW3 and SDL2, using OpenGL.

The screenshot above was created with such an example.

Extras

FreeType font rendering

If the FreeType library is available for your platform, you can enable using it with the build tag imguifreetype - as in

go build -tags="imguifreetype"

This extra is based on the reference implementation from Dear ImGui.

This allows you to use the function FontAtlas.BuildWithFreeType(). If the build tag is not set, this function will always return an error.

If you set the build tag, yet the corresponding support has not been added to the library, you will receive a build error. Contributions to support more build environments are happily accepted. See files FreeTypeEnabled*.go.

Alternatives

Before this project was created, the following alternatives were considered - and ignored:

  • kdrag0n/go-imgui (no longer available). Reasons for dismissal at time of decision:
    • Auto-generated bloat, which doesn't help
    • Was using old API (1.5x)
    • Did not compile
    • Project appeared to be abandoned
  • Extrawurst/cimgui. Reasons for dismissal at time of decision:
    • Was using old API (1.5x), 1.6x was attempted
    • Apparently semi-exposed the C++ API, especially through the structures
    • Adding this adds another dependency

License

The project is available under the terms of the New BSD License (see LICENSE file). The licenses of included sources are stored in the _licenses folder.