title |
---|
TremCasso- Iteration 1 |
Drawing/colouring is generally considered a means of artistic expression or a way to relieve stress. However, for an individual with tremors, having to deal with adapting to physical tools or UIs that are designed with the general population in mind can make it a frustrating process and take away from the joy of something that is otherwise basic and simple. We hope to address the needs of this user population and make practicing art more fun for them through our project TremCasso- an accessible drawing/colouring tool for people with motor skill impairments caused by hand tremors.
For the first iteration of this project, my team and I started with a brief literature survey to inform our design choices to suit our target population. We then decided to individually implement different concepts for the Colour Picker required for the drawing tool.
In this blog, I will go a little more into our experience, the literature survey and the reasoning behind my design choices for the Colour Picker and my process of developing it.
Owing to the commercially available adaptive tools like weighted pens for people with tremors my initial impression was that weighing down the hand movement would help to dampen the tremors and make the UI more accessible. However, literature revealed that this isn't necessarily ideal and that the pointer must instead be easy to move and less sensitive to small movements. This study also found that easy-to-reach buttons to reduce fatigue and design to facilitate holding the pointer in position during clicking were desirable attributes of interfaces for this target population[1]. Larger buttons and adequate spacing between them [2], using sliding rather than clicking [3], and introducing a delay in clicks[4] are other design modifications that have been proposed to make the UI more suitable for the target population.
The initial version of the UI consists of 2 functional screens,
- The Canvas- where the user can draw with the selected colour
- The Colour Picker- to select the colour
and a menu bar at the bottom allowing the user to navigate to the colour picker and settings page.
A damping effect has been applied to the end effector while on the canvas to simulate the effect of a weighted pen. Although there is some conflicting evidence in literature on whether this is ideal (although weighted pens work to some extent), I left the damping in for this iteration until we come up with a better solution for accommodating tremors while drawing on a blank canvas.
To build the canvas, I created a separate Java class for the colouring feature of the canvas as I was hoping to make it as modular and reusable as possible. It works by drawing a circle of the specified radius and colour onto the PGraphics object at the position of the end effector.
canvas.beginDraw();
canvas.noStroke();
canvas.fill(color(r,g,b));
if (drawingMode){
canvas.circle(Math.round(x), Math.round(y), rad);
}
canvas.endDraw();
The colour picker consists of a palette of colours, a display of the selected colour, and buttons to manipulate the position of the colour selector.
The colour selector is designed to move in the direction of the button where the end effector rests. These buttons are large to make it easy to position the end effector at the desired target and are closely placed to reduce fatigue caused by large movements. Since there are only four buttons it makes it possible to present a wide variety of colour options within limited space and also to navigate to the desired colour without fine motor control.
The colour selector is designed with a wrap-around feature (for example, it appears on the first column left side if the right direction button is pressed when it is on the last column on the right). Also, to reduce the risk of accidentally triggering neighbouring buttons a damping effect is applied to the area between the buttons. Further, a constant delay is introduced in button triggering when the end effector rests on them to avoid accidental triggering.
if (s.h_avatar.isTouchingBody(up)){
if (checkDelay(0))
cp.up();
}
...
...
...
public boolean checkDelay(int index){
if (millis()-counters[index]>delay){
counters= new float[]{millis(), millis(), millis(), millis()};
click=true;
return true;
}
else
return false;
}
Each of the buttons is also assigned a hotkey: W for up, S for down, A for left and D for right respectively.
A haptic effect somewhat resembling the feeling when a button is pushed has been applied to the end effector at each click. This is done by introducing a small force in the vertical direction at each click.
public void YforceSetter(){
if (click){
count++;
if (count==10)
{
click=false;
count=0;
}
f_ee.set(f_ee.x, f_ee.y+2.5);
}
}
During our meeting with the mentors and TAs, it became apparent that one of the major disadvantages of my design concept is the long time it takes to navigate from one colour to another. Even considering that the delay would be eventually configurable to the desired level if had to still be retained at a high enough level to avoid accidental triggering, it meant a significant wait time to get to the desired colour if the colours were far apart.
To try to alleviate this, I decided to try out a slightly nuanced implementation of the first version based on some of the feedback and ideas that came up during the meeting with the mentors and TAs. One of the ideas that was discussed during the meeting was to make it harder to enter or trigger something and thereby ensure that triggering was intentional.
Playing on this idea, I implemented the button with a gradient of delay- i.e. the delay would depend on the position of the end effector on the large button. A force gradient was also applied on the button so that intentionally pushing further into the button with greater force causes the colour selector to move faster. The gradient that has been implemented in this prototype has three discrete levels and can be illustrated for the 'down' button as shown below.
if (s.h_avatar.getY()<positions[1]+3.5)
{
delayGrad=500;
buttonForces=2;
}
else if (s.h_avatar.getY()<positions[1]+4.25)
{
delayGrad=1500;
buttonForces=1;
}
else
{
buttonForces=0;
delayGrad=3000;
}
Therefore with this design, the user can intentionally push harder to make the colour picker move faster while still avoiding accidental triggering owing to tremor since the delay is higher at the easily accessible portions of the button.
For this version, I removed the damping effect of the area between the buttons and replaced it with a hard invisible wall since the damping effect was interfering with the resistive forces. I also tweaked the 'click' haptics described earlier to make it act in the horizontal direction since the earlier version could no longer be felt when the resistive force was also acting in the vertical direction.
Given the limited time between the feedback session and the deadline, for now, I have only implemented this on the down button (rather than the entire UI) to be able to test and demonstrate the concept. I've set the button colour to gray to highlight this change.
Everything else mentioned in the section above (V0.1) was retained as is.
The Spacebar is configured as a disable/enable toggle key throughout the UI- disabling/enabling the drawing and the colour pciker buttons on the canvas and colour picker respectively when pressed so that users can avoid making errors if they ever feel fatigued, out of control or simply wanted to navigate freely through the application without accidentally painting over the canvas or changing colour selection.
The settings button currently leads to a placeholder. This page is intended to contain application settings like click delay, damping etc. and was only placed in this iteration to demonstrate how an invisible wall separating the 2 buttons (settings and palette) could help to avoid accidentally triggering the wrong button.
The functionality of the 'disable' in the colour picker and the canvas has been demonstrated in the video below. The video also shows how the invisible wall between the two buttons serves as a separation to avoid accidental triggering and presents the overall V0.1 UI.
You can find the code for both V0.1 and V0.2 here: TremCasso Iteration 1
I thought this iteration was fairly successful in that we managed to get 3 quite different colour picker concepts out of it. I was initially a little worried about how implementing the same thing in different ways would affect the overall progress of the project. However, ultimately, the approach we took made it possible to give each other feedback/ suggestions within the team since we were working on similar aspects and encountering similar problems, to explore and brainstorm a lot of different ideas, and has put us in a much better position to receive expert advice on our varied concepts. Besides, we still managed to implement a bare minimum colouring tool which is a fair bit of progress!
For this iteration, we had initially intended to analyze the various resulting designs and to converge our concepts into a final product. However, following our meeting with the mentors, the better plan of action seemed to be to try to refine the individual designs further. I found that the feedback session was especially helpful to rethink not just our course of action but also our design concepts. It helped me understand my design's pros and cons and explore new variations/ modifications. If there's one thing I'd change it'd be to try to seek feedback within the team and from the mentors and TAs more actively and earlier on in the iteration.
For the next iteration, we are hoping to get some expert advice on our concepts and tweak the colour picker and overall application design accordingly. Besides just refining the colour picker, there are also many other aspects to our project such as trying out the haptic effects on the canvas (for example, walls on outlines of a picture) and end effector modifications which I'd be excited to explore.
[1] Begnum, Miriam. (2010). Improving Computer Interaction for People with Parkinson's Disease.
[2] Hagen, Simen & Sandnes, Frode. (2010). Toward accessible self-service kiosks through intelligent user interfaces. Personal and Ubiquitous Computing. 14. 715-721. 10.1007/s00779-010-0286-8.
[3] Wacharamanotham, Chat & Hurtmanns, Jan & Mertens, Alexander & Kronenbuerger, Martin & Schlick, Christopher & Borchers, Jan. (2011). Evaluating swabbing: A touchscreen input method for elderly users with tremor. Conference on Human Factors in Computing Systems - Proceedings. 623-626. 10.1145/1978942.1979031.
[4] Khan, Muhammad & Ahsan, Kamran & Hussain, Muhammad. (2017). Time Based Intelligent Touch User Interface for Hand Tremor User in Self-service Kiosk. Journal of Huazhong University of Science and Technology. V. 115-125.