mirror of
				https://github.com/Drezil/imgui.git
				synced 2025-10-30 20:51:06 +01:00 
			
		
		
		
	Debug Tools: Added DebugStartItemPicker() in imgui_internal.h to facilitate binding this anywhere in user's tool. Adedd highlight. Added IMGUI_DEBUG_TOOL_ITEM_PICKER_EX to break in ItemAdd().
This commit is contained in:
		| @@ -80,6 +80,9 @@ | |||||||
| // Use 'Metrics->Tools->Item Picker' to pick widgets with the mouse and break into them for easy debugging. | // Use 'Metrics->Tools->Item Picker' to pick widgets with the mouse and break into them for easy debugging. | ||||||
| //#define IM_DEBUG_BREAK  IM_ASSERT(0) | //#define IM_DEBUG_BREAK  IM_ASSERT(0) | ||||||
| //#define IM_DEBUG_BREAK  __debugbreak() | //#define IM_DEBUG_BREAK  __debugbreak() | ||||||
|  | // Have the Item Picker break in the ItemAdd() function instead of ItemHoverable() - which is earlier in the code, will catch a few extra items, allow picking items other than Hovered one. | ||||||
|  | // This adds a small runtime cost which is why it is not enabled by default. | ||||||
|  | //#define IMGUI_DEBUG_TOOL_ITEM_PICKER_EX | ||||||
|  |  | ||||||
| //---- Tip: You can add extra functions within the ImGui:: namespace, here or in your own headers files. | //---- Tip: You can add extra functions within the ImGui:: namespace, here or in your own headers files. | ||||||
| /* | /* | ||||||
|   | |||||||
							
								
								
									
										73
									
								
								imgui.cpp
									
									
									
									
									
								
							
							
						
						
									
										73
									
								
								imgui.cpp
									
									
									
									
									
								
							| @@ -2861,16 +2861,6 @@ void ImGui::SetHoveredID(ImGuiID id) | |||||||
|     g.HoveredIdAllowOverlap = false; |     g.HoveredIdAllowOverlap = false; | ||||||
|     if (id != 0 && g.HoveredIdPreviousFrame != id) |     if (id != 0 && g.HoveredIdPreviousFrame != id) | ||||||
|         g.HoveredIdTimer = g.HoveredIdNotActiveTimer = 0.0f; |         g.HoveredIdTimer = g.HoveredIdNotActiveTimer = 0.0f; | ||||||
|  |  | ||||||
|     // [DEBUG] Item Picker tool! |  | ||||||
|     // We perform the check here because SetHoveredID() is not frequently called (1~ time a frame), making |  | ||||||
|     // the cost of this tool near-zero. We would get slightly better call-stack if we made the test in ItemAdd() |  | ||||||
|     // but that would incur a slightly higher cost and may require us to hide this feature behind a define. |  | ||||||
|     if (id != 0 && id == g.DebugBreakItemId) |  | ||||||
|     { |  | ||||||
|         IM_DEBUG_BREAK(); |  | ||||||
|         g.DebugBreakItemId = 0; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| ImGuiID ImGui::GetHoveredID() | ImGuiID ImGui::GetHoveredID() | ||||||
| @@ -2979,6 +2969,15 @@ bool ImGui::ItemAdd(const ImRect& bb, ImGuiID id, const ImRect* nav_bb_arg) | |||||||
|             if (g.NavWindow->RootWindowForNav == window->RootWindowForNav) |             if (g.NavWindow->RootWindowForNav == window->RootWindowForNav) | ||||||
|                 if (window == g.NavWindow || ((window->Flags | g.NavWindow->Flags) & ImGuiWindowFlags_NavFlattened)) |                 if (window == g.NavWindow || ((window->Flags | g.NavWindow->Flags) & ImGuiWindowFlags_NavFlattened)) | ||||||
|                     NavProcessItem(window, nav_bb_arg ? *nav_bb_arg : bb, id); |                     NavProcessItem(window, nav_bb_arg ? *nav_bb_arg : bb, id); | ||||||
|  |  | ||||||
|  |         // [DEBUG] Item Picker tool, when enabling the "extended" version we perform the check in ItemAdd() | ||||||
|  | #ifdef IMGUI_DEBUG_TOOL_ITEM_PICKER_EX | ||||||
|  |         if (id == g.DebugItemPickerBreakID) | ||||||
|  |         { | ||||||
|  |             IM_DEBUG_BREAK(); | ||||||
|  |             g.DebugItemPickerBreakID = 0; | ||||||
|  |         } | ||||||
|  | #endif | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     window->DC.LastItemId = id; |     window->DC.LastItemId = id; | ||||||
| @@ -3067,6 +3066,17 @@ bool ImGui::ItemHoverable(const ImRect& bb, ImGuiID id) | |||||||
|         return false; |         return false; | ||||||
|  |  | ||||||
|     SetHoveredID(id); |     SetHoveredID(id); | ||||||
|  |  | ||||||
|  |     // [DEBUG] Item Picker tool! | ||||||
|  |     // We perform the check here because SetHoveredID() is not frequently called (1~ time a frame), making | ||||||
|  |     // the cost of this tool near-zero. We can get slightly better call-stack and support picking non-hovered | ||||||
|  |     // items if we perform the test in ItemAdd(), but that would incur a small runtime cost. | ||||||
|  |     // #define IMGUI_DEBUG_TOOL_ITEM_PICKER_EX in imconfig.h if you want this check to also be performed in ItemAdd(). | ||||||
|  |     if (g.DebugItemPickerActive && g.HoveredIdPreviousFrame == id) | ||||||
|  |         GetForegroundDrawList()->AddRect(bb.Min, bb.Max, IM_COL32(255, 255, 0, 255)); | ||||||
|  |     if (g.DebugItemPickerBreakID == id) | ||||||
|  |         IM_DEBUG_BREAK(); | ||||||
|  |  | ||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -3787,6 +3797,27 @@ void ImGui::NewFrame() | |||||||
|     g.BeginPopupStack.resize(0); |     g.BeginPopupStack.resize(0); | ||||||
|     ClosePopupsOverWindow(g.NavWindow, false); |     ClosePopupsOverWindow(g.NavWindow, false); | ||||||
|  |  | ||||||
|  |     // [DEBUG] Item picker tool - start with DebugStartItemPicker() - useful to visually select an item and break into its call-stack. | ||||||
|  |     g.DebugItemPickerBreakID = 0; | ||||||
|  |     if (g.DebugItemPickerActive) | ||||||
|  |     { | ||||||
|  |         const ImGuiID hovered_id = g.HoveredIdPreviousFrame; | ||||||
|  |         ImGui::SetMouseCursor(ImGuiMouseCursor_Hand); | ||||||
|  |         if (ImGui::IsKeyPressedMap(ImGuiKey_Escape)) | ||||||
|  |             g.DebugItemPickerActive = false; | ||||||
|  |         if (ImGui::IsMouseClicked(0) && hovered_id) | ||||||
|  |         { | ||||||
|  |             g.DebugItemPickerBreakID = hovered_id; | ||||||
|  |             g.DebugItemPickerActive = false; | ||||||
|  |         } | ||||||
|  |         ImGui::SetNextWindowBgAlpha(0.60f); | ||||||
|  |         ImGui::BeginTooltip(); | ||||||
|  |         ImGui::Text("HoveredId: 0x%08X", hovered_id); | ||||||
|  |         ImGui::Text("Press ESC to abort picking."); | ||||||
|  |         ImGui::TextColored(GetStyleColorVec4(hovered_id ? ImGuiCol_Text : ImGuiCol_TextDisabled), "Click to break in debugger!"); | ||||||
|  |         ImGui::EndTooltip(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     // Create implicit/fallback window - which we will only render it if the user has added something to it. |     // Create implicit/fallback window - which we will only render it if the user has added something to it. | ||||||
|     // We don't use "Debug" to avoid colliding with user trying to create a "Debug" window with custom flags. |     // We don't use "Debug" to avoid colliding with user trying to create a "Debug" window with custom flags. | ||||||
|     // This fallback is particularly important as it avoid ImGui:: calls from crashing. |     // This fallback is particularly important as it avoid ImGui:: calls from crashing. | ||||||
| @@ -9801,27 +9832,9 @@ void ImGui::ShowMetricsWindow(bool* p_open) | |||||||
|  |  | ||||||
|     if (ImGui::TreeNode("Tools")) |     if (ImGui::TreeNode("Tools")) | ||||||
|     { |     { | ||||||
|         static bool picking_enabled = false; |         // The Item Picker tool is super useful to visually select an item and break into the call-stack of where it was submitted. | ||||||
|         if (ImGui::Button("Item Picker..")) |         if (ImGui::Button("Item Picker..")) | ||||||
|             picking_enabled = true; |             ImGui::DebugStartItemPicker(); | ||||||
|         if (picking_enabled) |  | ||||||
|         { |  | ||||||
|             const ImGuiID hovered_id = g.HoveredIdPreviousFrame; |  | ||||||
|             ImGui::SetMouseCursor(ImGuiMouseCursor_Hand); |  | ||||||
|             if (ImGui::IsKeyPressedMap(ImGuiKey_Escape)) |  | ||||||
|                 picking_enabled = false; |  | ||||||
|             if (ImGui::IsMouseClicked(0) && hovered_id) |  | ||||||
|             { |  | ||||||
|                 g.DebugBreakItemId = hovered_id; |  | ||||||
|                 picking_enabled = false; |  | ||||||
|             } |  | ||||||
|             ImGui::SetNextWindowBgAlpha(0.5f); |  | ||||||
|             ImGui::BeginTooltip(); |  | ||||||
|             ImGui::Text("HoveredId: 0x%08X", hovered_id); |  | ||||||
|             ImGui::Text("Press ESC to abort picking."); |  | ||||||
|             ImGui::TextColored(GetStyleColorVec4(hovered_id ? ImGuiCol_Text : ImGuiCol_TextDisabled), "Click to break in debugger!"); |  | ||||||
|             ImGui::EndTooltip(); |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ImGui::Checkbox("Show windows begin order", &show_windows_begin_order); |         ImGui::Checkbox("Show windows begin order", &show_windows_begin_order); | ||||||
|         ImGui::Checkbox("Show windows rectangles", &show_windows_rects); |         ImGui::Checkbox("Show windows rectangles", &show_windows_rects); | ||||||
|   | |||||||
| @@ -1029,7 +1029,8 @@ struct ImGuiContext | |||||||
|     int                     LogDepthToExpandDefault;            // Default/stored value for LogDepthMaxExpand if not specified in the LogXXX function call. |     int                     LogDepthToExpandDefault;            // Default/stored value for LogDepthMaxExpand if not specified in the LogXXX function call. | ||||||
|  |  | ||||||
|     // Debug Tools |     // Debug Tools | ||||||
|     ImGuiID                 DebugBreakItemId; |     bool                    DebugItemPickerActive; | ||||||
|  |     ImGuiID                 DebugItemPickerBreakID;             // Will call IM_DEBUG_BREAK() when encountering this id | ||||||
|  |  | ||||||
|     // Misc |     // Misc | ||||||
|     float                   FramerateSecPerFrame[120];          // Calculate estimate of framerate for user over the last 2 seconds. |     float                   FramerateSecPerFrame[120];          // Calculate estimate of framerate for user over the last 2 seconds. | ||||||
| @@ -1156,7 +1157,8 @@ struct ImGuiContext | |||||||
|         LogDepthRef = 0; |         LogDepthRef = 0; | ||||||
|         LogDepthToExpand = LogDepthToExpandDefault = 2; |         LogDepthToExpand = LogDepthToExpandDefault = 2; | ||||||
|  |  | ||||||
|         DebugBreakItemId = 0; |         DebugItemPickerActive = false; | ||||||
|  |         DebugItemPickerBreakID = 0; | ||||||
|  |  | ||||||
|         memset(FramerateSecPerFrame, 0, sizeof(FramerateSecPerFrame)); |         memset(FramerateSecPerFrame, 0, sizeof(FramerateSecPerFrame)); | ||||||
|         FramerateSecPerFrameIdx = 0; |         FramerateSecPerFrameIdx = 0; | ||||||
| @@ -1658,6 +1660,9 @@ namespace ImGui | |||||||
|     IMGUI_API void          ShadeVertsLinearColorGradientKeepAlpha(ImDrawList* draw_list, int vert_start_idx, int vert_end_idx, ImVec2 gradient_p0, ImVec2 gradient_p1, ImU32 col0, ImU32 col1); |     IMGUI_API void          ShadeVertsLinearColorGradientKeepAlpha(ImDrawList* draw_list, int vert_start_idx, int vert_end_idx, ImVec2 gradient_p0, ImVec2 gradient_p1, ImU32 col0, ImU32 col1); | ||||||
|     IMGUI_API void          ShadeVertsLinearUV(ImDrawList* draw_list, int vert_start_idx, int vert_end_idx, const ImVec2& a, const ImVec2& b, const ImVec2& uv_a, const ImVec2& uv_b, bool clamp); |     IMGUI_API void          ShadeVertsLinearUV(ImDrawList* draw_list, int vert_start_idx, int vert_end_idx, const ImVec2& a, const ImVec2& b, const ImVec2& uv_a, const ImVec2& uv_b, bool clamp); | ||||||
|  |  | ||||||
|  |     // Debug Tools | ||||||
|  |     inline void             DebugStartItemPicker() { GImGui->DebugItemPickerActive = true; } | ||||||
|  |  | ||||||
| } // namespace ImGui | } // namespace ImGui | ||||||
|  |  | ||||||
| // ImFontAtlas internals | // ImFontAtlas internals | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user