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

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.