mirror of
https://github.com/Drezil/imgui.git
synced 2024-11-25 21:17:01 +00:00
This commit is contained in:
parent
389982eb5a
commit
1c4066cd9e
10
imgui.cpp
10
imgui.cpp
@ -5289,15 +5289,16 @@ static void ApplyWindowSettings(ImGuiWindow* window, ImGuiWindowSettings* settin
|
|||||||
static void UpdateWindowInFocusOrderList(ImGuiWindow* window, bool just_created, ImGuiWindowFlags new_flags)
|
static void UpdateWindowInFocusOrderList(ImGuiWindow* window, bool just_created, ImGuiWindowFlags new_flags)
|
||||||
{
|
{
|
||||||
ImGuiContext& g = *GImGui;
|
ImGuiContext& g = *GImGui;
|
||||||
const ImGuiWindowFlags old_flags = window->Flags;
|
|
||||||
const bool child_flag_changed = (new_flags & ImGuiWindowFlags_ChildWindow) != (old_flags & ImGuiWindowFlags_ChildWindow);
|
|
||||||
|
|
||||||
if ((just_created || child_flag_changed) && !(new_flags & ImGuiWindowFlags_ChildWindow))
|
const bool new_is_explicit_child = (new_flags & ImGuiWindowFlags_ChildWindow) != 0;
|
||||||
|
const bool child_flag_changed = new_is_explicit_child != window->IsExplicitChild;
|
||||||
|
if ((just_created || child_flag_changed) && !new_is_explicit_child)
|
||||||
{
|
{
|
||||||
|
IM_ASSERT(!g.WindowsFocusOrder.contains(window));
|
||||||
g.WindowsFocusOrder.push_back(window);
|
g.WindowsFocusOrder.push_back(window);
|
||||||
window->FocusOrder = (short)(g.WindowsFocusOrder.Size - 1);
|
window->FocusOrder = (short)(g.WindowsFocusOrder.Size - 1);
|
||||||
}
|
}
|
||||||
else if (child_flag_changed && (new_flags & ImGuiWindowFlags_ChildWindow))
|
else if (!just_created && child_flag_changed && new_is_explicit_child)
|
||||||
{
|
{
|
||||||
IM_ASSERT(g.WindowsFocusOrder[window->FocusOrder] == window);
|
IM_ASSERT(g.WindowsFocusOrder[window->FocusOrder] == window);
|
||||||
for (int n = window->FocusOrder + 1; n < g.WindowsFocusOrder.Size; n++)
|
for (int n = window->FocusOrder + 1; n < g.WindowsFocusOrder.Size; n++)
|
||||||
@ -5305,6 +5306,7 @@ static void UpdateWindowInFocusOrderList(ImGuiWindow* window, bool just_created,
|
|||||||
g.WindowsFocusOrder.erase(g.WindowsFocusOrder.Data + window->FocusOrder);
|
g.WindowsFocusOrder.erase(g.WindowsFocusOrder.Data + window->FocusOrder);
|
||||||
window->FocusOrder = -1;
|
window->FocusOrder = -1;
|
||||||
}
|
}
|
||||||
|
window->IsExplicitChild = new_is_explicit_child;
|
||||||
}
|
}
|
||||||
|
|
||||||
static ImGuiWindow* CreateNewWindow(const char* name, ImGuiWindowFlags flags)
|
static ImGuiWindow* CreateNewWindow(const char* name, ImGuiWindowFlags flags)
|
||||||
|
@ -1984,6 +1984,7 @@ struct IMGUI_API ImGuiWindow
|
|||||||
bool Appearing; // Set during the frame where the window is appearing (or re-appearing)
|
bool Appearing; // Set during the frame where the window is appearing (or re-appearing)
|
||||||
bool Hidden; // Do not display (== HiddenFrames*** > 0)
|
bool Hidden; // Do not display (== HiddenFrames*** > 0)
|
||||||
bool IsFallbackWindow; // Set on the "Debug##Default" window.
|
bool IsFallbackWindow; // Set on the "Debug##Default" window.
|
||||||
|
bool IsExplicitChild; // Set when passed _ChildWindow, left to false by BeginDocked()
|
||||||
bool HasCloseButton; // Set when the window has a close button (p_open != NULL)
|
bool HasCloseButton; // Set when the window has a close button (p_open != NULL)
|
||||||
signed char ResizeBorderHeld; // Current border being held for resize (-1: none, otherwise 0-3)
|
signed char ResizeBorderHeld; // Current border being held for resize (-1: none, otherwise 0-3)
|
||||||
short BeginCount; // Number of Begin() during the current frame (generally 0 or 1, 1+ if appending via multiple Begin/End pairs)
|
short BeginCount; // Number of Begin() during the current frame (generally 0 or 1, 1+ if appending via multiple Begin/End pairs)
|
||||||
|
Loading…
Reference in New Issue
Block a user