From 82ea385c6d9942743e13f415e1569e4df51435f1 Mon Sep 17 00:00:00 2001 From: Jakob Bornecrantz Date: Fri, 11 Sep 2020 16:57:20 +0100 Subject: [PATCH] imgui: Add igToggleButton function --- .../imgui/imgui_monado/cimgui_monado.h | 2 + .../imgui/imgui_monado/imgui_monado.cpp | 40 +++++++++++++++++++ 2 files changed, 42 insertions(+) diff --git a/src/external/imgui/imgui_monado/cimgui_monado.h b/src/external/imgui/imgui_monado/cimgui_monado.h index c030354d0..55e711af5 100644 --- a/src/external/imgui/imgui_monado/cimgui_monado.h +++ b/src/external/imgui/imgui_monado/cimgui_monado.h @@ -20,6 +20,8 @@ void igPlotTimings(const char *label, bool center_reference_timing, float range, const char *unit, bool dynamic_rescale); +void igToggleButton(const char *str_id, bool *v); + #ifdef __cplusplus } #endif diff --git a/src/external/imgui/imgui_monado/imgui_monado.cpp b/src/external/imgui/imgui_monado/imgui_monado.cpp index f8b7f7c6f..38cf7e335 100644 --- a/src/external/imgui/imgui_monado/imgui_monado.cpp +++ b/src/external/imgui/imgui_monado/imgui_monado.cpp @@ -235,3 +235,43 @@ void igPlotTimings(const char *label, center_reference_timing, range, unit, dynamic_rescale); } } + +extern "C" { +void igToggleButton(const char *str_id, bool *v) { + ImVec2 p = ImGui::GetCursorScreenPos(); + ImDrawList *draw_list = ImGui::GetWindowDrawList(); + + float height = ImGui::GetFrameHeight(); + float width = height * 1.55f; + float radius = height * 0.50f; + + ImGui::InvisibleButton(str_id, ImVec2(width, height)); + if (ImGui::IsItemClicked()) + *v = !*v; + + float t = *v ? 1.0f : 0.0f; + + ImGuiContext &g = *GImGui; + float ANIM_SPEED = 0.08f; + if (g.LastActiveId == + g.CurrentWindow->GetID(str_id)) // && g.LastActiveIdTimer < ANIM_SPEED) + { + float t_anim = ImSaturate(g.LastActiveIdTimer / ANIM_SPEED); + t = *v ? (t_anim) : (1.0f - t_anim); + } + + ImU32 col_bg; + if (ImGui::IsItemHovered()) + col_bg = ImGui::GetColorU32(ImLerp(ImVec4(0.78f, 0.78f, 0.78f, 1.0f), + ImVec4(0.64f, 0.83f, 0.34f, 1.0f), t)); + else + col_bg = ImGui::GetColorU32(ImLerp(ImVec4(0.85f, 0.85f, 0.85f, 1.0f), + ImVec4(0.56f, 0.83f, 0.26f, 1.0f), t)); + + draw_list->AddRectFilled(p, ImVec2(p.x + width, p.y + height), col_bg, + height * 0.5f); + draw_list->AddCircleFilled( + ImVec2(p.x + radius + t * (width - radius * 2.0f), p.y + radius), + radius - 1.5f, IM_COL32(255, 255, 255, 255)); +} +}