|
|
@@ -2255,14 +2255,11 @@ void ImGui::NewFrame()
|
|
|
window->SizeFull *= scale;
|
|
|
}
|
|
|
}
|
|
|
- else
|
|
|
+ else if (!(window->Flags & ImGuiWindowFlags_NoScrollWithMouse))
|
|
|
{
|
|
|
// Scroll
|
|
|
- if (!(window->Flags & ImGuiWindowFlags_NoScrollWithMouse))
|
|
|
- {
|
|
|
- const int scroll_lines = (window->Flags & ImGuiWindowFlags_ComboBox) ? 3 : 5;
|
|
|
- SetWindowScrollY(window, window->Scroll.y - g.IO.MouseWheel * window->CalcFontSize() * scroll_lines);
|
|
|
- }
|
|
|
+ const int scroll_lines = (window->Flags & ImGuiWindowFlags_ComboBox) ? 3 : 5;
|
|
|
+ SetWindowScrollY(window, window->Scroll.y - g.IO.MouseWheel * window->CalcFontSize() * scroll_lines);
|
|
|
}
|
|
|
}
|
|
|
|
|
|
@@ -2280,6 +2277,15 @@ void ImGui::NewFrame()
|
|
|
window->Accessed = false;
|
|
|
}
|
|
|
|
|
|
+ // Closing the focused window restore focus to the first active root window in descending z-order
|
|
|
+ if (g.FocusedWindow && !g.FocusedWindow->WasActive)
|
|
|
+ for (int i = g.Windows.Size-1; i >= 0; i--)
|
|
|
+ if (g.Windows[i]->WasActive && !(g.Windows[i]->Flags & ImGuiWindowFlags_ChildWindow))
|
|
|
+ {
|
|
|
+ FocusWindow(g.Windows[i]);
|
|
|
+ break;
|
|
|
+ }
|
|
|
+
|
|
|
// No window should be open at the beginning of the frame.
|
|
|
// But in order to allow the user to call NewFrame() multiple times without calling Render(), we are doing an explicit clear.
|
|
|
g.CurrentWindowStack.resize(0);
|
|
|
@@ -3917,16 +3923,10 @@ bool ImGui::Begin(const char* name, bool* p_open, const ImVec2& size_on_first_us
|
|
|
else
|
|
|
PushClipRect(fullscreen_rect.Min, fullscreen_rect.Max, true);
|
|
|
|
|
|
- // New windows appears in front
|
|
|
if (!window_was_active)
|
|
|
{
|
|
|
- window->AutoPosLastDirection = -1;
|
|
|
-
|
|
|
- if (!(flags & ImGuiWindowFlags_NoFocusOnAppearing))
|
|
|
- if (!(flags & (ImGuiWindowFlags_ChildWindow|ImGuiWindowFlags_Tooltip)) || (flags & ImGuiWindowFlags_Popup))
|
|
|
- FocusWindow(window);
|
|
|
-
|
|
|
// Popup first latch mouse position, will position itself when it appears next frame
|
|
|
+ window->AutoPosLastDirection = -1;
|
|
|
if ((flags & ImGuiWindowFlags_Popup) != 0 && !window_pos_set_by_api)
|
|
|
window->PosFloat = g.IO.MousePos;
|
|
|
}
|
|
|
@@ -4264,6 +4264,11 @@ bool ImGui::Begin(const char* name, bool* p_open, const ImVec2& size_on_first_us
|
|
|
if (window->AutoFitFramesY > 0)
|
|
|
window->AutoFitFramesY--;
|
|
|
|
|
|
+ // New windows appears in front (we need to do that AFTER setting DC.CursorStartPos so our initial navigation reference rectangle can start around there)
|
|
|
+ if (!window_was_active && !(flags & ImGuiWindowFlags_NoFocusOnAppearing))
|
|
|
+ if (!(flags & (ImGuiWindowFlags_ChildWindow|ImGuiWindowFlags_Tooltip)) || (flags & ImGuiWindowFlags_Popup))
|
|
|
+ FocusWindow(window);
|
|
|
+
|
|
|
// Title bar
|
|
|
if (!(flags & ImGuiWindowFlags_NoTitleBar))
|
|
|
{
|