maoan-imgui-js
v1.1.2
Published
JavaScript bindings for Dear ImGui using Emscripten and TypeScript
Downloads
891
Readme
effects-imgui
JavaScript bindings for Dear ImGui using Emscripten and TypeScript.
Based on imgui-js by flyover.
Notes
All functions in the C++ ImGui namespace are exported at the top level of the module.
import * as ImGui from "imgui-js";Individual exports can be imported as well.
import { ImVec2 } from "imgui-js";In general, functions that take an address of a variable in C++ have been changed to take an access function in JavaScript. Calling the access function with no arguments returns the variable, calling with a value sets the variable.
type ImAccess<T> = (value?: T) => T;
let show: boolean = true;
const _show: ImAccess<boolean> = (_: boolean = show): boolean => show = _;
// get the value of show
console.log(_show()); // true
// set the value of show to false (also returns the updated value)
console.log(_show(false)); // falseIn the following example, the address of show in the C++ code has been replaced with an inline arrow access function.
#include "imgui.h"
bool show = true;
void draw() {
if (ImGui::Button("Toggle")) { show = !show; }
if (show) {
ImGui::Begin("My Window", &show, ImGuiWindowFlags_AlwaysAutoResize));
ImGui::Text("Hello, World!");
ImGui::End();
}
}import * as ImGui from "imgui-js";
let show: boolean = true;
function draw(): void {
if (ImGui.Button("Toggle")) { show = !show; }
if (show) {
ImGui.Begin("My Window", (_ = show) => show = _, ImGui.WindowFlags.AlwaysAutoResize));
ImGui.Text("Hello, World!");
ImGui.End();
}
}Enumerations that begin with ImGui* are also exported with ImGui removed. So the following examples are equivalent.
import * as ImGui from "imgui-js";
const flags: ImGui.WindowFlags = ImGui.WindowFlags.AlwaysAutoResize;import { ImGuiWindowFlags } from "imgui-js";
const flags: ImGuiWindowFlags = ImGuiWindowFlags.AlwaysAutoResize;In order to minimize size of the output, the C++ library has been compiled with IMGUI_DISABLE_OBSOLETE_FUNCTIONS and IMGUI_DISABLE_DEMO_WINDOWS.
Building
Prerequisites
- Emscripten installed and available in PATH
- Node.js
Steps
git clone --recursive <repo-url>
cd effects-imgui
npm install
npm run buildnpm run build will:
- Compile the C++ Dear ImGui source and bindings to WebAssembly via Emscripten (
make build-bind-imgui) - Compile the TypeScript wrapper (
tsc)
Run the Example
npm startThis starts a Vite dev server and opens the example in your browser.
License
imgui-js is licensed under the MIT License, see LICENSE for more information.
