mirror of
https://github.com/ocornut/imgui.git
synced 2025-01-19 08:03:01 +08:00
Debug Tools: Metrics: Improved Monitors and Viewports minimap display. Highlight on hover. (amends)
This commit is contained in:
parent
71bcf350bd
commit
8490a262c4
18
imgui.cpp
18
imgui.cpp
@ -19646,10 +19646,19 @@ static void RenderViewportsThumbnails()
|
|||||||
ImGuiContext& g = *GImGui;
|
ImGuiContext& g = *GImGui;
|
||||||
ImGuiWindow* window = g.CurrentWindow;
|
ImGuiWindow* window = g.CurrentWindow;
|
||||||
|
|
||||||
|
// Draw monitor and calculate their boundaries
|
||||||
float SCALE = 1.0f / 8.0f;
|
float SCALE = 1.0f / 8.0f;
|
||||||
ImRect bb_full(g.Viewports[0]->Pos, g.Viewports[0]->Pos + g.Viewports[0]->Size);
|
ImRect bb_full(FLT_MAX, FLT_MAX, -FLT_MAX, -FLT_MAX);
|
||||||
|
for (ImGuiPlatformMonitor& monitor : g.PlatformIO.Monitors)
|
||||||
|
bb_full.Add(ImRect(monitor.MainPos, monitor.MainPos + monitor.MainSize));
|
||||||
ImVec2 p = window->DC.CursorPos;
|
ImVec2 p = window->DC.CursorPos;
|
||||||
ImVec2 off = p - bb_full.Min * SCALE;
|
ImVec2 off = p - bb_full.Min * SCALE;
|
||||||
|
for (ImGuiPlatformMonitor& monitor : g.PlatformIO.Monitors)
|
||||||
|
{
|
||||||
|
ImRect monitor_draw_bb(off + (monitor.MainPos) * SCALE, off + (monitor.MainPos + monitor.MainSize) * SCALE);
|
||||||
|
window->DrawList->AddRect(monitor_draw_bb.Min, monitor_draw_bb.Max, (g.DebugMetricsConfig.HighlightMonitorIdx == g.PlatformIO.Monitors.index_from_ptr(&monitor)) ? IM_COL32(255, 255, 0, 255) : ImGui::GetColorU32(ImGuiCol_Border), 4.0f);
|
||||||
|
window->DrawList->AddRectFilled(monitor_draw_bb.Min, monitor_draw_bb.Max, ImGui::GetColorU32(ImGuiCol_Border, 0.10f), 4.0f);
|
||||||
|
}
|
||||||
|
|
||||||
// Draw viewports
|
// Draw viewports
|
||||||
for (ImGuiViewportP* viewport : g.Viewports)
|
for (ImGuiViewportP* viewport : g.Viewports)
|
||||||
@ -20045,6 +20054,7 @@ void ImGui::ShowMetricsWindow(bool* p_open)
|
|||||||
// Viewports
|
// Viewports
|
||||||
if (TreeNode("Viewports", "Viewports (%d)", g.Viewports.Size))
|
if (TreeNode("Viewports", "Viewports (%d)", g.Viewports.Size))
|
||||||
{
|
{
|
||||||
|
cfg->HighlightMonitorIdx = -1;
|
||||||
bool open = TreeNode("Monitors", "Monitors (%d)", g.PlatformIO.Monitors.Size);
|
bool open = TreeNode("Monitors", "Monitors (%d)", g.PlatformIO.Monitors.Size);
|
||||||
SameLine();
|
SameLine();
|
||||||
MetricsHelpMarker("Dear ImGui uses monitor data:\n- to query DPI settings on a per monitor basis\n- to position popup/tooltips so they don't straddle monitors.");
|
MetricsHelpMarker("Dear ImGui uses monitor data:\n- to query DPI settings on a per monitor basis\n- to position popup/tooltips so they don't straddle monitors.");
|
||||||
@ -20057,6 +20067,8 @@ void ImGui::ShowMetricsWindow(bool* p_open)
|
|||||||
i, mon.DpiScale * 100.0f,
|
i, mon.DpiScale * 100.0f,
|
||||||
mon.MainPos.x, mon.MainPos.y, mon.MainPos.x + mon.MainSize.x, mon.MainPos.y + mon.MainSize.y, mon.MainSize.x, mon.MainSize.y,
|
mon.MainPos.x, mon.MainPos.y, mon.MainPos.x + mon.MainSize.x, mon.MainPos.y + mon.MainSize.y, mon.MainSize.x, mon.MainSize.y,
|
||||||
mon.WorkPos.x, mon.WorkPos.y, mon.WorkPos.x + mon.WorkSize.x, mon.WorkPos.y + mon.WorkSize.y, mon.WorkSize.x, mon.WorkSize.y);
|
mon.WorkPos.x, mon.WorkPos.y, mon.WorkPos.x + mon.WorkSize.x, mon.WorkPos.y + mon.WorkSize.y, mon.WorkSize.x, mon.WorkSize.y);
|
||||||
|
if (IsItemHovered())
|
||||||
|
cfg->HighlightMonitorIdx = i;
|
||||||
}
|
}
|
||||||
TreePop();
|
TreePop();
|
||||||
}
|
}
|
||||||
@ -20078,10 +20090,14 @@ void ImGui::ShowMetricsWindow(bool* p_open)
|
|||||||
if (viewports.Size > 1)
|
if (viewports.Size > 1)
|
||||||
ImQsort(viewports.Data, viewports.Size, sizeof(ImGuiViewport*), ViewportComparerByLastFocusedStampCount);
|
ImQsort(viewports.Data, viewports.Size, sizeof(ImGuiViewport*), ViewportComparerByLastFocusedStampCount);
|
||||||
for (ImGuiViewportP* viewport : viewports)
|
for (ImGuiViewportP* viewport : viewports)
|
||||||
|
{
|
||||||
BulletText("Viewport #%d, ID: 0x%08X, LastFocused = %08d, PlatformFocused = %s, Window: \"%s\"",
|
BulletText("Viewport #%d, ID: 0x%08X, LastFocused = %08d, PlatformFocused = %s, Window: \"%s\"",
|
||||||
viewport->Idx, viewport->ID, viewport->LastFocusedStampCount,
|
viewport->Idx, viewport->ID, viewport->LastFocusedStampCount,
|
||||||
(g.PlatformIO.Platform_GetWindowFocus && viewport->PlatformWindowCreated) ? (g.PlatformIO.Platform_GetWindowFocus(viewport) ? "1" : "0") : "N/A",
|
(g.PlatformIO.Platform_GetWindowFocus && viewport->PlatformWindowCreated) ? (g.PlatformIO.Platform_GetWindowFocus(viewport) ? "1" : "0") : "N/A",
|
||||||
viewport->Window ? viewport->Window->Name : "N/A");
|
viewport->Window ? viewport->Window->Name : "N/A");
|
||||||
|
if (IsItemHovered())
|
||||||
|
cfg->HighlightViewportID = viewport->ID;
|
||||||
|
}
|
||||||
TreePop();
|
TreePop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user