Difference between revisions of "Slicer3:UIDesign"

From NAMIC Wiki
Jump to: navigation, search
Line 64: Line 64:
 
'''Proposed modification of vtkSliceControllerWidget:'''
 
'''Proposed modification of vtkSliceControllerWidget:'''
  
The widget below shows a read-out/entry for current fiducial; buttons for navigate-to-next-fiducial and navigate-to-previous-fiducial. Slice scrollbar is longer, and contains labels at each endpoint.  
+
The widget below shows a read-out/entry for current fiducial; buttons for navigate-to-next-fiducial and navigate-to-previous-fiducial. Slice scrollbar is longer, and contains labels at each endpoint.
 +
 
[[image:FiducialNavigationSliceWindow.png | icons ]]
 
[[image:FiducialNavigationSliceWindow.png | icons ]]
  

Revision as of 21:54, 13 March 2007

Home < Slicer3:UIDesign

Return to Slicer3 Interface Design and Usability


Embodiment


Usability goals

1. Enable a user to understand and effectively use the content and tools being presented;

2. Enable a user to accomplish a principle task by following an appropriate and satisfying workflow or a curiosity-driven exploration, at an appropriate pace;

3. Enhance and support the developer’s experience with GUI infrastructure and guidelines that simplify and clarify their work.


Slicer users

Core user communities:

  • (NAC) Longitudinal and multi-channel dataset analysis
  • (BIRN/NA-MIC) Individual and group analysis
  • (IGT/AMIGO) Real-time control and tracking in the operating theater
  • (IGT) Neurosurgical planning and guidance

Types of users:

  • Algorithm researchers (who work within 3DSlicer's development environment and with associated toolkits)
  • Biomedical engineers (who rely on 3DSlicer's interactive enironment and scripting capabilities)
  • Application scientists (who use 3DSlicer as a desktop application and turnkey system)


Current status and TO-DO

The existing base classes form a basic framework for the UI. For the Alpha/Beta releases, we provided a main application window with the general layout described in our current design. For the Release deadline, we plan to complete the overall application GUI. Things we are focusing on:

  • make default font size a function of display size.
  • implementing functionality for view control widgets,
  • implementing lightbox viewer
  • implement GUIs for specification of oblique views.
  • design/implement mouse-mode interaction paradigm (using one mouse button, hot-keys, and view xform or action mouse-modes).
  • design mouse-mode icons and mouse-mode cursors.
  • build base classes for pop-up information.
  • copyright Slicer base icons and logo (all versions)

Working problem: Navigating with fiducials

GOALS:

  • use fiducials as markers for features of interest
  • allow navigation to fiducial points within a slice window and
  • allow navigation to same fiducial point in all slice windows (a feature we're calling 'jumpslice').
  • want to read-out which fiducial is currently being viewed while navigating
  • want to expose these features in top level in each slice controller widget
  • want also to keep the slice scrollbar from getting too small to use.
  • want to indicate which slice scrollbar direction is R,L, S,I, A,P, depending on orientation

Proposed modification of vtkSliceControllerWidget:

The widget below shows a read-out/entry for current fiducial; buttons for navigate-to-next-fiducial and navigate-to-previous-fiducial. Slice scrollbar is longer, and contains labels at each endpoint.

icons

  • user can navigate forward, backward using fiducial jump buttons
  • user can enter an ordinal number (or name?) to jump to a fiducial (above, third fiducial of 12 total in the list)
  • if viewers are unlinked, only the active slice viewer is updated
  • if viewers are linked, all viewers are updated to show the slice containing the same fiducial.
  • if a viewer's slice scrollbar is adjusted, its fiducial read-out is reset to ""
  • any time a new fiducial is placed in a viewer, the fiducial read-out is updated to that (current) fiducial.

Questions about placing and moving new fiducials:

  • should placing a new fiducial in the viewer cause a jumpslice event if all viewers are linked?

Seems we may not always want to trigger this by default.

  • should moving a newly placed fiducial in the viewer cause a jumpslice event if all viewers are linked?

Again, seems we may not want this default behavior.

Questions about navigation:

  • first time navigating, we start on fiducial#1. maybe we go forward to

fiducial 10 of 20. Next time navigating, do we continue on to 11, or restart at 1?

  • Will there ever be too many fiducials to navigate?
  • should the fiducial navigation entry (read-out) also take a fiducial NAME instead of number?
  • Do we want to include other navigation options?

Proposed solution:

  • We're already implementing a mouse-mode for 'place fiducials'. A new mouse-mode for place-fiducials-in-jumpslice-mode could be added that gives that behavior specifically when viewers are linked:
    • put fiducial down and jumpslice in all viewers on mousebutton-release
    • move fiducial in any viewer and jumpslice in all viewers on mousebutton-release.
    • switch to regular place-fiducials mode, and the jumpslice stops.

Working problem: What does a left-mouse-button click mean in Slicer's Viewers?

Currently, a left-mouse-button click in Slicer's 3D or Slice Viewers can mean different things at different times; this can be confusing to users, and can lead to mistakes. We are currently deciding a good paradigm for defining and controlling mouse modes in Slicer's 3D viewer and 2D slice windows. We rely on mouse interaction to transform the view, and to perform explicit actions like placing a fiducial, selecting and moving a fiducial, collecting voxel-value samples, and so on. The challenge is to make all actions possible with just the left mouse button (some mice have only one button), and to disambiguate what a left-mouse-button click in the 3D and Slice viewers means.

Goals: We'd like the interaction paradigm to have the following features:

  • Consistent in all slice windows and 3D viewer
  • Intuitive and easy for beginners
  • Fast for intermediate and expert users
  • Rely on only one mouse button (but accommodate multiple mouse buttons)
  • Support direct manipulation as much as possible
  • Provide clear visual feedback about current mouse mode
  • Support both view transformation (rotate, pan, zoom) and mouse actions (pick, manipulate, place, etc...).

---

Current problems we want to address in existing Slicer3 implementation:

  • Mouse motion always in "view transform" mode
  • Relies on three mouse buttons (for rotate, pan, zoom, slice scroll) which aren't always present on all computers
  • Relies on hot-keys for non-transform mouse actions, which vary from module to module (tough for novice users, or forgetful intermediate users)
  • 3D viewer mouse event bindings and Slice viewer mouse event bindings not entirely consistent
  • Would like to free up right mouse button to invoke the display of a 'context menu'.
  • Would like BOTH intuitive one-handed mouse-only interaction to be possible AND hot-key assisted shortcuts to be available.


Current bindings (not entirely consistent across 3D Viewer and Slice Viewers):

  • 3D viewer: left mouse button >> rotate
  • 3D viewer: middle mouse button >> pan
  • 3D viewer: mouse wheel button >> zoom in/out
  • 3D viewer: right mouse button, pull drag >> zoom in
  • 3D viewer: right mouse button, push drag >> zoom out
  • Slice viewer: left mouse button >> select/move a fiducial point
  • Slice viewer: middle mouse button >> pan
  • Slice viewer: mouse wheel button >> scroll slices
  • Slice viewer: right mouse button, pull drag >> zoom in
  • Slice viewer: right mouse button, push drag >> zoom out
  • special key-bindings enable placing of fiducials

---

How Actions and View Transformations are done in Maya

Maya is a very heavily used professional 3D animation package. Basic mouse bindings are:

  • Rotate: alt-left mouse button
  • Pan: alt-middle mouse button
  • Zoom: alt-right or alt-right-and-middle mouse button
  • Actions: always left mouse button, specific action depends on current mode
  • Context menu: space bar

The advantage of this approach is that the left mouse button is freed up for many possible tasks such as selection, grabbing widget handles, etc. Disadvantage is that it requires two hands to operate. (A free copy of an almost-fully functional version of Maya is available for testing ).


How Actions and View Transformations are done in Blender

Blender is an Open Source modeling and animation package similar in many ways to Maya (almost like GIMP is to Photoshop). Basic mouse bindings are:

  • Rotate: alt-left mouse button OR middle mouse button
  • Pan: shift-middle mouse button
  • Zoom: control-middle mouse button
  • Actions: mostly left mouse button
  • Context menu: space bar


Note: Mac bindings

On a one-button mac, the following translations work by default in Mac OSX:

  • single button -> left mouse button
  • alt (option) + button -> middle mouse button
  • apple (command) + button -> right mouse button

---

Proposed approach -- please comment!:

We are looking for user feedback on a proposed approach to solving the problems listed above, in a manner that echos what other 3D modeling packages do: providing explicit mouse modes which clearly differentiate whether a user is transforming a view, or performing some "action" by clicking or dragging the mouse. Please have a look at the interaction paradigm we're proposing and the description of the workflow it would generate for novice users and for expert users. This way of interacting is a little different from Slicer2's paradigm. Also see the analogous interfaces from Maya (a popular 3D modeling and rendering software package) and also SketchUp (which does some simple but powerful 3D modeling). Please contribute any feedback you have in the bottom section. Thanks for your help!


Details of the proposed interaction design:

  • Mouse mode icons in "selected" (top) and "deselected" (bottom) states: icons
  • Icons + descriptions:
    • pick+manipulate ToolbarMouseManipulate.png pick and/or manipulate an object as appropriate, like selecting and moving a fiducial point, or grabbing and manipulating a 3D vtkWidget, or for sampling voxel values, etc. When multiple objects (or objects of different types) are selected, this behavior may or may not apply.
    • region-select ToolbarMouseSelectRegion.png rubber-band box to select multiple objects, selected state is persistent until deselected;
    • lasso-a-region ToolbarMouseLasso.png manually drawn outline to select multiple objects, persistent until deselected;
    • deselect all ToolbarMouseDeselectAll.png not really a *mode* per se. The Deselect-All icon becomes highlighted when anything has been "selected" with the region or lasso (persistent selectors), and it becomes lowlighted when nothing is "selected". Clicking the button when highlighted deselects all, and then lowlights the DeselectAll icon;
    • put ToolbarMousePlace.png for new placing fiducials, seed points, etc.;
    • view-tumble ToolbarMouseRotate.png rotates camera in the view plane;
    • view-track ToolbarMousePan.png translates camera in the view plane;
    • view-dolly ToolbarMouseZoom.png moves camera closer to or farther from the scene.
  • Selected state and accompanying special cursor indicates current mouse mode.
  • Each mouse-mode causes a special cursor to be displayed, as feedback to user.
  • Hot-keys to select a mouse mode are contiguous on the keyboard (action): 1 2 3 4 5 (view transform:) 6 7 8.
  • View transform modes are also selected with key-modified mouse-clicks (see table below). But once a mode is selected, only left-mouse-button is required to transform the view in that mode.
  • All mouse modes apply consistently in 3D Viewer and Slice Viewers, except the view-tumble mode, which is not defined in the Slice Viewers. When Slicer is in view-tumble mode, either:
    • the view-tumble cursor would be displayed in the Slice Viewers but nothing would happen when the mouse is clicked *or*
    • the pick-and-manipulate cursor will be displayed when the mouse moves over the Slice Viewers even though the tumble-view icon is selected and the tumble-view cursor is displayed when the mouse moves over the 3D Viewer, *or*
    • a new cursor that indicates "mode-doesn't-apply-here" will be displayed when the mouse is over a Slice Viewer.
  • Novice user can select mouse modes by clicking icons above 3D viewer, and current mode is clearly displayed.
  • Intermediate or Expert user selects mouse modes by using a combination of keyboard keys and mouse buttons.
  • Works with one (left) mouse button only, but other mouse buttons are mapped (for tumble, track and zoom) for people who have and want to use them.
  • Context menu can be displayed with space bar, or with quick click-and-release of right mouse button.


---

Shown in the figure below:

  • the icons for mouse-modes (their appearance when highlighted and lowlighted),
  • suggested hot-keys and mouse-selection actions, and
  • cursor appearance when any one mode is chosen.
  • an example workflow for novice and expert users to perform the same simple task.

3D Slicer Mouse mode interaction design

---

Simple workflow storyboard

Below is how a user would use the mouse-mode interface to tumble, track and dolly the camera to get the 3D View to look the way they like, and then put down three fiducial points and adjust their position. A novice user's workflow is compared with an expert user's workflow.

1 (novice) tumble: click the view tumble mouse-mode icon ToolbarMouseRotate.png

  • --> mouse-tumble icon highlights and all others deselect, cursor changes to indicate mouse-tumble mode.
  • then left-Click and drag in the 3D Viewer to rotate the view.
  • if the mouse moves over a Slice Viewer, the cursor changes to indicate that the mode doesn't apply.

1 (expert) tumble: ctrl+left-Click and drag in the 3D Viewer,

  • --> mouse-tumble icon ToolbarMouseRotate.png highlights and all others deselect; cursor changes to indicate mouse-tumble mode; view tumbles.
  • if the mouse moves over a Slice Viewer, the cursor changes to indicate that the mode doesn't apply.

SB1.png

---


2 (novice) dolly: click the view dolly mouse-mode icon ToolbarMouseZoom.png

  • --> mouse-dolly icon hightlights and all others deselect, cursor changes to indicate mouse-dolly mode.
  • then left-Click and drag in the 3D Viewer to dolly the camera in and out.

2 (expert) dolly: shift+left-Click and drag in the 3D Viewer

  • --> mouse-dolly icon ToolbarMouseZoom.png highlights and all others deselect; cursor changes to indicate mouse-dolly mode; view zooms.

SB2.png

---

3 (novice) track: click the view track mouse-mode icon ToolbarMousePan.png

  • --> mouse-track icon highlights and all others deselect, cursor changes to indicate mouse-track mode.
  • then left-Click and drag in the 3D Viewer to translate the view left-right, and up-down,

3 (expert) track: alt+left-Click and drag in the 3D Viewer,

  • --> mouse-track icon ToolbarMousePan.png highlights and all others deselect; cursor changes to indicate mouse-track mode; view tracks.

SB3.png

---

4 (novice) place fiducials: click the mouse-place icon ToolbarMousePlace.png

  • --> mouse-place icon highlights and all others deselect, cursor changes to indicate mouse-place mode.
  • then click the Slice Viewer's Fit-To-Window icon SlicesFitToWindow.png
  • --> the Slice in that viewer (or in all viewers if their controls are locked) resize to fit the Viewer.
  • then left-Click three times at x,y locations in a Slice Viewer to put down three fiducial points.

4 (expert) place fiducials: press 5-key to switch into mouse-put (or place) mode

  • --> mouse put icon ToolbarMousePlace.png highlights, and all others deselect; cursor changes to indicate mouse-place mode.
  • then click the Slice Viewer's Fit-To-Window icon SlicesFitToWindow.png
  • --> the Slice in that viewer (or in all viewers if their controls are locked) resize to fit the Viewer.
  • then left-Click on three x,y locations in a Slice Viewer to put down three new fiducial points.

SB4.png

---

5 (novice) zoom the slice view: click the mouse-dolly icon ToolbarMouseZoom.png

  • --> mouse-dolly icon highlights and all others deselect, cursor changes to indicate mouse-dolly mode.
  • then left-Click and drag in a Slice Viewer to zoom in.

5 (expert) zoom the slice view: shift+left-Click and drag in the Slice Viewer

  • --> mouse-dolly icon ToolbarMouseZoom.png highlights and all others deselect; cursor changes to indicate mouse-dolly mode; view zooms.

SB5.png

---

6 (novice) select and move fiducials: click the mouse-pick-and-manipulate icon ToolbarMouseManipulate.png

  • --> mouse-pick-and-manipulate icon highlights, all others deselect, cursor changes to indicate mouse-pick-and-manipulate mode.
  • move mouse to location of fiducial in a Slice Viewer and see the fiducial highlight; left-Click and drag in a Slice Viewer to reposition the fiducial point.
  • move the mouse away from the fiducial and see it lowlight.

6 (expert) select and move fiducials: press 1-key to switch into mouse-pick-and-manipulate mode.

  • --> mouse pick-and-manipulate icon ToolbarMouseManipulate.png highlights, and all others deselect; cursor changes to indicate mouse-pick-and-manipulate mode,
  • then mouse-over a fiducial point, see it highlight, left-Click and drag to reposition it. Release mouse button and move away, and see the fiducial lowlight.

SB6.png

---

7 (novice) pan the slice view: click the mouse-track icon ToolbarMousePan.png

  • --> mouse-pan icon highlights and all others deselect, cursor changes to indicate mouse-pan mode.
  • left-Click and drag in a Slice View to pan.

7 (expert) pan the slice view: alt+left-Click to switch into mouse-track mode.

  • --> mouse-track icon ToolbarMousePan.png highlights and all others deselect; cursor changes to indicate mouse-track mode; left-Click and drag in the Slice Viewer to pan the view.

SB7.png

---

8 (novice) select multiple fiducials: click the mouse select-region icon ToolbarMouseSelectRegion.png

  • --> mouse-select-region icon highlights and all others deselect, cursor changes to indicate mouse-select-region mode.
  • sweep out a rubber band to enclose three fiducials and see them highlight.
  • when fiducials become selected, the "Deselect-all" icon ToolbarMouseDeselectAll.png highlights.

8 (expert) select multiple fiducials: press 2-key to switch into region-select mode.

  • --> mouse select-region icon ToolbarMouseSelectRegion.png highlights, all other icons deselect; cursor changes to indicate mouse-region-select mode.
  • sweep out a rubber-band box to enclose three fiducial points, see them highlight.
  • when fiducials become selected, the "Deselect-all" icon ToolbarMouseDeselectAll.png highlights.

SB8.png

---

9 (novice) move multiple fiducials: click the mouse-pick-and-manipulate icon ToolbarMouseManipulate.png

  • --> mouse-pick-and-manipulate icon highlights, all others deselect, cursor changes to indicate mouse-pick-and-manipulate mode.
  • left-Click and drag in a Slice Viewer to reposition the fiducial points.

9 (expert) move multiple fiducials: press 1-key to switch into mouse-pick-and-manipulate mode.

  • --> mouse pick-and-manipulate icon ToolbarMouseManipulate.png highlights, and all others deselect; cursor changes to indicate mouse-pick-and-manipulate mode,
  • left-Click and drag in the Slice Viewer to reposition multiple fiducials.

SB9.png

---

10 (novice) de-select fiducials: click the mouse-deselect-all icon ToolbarMouseDeselectAll.png

  • --> the last mouse-mode (mouse-pick-and-manipulate) remains highlighted, and the fiducials are deselected.
  • The "Deselect-All" icon lowlights.

10 (expert) de-select fiducials: press 4-key again to deselect the fiducial points

  • --> the last mouse-mode (mouse-pick-and-manipulate) remains highlighted, the fiducial is no longer highlighted.
  • The "Deselect-All" icon lowlights.

SB10.png


---

Please contribute comments here -- Thank you!:

PNL:

  • Tumble view mouse mode: We would prefer the cursor indicating "mode-doesn't-apply-here" like it can be seen on workflow example 1 in order to avoid confusion.
  • Deselected states of icons: This will not be a problem for anybody who uses slicer more often, but to a novice user the "deselected" state of the mouse mode icons might suggest that these modes are currently unavailable. This might be because in menues usually unavailable options are greyed out. Maybe all icons could be coloured all the time and the active mouse mode icon could be somehow indented or framed (like on the Maya screenshot)?
  • The icons, shortcuts and different cursors look very good and it's great to have consistency within different views and modules. Also, the shortcuts are really easy to memorize!
  • First we thought it would be good to have another mouse mode in which a mouse click on one voxel adapts all the views so that this voxels can be seen in all views (currently in slicer 2 this is done with holding shift and left clicking). But then we came to the conclusion that it would be even better if this functionality would be an independent hot key(shift+ click for example) that can be used in every mouse mode at any time, since we use this functionality a lot. Do you guys plan to have such a shortcut implemented?
  • Does the general undo also apply to accidential mouse mode selections? For example, say you've selected 10 different fiducials and accidentially hit hot key "4" that deselected everything. It would be great if this could be undone as well.
  • Minor thing that was not clear to me: if you want to change to say the "mouse dolly camera" mode using ctrl + right mouse key: Do you have to hold the ctrl key down all the time when zooming? Or do you only right-click once while holding crtl and then the mode is changed so that you can zoom in and out with only left mouse button?
  • Do you have already plans about how this mouse interaction schema will work in the Editor module? Will it be the same, just with more hot keys for the drawing tools for example?
  • Actually about the Editor Module: When drawing in the slices and the user mouses over to the 3D view, could the mouse then automatically be in tumble view mode in the 3D view?
  • (not directly realted) It would be great to be able to switch between one's favourite modules using hot keys, is there anything planned like that?
  • In case you have a labelmap overlayed on for example a structural volume: would it be possible to bind the mouse scrollbar(if existing) to fading the foreground in and out? Related to that: it would be good to have smaller increments available for the fading (compared to the fade bar currently available in slicer2) for more sensitive differences.

---

Slicer mockup and GUI screenshots from other packages:

Below are snippets of SketchUp's interface, and Maya's Interface. Maya's mouse modes switch between object transforms (translate, rotate and scale), object or region select, and an extrude function. SketchUp's mouse-mode icons switch between view transforms (translate, rotate, zoom) and an object extrude function.

SketchUp Example

Maya Example


---



Return to TOC

Return to Slicer3 Interface Design and Usability