mirror of
				https://github.com/ocornut/imgui.git
				synced 2025-10-25 20:07:00 +00:00 
			
		
		
		
	Nav: Fixed ButtonBehavior mistakenly setting active id when the Activate button is held and we have a new NavId, which affected browsing some popups (#787)
This commit is contained in:
		
							
								
								
									
										12
									
								
								imgui.cpp
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								imgui.cpp
									
									
									
									
									
								
							| @@ -6575,12 +6575,16 @@ bool ImGui::ButtonBehavior(const ImRect& bb, ImGuiID id, bool* out_hovered, bool | ||||
|         hovered = true; | ||||
|         if (!g.NavWindowingTarget && IsNavInputDown(ImGuiNavInput_PadActivate)) | ||||
|         { | ||||
|             // Set active id so it can be queried by user via IsItemActive(), etc. but don't react to it ourselves | ||||
|             g.NavActivateId = id; | ||||
|             bool nav_pressed = IsNavInputPressed(ImGuiNavInput_PadActivate, (flags & ImGuiButtonFlags_Repeat) ? ImGuiNavReadMode_Repeat : ImGuiNavReadMode_Pressed); | ||||
|             if (nav_pressed) | ||||
|                 pressed = true; | ||||
|             if (nav_pressed || g.ActiveId == id) | ||||
|             { | ||||
|                 // Set active id so it can be queried by user via IsItemActive(), equivalent of holding the mouse button. | ||||
|                 g.NavActivateId = id; // This is so SetActiveId assign a Nav source | ||||
|                 SetActiveID(id, window); | ||||
|                 g.ActiveIdAllowNavDirFlags = (1 << ImGuiDir_Left) | (1 << ImGuiDir_Right) | (1 << ImGuiDir_Up) | (1 << ImGuiDir_Down); | ||||
|             if (IsNavInputPressed(ImGuiNavInput_PadActivate, (flags & ImGuiButtonFlags_Repeat) ? ImGuiNavReadMode_Repeat : ImGuiNavReadMode_Pressed)) | ||||
|                 pressed = true; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 omar
					omar