-
-
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
High resolution dragging mode for float sliders? #180
Comments
Yes, I am very unhappy with the current sliders so they will be replaced! |
OK I'm working on this now. The tricky part is defining the API entry point(s) for potentially desired options without cluttering:
I'm not sure yet how to handle those possibility. Obviously a function with 8 parameters is probably not the right way to go. |
Also what would be a good name for this widget. DragFloat() ? DragFloat() vs DragFloatRange() ? |
Is it necessary to specify the fast step? My thinking on this was that it works just like the current sliders. You would then only need to specify a slow step. It also seems like we could make this optional as well and default to some fraction of the fast/normal step, but I feel like this could fail at some number ranges (I'm not familiar with how you're computing the final slider values). I think +/- buttons wouldn't be necessary. Maybe it makes it more obvious that you can move at some specific step, but seems like the finer resolution dragging slider would cover the same cases. As for naming, well, that's the hardest of them all! DragFloat() doesn't seem too bad too me. Are you thinking of replacing SliderFloat() outright or have these be two separate widgets living side-by-side? |
My idea for steps is that the default, maybe -1.0f would automatically be like *100 and *0.01 when modifiers are held. So it's ok to have them if they are final parameters I suppose. Or fast could be the inverse the slow. But yes I agree they not be so necessary by default. Especially with CTRL+Click always available. Won't replace the slider no, but will launch a giant lobbying/marketing campaign to advise people to use the new widget. |
The slow/fast factors could also be part of the imgui state, so by default they don't show in the simple API (and you can always have a helper to push/pop them for you). |
Proposal
With global state to adjust slow/fast step ratios. DragFloat("", &f, 0, 1.0f, 10000.0f, "%.3f coins") |
I was actually going to suggest exactly this as a way to reduce the number of parameters. As long as the default step sizes are intuitive, I definitely think this is the way to go.
|
I currently have two variants of each (uncommited)
May not be very useful but this is easily specify the display format without the min/max. |
I suggest you can look at the Unity's FloatField The mouse can drag the lable of the input field to change the float value. I think this is very easy to use. |
Yes, I suppose that's very similar. The difference are:
|
Committed a first version that you can try.
Let me know how that works. |
(
) Also need to spend some time redesigning ShowTestWindow before there's too many things in there. I don't want to remove anything (in fact we should add more examples) but the presentation may need to change. |
I just tried them out and it's a decent first version. It did take me a second to realize that only horizontal mouse movement affected it. Would probably help to have a unique graphic for this widget to make it easily identifiable that it's a DragFloat. I also found myself wanting to see the widget as a normal slider if the DragFloat was bounded so I can have some context as to what the extremes are and where I am in relation to them. It might just be because I'm so used to working with the sliders. We use imgui right now to handle live editing of some game data, and in theory, a lot of our float values can be "unbounded". However, for all practical purposes, they fall within a reasonable range so they work OK with sliders. The case that would be solved better with these DragFloats are those where the range is bounded only on one side. We do have quite a few of these (like specifying time durations) and we've had to force them into the sliders and place arbitrary limits on either the min or the max and just size them accordingly to the most common ranges. |
Very good points. I can see a case for drawing the visual marker, but also use range as reference while being able to get out of the range if you need. May have to redesign and break the current DragFloat() interface. I'm starting to understand why you suggested they could replace sliders altogether. |
Ah, yes, sorry I wasn't more clear! The way I originally envisioned it was that the current sliders would just be modified to be able to step at a much smaller increment when you hit another key while fiddling with the slider. Nevertheless, we would still find the DragFloat or something like it very useful for the case of bounding on only one side of the number line. It's actually kind of a pain right now when we implement our data editing gui and have a float to expose. Usually there's a clear bound on min or max, but not always both, so we need to spend some time fiddling around to see what a good range is and hope that we set the range well enough for the tuning work. We're not always right, so sometimes we get requests to resize the range. Something that might be worth looking into is looking at #76 and see if maybe we can kill a few birds with one mega stone? Might be too much in one widget... but customizable ranges + a high resolution mode would solve a few issues we're seeing! |
After tried,I feel the "step/pixel" movement speed is too hard to set value accurately.Maybe add a speed parameter? |
OK it looks like I may need to rewrite that (and rewrite Slider as well) to latch the initial value on press and go relative from there when clicking on the little box, including speed scale and non-linear curve shenanigans. From there we can use the bounds as visual reference but allow the user to get past them, it's a matter of figuring out the right API after the feature is coded in. |
…sion settings, slow step with integer works #180
@heroboy have you tried holding ALT to slow down the speed ? |
…sion settings, slow step with integer works #180
Fixed commit below, didn't commit the right hunks (my github ui acts weird?) |
Unsure how to visualize the current value of a drag box similarly to a slider, while uniquely identifying them. It got me thinking. I was wondering if slider could just be changed to function like DragFloat(), that is, clicking is never setting an absolute value. Pros: is that slider/drag just become the same thing, and we can have API variants of options to : have no bounds, have bounds but allow to go past them, etc. Cons: can't set an absolute value in one click, drag is generally slower (even if it's more flexible and precise). Need to decide on a default speed for sliders (e.g. 1 pixel is 1/200 of the input range). |
I made DragFloat() support power curves while applying relative changes and working on both sides of zero. Perhaps someone who is more competent at maths or floating-point issues can review this and tell me if it's total rubbish or if there are edge cases to be wary about:
|
I tried use ALT to slow down, but it is not what I want. It just decrease the change amount. To set a value,fox example 1.00 (not 0.99,not 1.01), I must move mouse very carefully. |
I have use a horizontal slider on IOS. It use cursor y position to determine the speed. When the cursor move away the slider in y axis, you need move more distance to change the value. It's very interesting. You may reference this one to improve the float slider? |
@heroboy To set a specific value you simply type it in. I like the DragFloat widget as it is, especially now that you can specify the speed. |
@extrawurst I want set value to 1.00,2.00,3.00,.... sequentially. I think what I want is snap |
@heroboy sounds like you want is DragInt... |
Or you can use a format of %.0f to snap float to integer values (whiles using actual floats) |
iOS behavior could be nice, I'd have to try it with mouse + keyboard to know for sure. Even on iOS, I don't find the dragging resolution being tied to vertical distance from the dragging element to be that great (but better than nothing). Being locked to the horizontal axis and having no regard for the vertical component is useful in dragging; most of the time I kind of throw my mouse over to get to values quickly and having the resolution constantly change on me seems like it would be annoying. |
One thing I would like to see in this new widget is: The support that unity brings for similar dragSliders to wrap the mouse pos around to enable infinite dragging, this is really usefull! |
Btw I have released 1.38 as is. Established that the missing desired features (e.g. bounds for clamp different from bounds for display) won't break the current API. They may have to be a different API. |
We just bumped up to 1.38 today in our game, and though we aren't using the drag floats yet, things are looking good! Will try to find some places to use these and let you know of anything we find as a result... |
Hello! |
@CaptNemo999
No it isn't at the moment. Curious as to why you would need to disable it? |
Ok, don't worry. Thank you for your answer. |
That makes sense. I would suggest you can implement a custom control. SliderFloat() does a lot of subtle stuff you don't really need, a simplified version would be less code.
|
I was wondering if imgui already supports some method of high resolution dragging on sliders?
An issue I encounter frequently is having a slider which might have a large range and the default dragging increments are very high (or alternatively, the window is sized so that the slider is quite small so the dragging precision drops dramatically). Most of the time this is OK, but sometimes I want to move at much smaller increments and the sliding mechanism is much more natural than having to type in values directly.
One such thing I've seen somewhere (don't remember where) is allowing the user to hold a modifier key (such as control or alt) while dragging which enables the high resolution dragging mode and the slider then starts to move at a smaller increment.
I think this would be a really useful feature if imgui doesn't already have it! Let me know what you think.
-Dale Kim
The text was updated successfully, but these errors were encountered: