<div dir="ltr"><div>Hi Jed</div><div><br></div><div>Thanks a lot for all the input - there is a lot of value in there. I like the idea of having a modifier like Space to temporarily switch from the current tool to navigation - right now we only have some basic tools like identify or measure, but in the future we will likely have editing tools where this will be very handy. Some of your suggestions mean that we would also need to change the existing associations to various mouse keys - that needs a bit more consideration. In the short term one of the big wins would be to fix the camera rotation ("tumble") as you mentioned.<br></div><div><br></div><div>The good news is that a "fly" navigation mode is on its way - hopefully we can get it merged for QGIS 3.18:<br></div><div><a href="https://github.com/qgis/QGIS/pull/40893">https://github.com/qgis/QGIS/pull/40893</a></div><div><br></div><div>Cheers</div><div>Martin</div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Wed, Jan 6, 2021 at 2:31 AM Jed Frechette <<a href="mailto:jedfrechette@gmail.com">jedfrechette@gmail.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi Martin,<br>
<br>
I’m glad to hear my impressions weren’t too far off. I do think there<br>
are benefits to the GE style controls, especially for users that are<br>
already familiar with that software. Perhaps it makes sense to keep<br>
those controls as a separate navigation mode in addition to a new mode<br>
that is better suited to more complex tasks? Although I guess there’s<br>
the risk of muddying the interface by not picking one clear consistent<br>
set of controls and optimizing them.<br>
<br>
It’s interesting that you mention multiple viewports, as that would<br>
actually be fairly low on my wish list. This may be a personal<br>
preference, but I don’t use multiple views very often in applications<br>
where I have access to them. There are definitely certain tasks which<br>
are easier with multiple views so they are nice to have, but if I had<br>
to choose I’d much rather have a single viewport that is very<br>
efficient than multiple viewports that are less fluid. That’s what<br>
most of my suggestions below are geared toward; a single viewport<br>
where an experienced user can almost instantly navigate to the exact<br>
view they want, potentially edit/create some data, and within a few<br>
seconds be moving on to the next part of the scene.<br>
<br>
I’ll provide links to a couple examples and videos at the end of my<br>
post, but since there is so little consistency between 3D apps I want<br>
to provide some justification for what I think works rather than just<br>
say “Make it like my favorite program.”<br>
<br>
Regardless of the exact control scheme, I think the most important<br>
observation to make when designing a 3D interface is that for any type<br>
of interactive task the user is constantly switching between<br>
navigating around the scene and using tools to perform actions, e.g.<br>
identify, measure, digitize, etc.. Therefore, switching between those<br>
two modes of interaction needs to be as quick and easy as possible.<br>
Clicking toolbar icons to switch modes works but is probably the<br>
slowest way to do it. Some applications try to overload the mouse<br>
buttons so you can navigate and use tools at the same time, but I’ve<br>
never used a system like that which I thought worked well. I think<br>
it’s much better to make a clear distinction between navigate mode and<br>
tool mode and make the user responsible for switching between them via<br>
hotkey. That way your tools can make use of all 3 mouse buttons<br>
independently of your navigation control scheme, which can also<br>
utilize all 3 buttons.<br>
<br>
Although various applications have made different choices about the<br>
hotkey to use, to me the space bar is the obvious choice. The space<br>
bar is the most used key when typing and the navigation hotkey will be<br>
the most used key while navigating in 3D view so it should be the<br>
space bar too. The navigate hotkey could be used as a toggle, e.g.<br>
with a tool active tap the spacebar to switch to navigate mode then<br>
tap it again when you want to go back to the tool. Alternatively, the<br>
hotkey could be a modifier, e.g. hold down the spacebar to navigate<br>
then release it to return to the tool. Both can work well, but I<br>
prefer the modifier approach. A modifier removes the need for an<br>
indicator, e.g. different cursors, for which mode you’re currently in<br>
like you would need with a toggle. In addition a modifier can act as a<br>
hint to stay in dynamic mode if your viewport is set up to improve<br>
interactive performance by rendering different LODs based on whether<br>
the camera is currently static or dynamically moving.<br>
<br>
The specific navigation control scheme I would advocate for is:<br>
<br>
Dolly along camera z-axis (Space + RMB or Scroll wheel)<br>
==========================================<br>
QGIS already behaves this way so no changes here. Usage of the scroll<br>
wheel is also consistent between the 2D and 3D views so that’s good.<br>
<br>
Track along camera x & y axes (Space + MMB, Space + Shift + RMB)<br>
===================================<br>
The middle mouse button is used for the same movement in the 2D view<br>
so it would be good to stay consistent with that. The alternate<br>
mapping, Space + Shift+ RMB, is for laptop users that only have 2<br>
trackpad buttons. By tracking along the camera x & y axes instead of<br>
GE style tracking navigation is much more intuitive in a fully 3D<br>
world and you eliminate the orientation dependence I referred to in my<br>
first post.<br>
<br>
Tumble (Space + LMB)<br>
=================<br>
Tumbling in QGIS is already pretty good. The only change I would make<br>
is to pivot around the cursor’s current position rather than the<br>
center of the viewport. uclaros already suggested this in the tracker<br>
[1] and it would make precise navigation much easier.<br>
<br>
Roll around camera z-axis (Space + Ctrl + LMB)<br>
===================================<br>
This is really useful when you just want to level the camera relative<br>
to the horizon.<br>
<br>
Box zoom (Space + Ctrl + RMB)<br>
========================<br>
Good for zooming in to a specific region of the scene.<br>
<br>
Other navigation controls could certainly be added, e.g. restricting<br>
tumbling around additional axes, but I think the controls above cover<br>
the majority of needs.<br>
<br>
Two applications I think serve as good examples of what works well are<br>
Houdini and PolyWorks. They have both been around for decades and even<br>
though they serve very different types of users and are used in very<br>
different ways their control schemes are remarkably similar. I used<br>
their control schemes as the basis for the one I described above.<br>
Houdini has good documentation, including lot’s of videos [2], and has<br>
a free version so it is the easiest to observe in use. In contrast,<br>
PolyWorks might cost you a kidney to evaluate. I do, however, have a<br>
video I recorded a while ago showing it being used for some simple<br>
feature extraction [3]. This is the kind of task I would love to be<br>
able to do in QGIS. If I was designing a UI from the ground up for<br>
that specific type of feature extraction it would be a little<br>
different than what’s shown in the video, but it does give a good idea<br>
of the type of fluid, highly interactive workflow, I’d be aiming for.<br>
<br>
Hopefully, some of this is useful and provides some inspiration. I’m<br>
afraid I’m not familiar enough with Qt to implement any of it myself,<br>
but would love to be able to help in any other way that I can.<br>
<br>
Best wishes,<br>
<br>
[1] <a href="https://github.com/qgis/QGIS/issues/40530#issuecomment-742092974" rel="noreferrer" target="_blank">https://github.com/qgis/QGIS/issues/40530#issuecomment-742092974</a><br>
[2] <a href="https://www.sidefx.com/docs/houdini/basics/view.html" rel="noreferrer" target="_blank">https://www.sidefx.com/docs/houdini/basics/view.html</a><br>
[3] <a href="https://youtu.be/d5__-Vu6RkA?t=155" rel="noreferrer" target="_blank">https://youtu.be/d5__-Vu6RkA?t=155</a><br>
<br>
<br>
--<br>
Jed Frechette<br>
</blockquote></div>