Investigating Direct Manipulation of Graphical Encodings

What is this study about?

We investigate direct manipulation of graphical encodings as a method for interacting with visualizations. There is an increasing interest in developing visualization tools that enable users to perform operations by directly manipulating graphical encodings rather than external widgets such as checkboxes and sliders. Designers of such tools must decide which direct manipulation operations should be supported, and identify how each operation can be invoked. However, we lack empirical guidelines for how people convey their intended operations using direct manipulation of graphical encodings. We address this issue by conducting a qualitative study that examines how participants perform 15 operations using direct manipulation of standard graphical encodings. From this study, we 1) identify a list of strategies people employ to perform each operation, 2) observe commonalities in strategies across operations, and 3) derive implications to help designers leverage direct manipulation of graphical encoding as a method for user interaction.

The prototype used in our study

We developed an interactive data visualization using JavaScript. The visualization modules are built using the D3 toolkit. The tool we implemented has an Upload and a Reset button. The Upload button enables the interviewer to upload any of the visualizations created using the datasets used in our study. The Reset button allows the interviewer to reset the visualization after a participant has interacted with the visualization. We added interactivity to the encodings used in visualizations. For instance, users could change the position, color, width, and height of the bars in a bar chart. Or, they could change the size, position, and color of circles in the scatterplot. The tool shows one visualization at a time. Participants can perform each operation by directly manipulating the encodings in the visualization. For example, the interviewer uploads a bar chart visualization in our tool and asks a participant to perform an operation. The participant can manipulate different operations to convey her intention. The tool only enables participants to manipulate the encodings and does not recompute the visualization (similar to a drawing interface like Adobe Illustrator). Enabling the participants to convey their actions without the system reacting to those actions allowed us to observe participants' unrevised behavior, and drive system design to accommodate it.

Strategies employed by participants

In total participants employed 203 strategies to perform 15 different operations. We first sketched out each participant's strategy and grouped these sketches into 48 independent categories based on their similarities. Each sketch belongs only to one of the identified categories and all categories are exclusive. We then independently named each category of strategies (e.g.,``Stack points vertically'') and counted the total number of sketches ineach category. The interactive table below shows in rows the 15 operations participants performed during the study, and in columns the 48 strategies we identified. Each cell shows the number of times participants used the strategy in column to perform the operation in row. The higher the value in a cell, the darker the background of the cell. Hovering on each strategy shows its description.

Names
Reposition a few Points
Rearrange a few points to sort them based on their values
Stack Points Vertically
Rearrange a few points to position them vertically where they have some overlaps
Reposition Points Vertically
Rearrange a few points to position them vertically where they have no overlap
Regroup a few Points
Rearrange a few points to put them close together
Reposition to Target
Move a point to the target value
Retop to Target
Moving a bar so the top of the bar aligns with the target value
Reposition to Tick Mark
Move a point to the tick mark representing the target value
Overlay Bars
Move one bar on the top of another bar so they overlay
Sloping Bars
Move bars vertically to sort them based on their heights to create ascending or descending slope
Reposition Tallest & Shortest
Move the tallest bar to one extreme, then the shortest bar to another extreme
Stack two Bars
Stack one bar on the top of another one
Reposition Bars by Height
Move a few bars based on their heights
Resize a few Points Equally
Resize a few points equally
Resize & Reposition to Axis
Resize a few points, then move them to the tick marks on the axis
Resize Point
Resize a point to the target value
Select & Resize
Select a set of points and resize them
Resize by Values
Resize a few data points differently based on their values
Cover & Resize
Make one point big to cover few other points
Recolor one Group
Color few points that fall in the same range using the same color
Recolor Groups
Color few points that fall in different ranges differently
Select & Recolor One
Select all points, then color one of them
Select & Recolor Group
Select a set of points and color them
Recolor by Values
Color a set of points based on their values
Recolor a few Points
Color a few points using the same color
Reposition & Resize
Rearrange a few points to sort them based on their values, then resize them
Stack & Enclose
Rearrange a few points to stack them vertically, then resize a circle to enclose the stack
Reposition to Target & Resize
Reposition a point to target value, then resize it
Resize & Move out
Resize a point, then move it out of the visualization
Reposition Inline and Recolor
Rearrange a few points vertically/horizontally, then color them
Reposition by Range & Recolor
Rearrange a few points based on a range of values, then color them
Recolor, Reposition & Recolor
Color a point, then move a second point to the target value and color it the same color as the first point
Reposition to Target & Recolor
Move the point to the target value, then color it
Regroup & Recolor
Move a few points closer together, then color them
Recolor & Paint
Change the color of one data point, then move it over other points
Recolor & Dip
Color a point, then move other data points over it
Resize a Point and Recolor
Resize a single point, then color it
Resize & Recolor
Resize points based on their values, then color them
Cover & Recolor
Make one point big to cover other points, then color it
Reheight Ascending
Changing the height of the bar in an ascending order
Reheight to Target
Changing the height of the bar to the target vlaue
Enwidth
Increase the width of the bar
Enheight & Enwidth
Increase the height of the bar to exceed the x axis, then increase its width
Reposition & Enwidth
Drag two bars close together, then increase the width of one of the bars
Recolor & Enwidth
Color two bars and increase the width of one of the bars to cover all the other bars
Enwidth & Recolor
Increase the width of the bar, then color it
Enwidth & Cover
Increase the width of a bar to cover all the other bars, then color it
Intersect & Recolor
Drag the bottom of the bar to intersect with the tick mark, then color it
Recolor & Reheight
Color the bar, then change its height to the target value
O1: Assign a data attribute to an axis
7
3
1
1
O2: Switch from a scatterplot to a bar chart
2
5
1
3
2
1
1
1
O3: Navigate the point over time in a scatterplot
5
4
5
1
1
O4: Adjust the value of a data point
3
1
2
4
O5: Group the two bars into one bar
9
2
3
1
O6: Sort the bar chart
1
3
9
1
1
O7: Change the size of all data points
8
4
1
1
O8: Assign a data attribute to the size of points
1
1
7
2
O9: Change the color of all points
3
5
1
2
1
2
O10: Assign a data attribute to the color of points
1
8
1
O11: Change the color of all bars
3
7
2
2
2
O12: Assign a data attribute to the color of all bars
10
1
1
O13: Navigate the point over time in a bar chart
4
9
1
O14: Adjust the value of a bar
2
9
2
O15: Expand the range of a bin in a histogram
3
1
9
1
1