-
-
Notifications
You must be signed in to change notification settings - Fork 10.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Clipper & Vertical scrolling. Unsure how to scroll to active item when it's no longer visible? #3578
Comments
If I comment out all the SetKeyboardFocusHere (that were forcing the text field to have navigation/focus) and click on one of the selectables and then move up/down (which uses imgui default navigation), the windows scrolls just fine... Here's a video https://youtu.be/ej-1tOPPzQ0 This is basically the exact behavior I want, but I want to force focus to be always on the text field, and use my own custom ActiveIndex to indicate which is the selected/highlighted item... |
Hello, Sorry for my late answer. At first glance this look actually easy to handle on your end.
The |
Hey Omar this is vexe, just my work account. The suggested fix has the same mouse wheel scrolling problem, I just can't scroll with the mouse anymore as it keeps overriding it with SetScrollFromPosY. Ideally this whole thing would run only if I try to navigate up/down the menu and the current item is not visible. Like I expect to be able to scroll freely with the mouse even making the active item invisible completely, then if I hit up/down, it snaps back into view if that makes sense. Unless I put the code in the wrong spot? I put it after the loop, tried both before and after the Clipper.End() |
@vexe @TTALIA From imgui_internal you can use: void ScrollToItem(ImGuiScrollFlags flags = 0);
void ScrollToRect(ImGuiWindow* window, const ImRect& rect, ImGuiScrollFlags flags = 0); In particular the flags that are interesting for you: ImGuiScrollFlags_KeepVisibleEdgeY = 1 << 1, // If item is not visible: scroll as little as possible on Y axis to bring item back into view [default for Y axis for windows that are already visible]
ImGuiScrollFlags_KeepVisibleCenterY = 1 << 3, // If item is not visible: scroll to make the item centered on Y axis
ImGuiScrollFlags_AlwaysCenterY = 1 << 5, // Always center the result item on Y axis [default for Y axis for appearing window) Using default is good as while the window is kept visible it'll use
That should allow you to request a "scroll enough to keep visible" on any Up/Down press. In addition, I have reintroduced the I think between those two your issue is now fully fixable. |
This partially reverts commit 6a7e2c7.
This partially reverts commit 6a7e2c7.
📣 FYI the function |
Version/Branch of Dear ImGui
Version: 1.79 WIP (17803)
Branch: docking
Back-end/Renderer/Compiler/OS
Back-ends: imgui_impl_win32.cpp + imgui_impl_dx11.cpp
Compiler: MSVC
Operating System: Win7 64-bit & Win10 64-bit
My Issue/Question:
Context:
I basically have file fuzzy finder/searcher/browser thing going on in my text editor, the purpose is to navigate to the selected file upon enter or double click. I give it a list of files from the current directory, I apply a filter to that list using an input text, then I draw the results as a Selectable. The drawing is wrapped around ImGuiListClipper.Begin/End.
The text input should always be the item that has focus/navigation, I type in part of a file name I want, I get filtered results populated, I hit UP or DOWN arrow to move the 'Active Index' up or down. The 'Active Index' is in filtered space. (i.e. ActiveIndex of 0 refers to the first in the FILTERED list)
Problem:
When I move down past the last visible item in the clipper, the window does not automatically scroll. I'm not sure what's the best way to do it.
I tried something like this at the end of the clipper loop:
And this at the beginning of it:
It kinda works, but it's pretty ugly, uses internal state and it messes up with mouse wheel scrolling, as I scroll the mouse the "Active Index" becomes out of range, and it keeps trying to SetScrollHere...
Note that previously I didn't use a clipper and the problem was much easier to solve, just "if (ItemIndex==ActiveIndex && !ImGui::IsItemVisible()) ImGui::SetScrollHere();" obviously this doesn't work with the clipper.
Here's a video demonstrating the issue: https://youtu.be/ZNooiltKJIc
And here's my code: https://pastebin.com/yxXYLzjv (wanted you to see full code and not snippets but also bring down the noise in here, but if you prefer to have the code pasted here just let me know!)
I'm pretty sure there's an easier way to do this that I'm missing.
Any help is appreciated, thanks!
The text was updated successfully, but these errors were encountered: