mirror of
https://github.com/Drezil/imgui.git
synced 2024-11-15 01:17:00 +00:00
WIP Menus: fixed case where zero-sized display (e.g. minimised window) clips popups/menus and asserted (#126)
This commit is contained in:
parent
88d7b3de23
commit
7f3f3891c0
@ -3062,11 +3062,13 @@ static bool BeginPopupEx(const char* str_id, ImGuiWindowFlags extra_flags)
|
||||
ImFormatString(name, 20, "##popup_%08x", id); // Not recycling, so we can close/open during the same frame
|
||||
float alpha = 1.0f;
|
||||
bool opened = ImGui::Begin(name, NULL, ImVec2(0.0f, 0.0f), alpha, flags);
|
||||
IM_ASSERT(opened);
|
||||
|
||||
if (!(window->Flags & ImGuiWindowFlags_ShowBorders))
|
||||
GetCurrentWindow()->Flags &= ~ImGuiWindowFlags_ShowBorders;
|
||||
|
||||
if (!opened) // opened can be 'false' when the popup is completely clipped (e.g. zero size display)
|
||||
ImGui::EndPopup();
|
||||
|
||||
return opened;
|
||||
}
|
||||
|
||||
@ -7518,8 +7520,7 @@ bool ImGui::BeginMenu(const char* label)
|
||||
if (opened)
|
||||
{
|
||||
ImGui::SetNextWindowPos(popup_pos, ImGuiSetCond_Always);
|
||||
bool popup_opened = BeginPopupEx(label, ImGuiWindowFlags_Menu);
|
||||
IM_ASSERT(opened == popup_opened);
|
||||
opened = BeginPopupEx(label, ImGuiWindowFlags_Menu); // opened can be 'false' when the popup is completely clipped (e.g. zero size display)
|
||||
}
|
||||
|
||||
return opened;
|
||||
|
Loading…
Reference in New Issue
Block a user