This is a small collection of design and graphic user interface usability observations, tips, tricks and how-to's, I've collected over three decades. It's random, unsystematic and by no means a replacement for such serious knowledge treasuries like Ask Tog, Nielsen-Norman Group, UX matters and many others.

This part is always "under construction", always in the process of being enriched and updated.

Cartoons are courtesy Victor Bogorad

  Click on any topic on the left to read more.

Affordances or Cues

James Gibson wrote about the idea of affordance in 1979. He described affordances as action possibilities in the environment. In 1988 Don Norman modified the idea of affordances in his book The Design of Everyday Things. He referred to the idea of perceived affordances: if you want people to take action on an object, whether in real life or on a computer screen, you need to make sure that they can easily perceive, figure out, and interpret what the object is and what they can and should do with it.

Think about affordance cues when you design. By giving people cues (mostly visual) about what they can do with a particular object, you make it more likely that they will take that action. To maximize the perceived affordance of "clickability", color and underline the link text, make buttons look like buttons. Users shouldn't have to guess or scrub the page to find out where they can click. If an element is clickable, for example, it must appear that way, or a user may never try clicking it. In touch screens, where is no hover highlight affordance, this is even more important. How new users understand what to do?

You deal with them every day. There are typically hidden in:

  • Object design. For example, clickable buttons or links have distinctive visual style.
  • Tips. Either as icons next to them. Or direct message like "see more", "more info", "read more", etc.
  • Appearance change on cursor hover.

Four principles for screen interfaces:

  • Follow conventional usage, both in the choice of images and the allowable interactions.
  • Use words to describe the desired action (e.g., "click here" or use labels in front of perceived objects).
  • Use culturally acceptable metaphor.
  • Follow a coherent conceptual model so that once part of the interface is learned, the same principles apply to other parts.

A bit of Behavioral Psych

"Knowledge is knowing a tomato is a fruit.. Wisdom is not putting it in a fruit salad."

Our Brain Capacity
The human brain is capable of 1016 processes per second, which makes it far more powerful than any computer currently in existence. But that doesn't mean our brains don't have major limitations. The lowly calculator can do math thousands of times better than we can, and our memories are often less than useless.

How many clicks are too many
Clicks reduction, as the only way to minimize the process time, has recently become an obsession in UI design. The truth, however, is more complicated.

  • 3-click away principle is a MYPH. In more than 200 user studies users never complained about number of clicks.
  • Each click is a decision point. It's crucial to make user sure what content he will find when he clicks.
  • Vague, nondescript (various "click here" or "learn more" that assume the user IQ being less than his shoe size), misleading or jargon-filled links cause people to hesitate, to ponder whether this is the right decision. This amplifies the click itself and it is what has created this myth of too many clicks.

Use "+" and "-" button to see more:

+ -
The total time user spends is a sum of human and machine actions. One can measure it using CogTool or use data provided by Card, Moran and Newell in 1968, called CMN-GOMS methods.
  • Eye fixation - 230[70, 700] milliseconds
  • Eye Movement - 30 milliseconds
  • Perceptual Processor - 100[50, 200] milliseconds
  • Cognitive Processor - 70[25, 170] milliseconds
  • Motor Processor - 70[30, 100] milliseconds
  • Press a key or button (K)
  • Best typist = .08 seconds
  • Good typist = .12 seconds
  • Average skilled typist = .20 seconds
  • Average non-secretary = .28 seconds
  • Typing random letters = .50 seconds
  • Typing complex codes = .75 seconds
  • Worst typist = 1.2 seconds
  • Point with a mouse (excluding click) (P) = 1.1 seconds
  • Move hands to keyboard from mouse (or vice-versa) = .4 seconds
  • Mentally prepare (M) = 1.35 seconds
  • Wait for a computer to respond to input (R) - vary

While it’s hard to predict “R”, it's clear that the goal is to reduce "P" and "M". "P" time will increase exponentially, if the number of active (clickable) elements exceeds 8-12 (the approx. number of things one can grasp simultaneously). Alas, "M" time is the true test of how intuitive your UI is.

How to reduce “M” or predictive behavior of “next”.

Try to define all possible “next” actions in order of probability. A mental model of a task is typically streamlined and focused on the fundamental components of the task. Although there may be myriad optional details associated with a given task, the basic components should not have to compete with the details for the user’s attention. This is your Main Task, it defines the next move. I call this "next defines now" rule.
+ -
Cognitive Biases in Bounded Rationality

Developed by Herbert Simon in late 40-ies, the Bounded Rationality is the idea that in decision-making, rationality of individuals is limited by (1) the information they have, (2) the cognitive limitations of their minds, and (3) the finite amount of time they have to make a decision. While we can do little to change (1) and (3), we can take (2 - the cognitive biases) into consideration. Cognitive biases are glitches in our thinking that cause us to make questionable decisions and reach erroneous conclusions.


Confirmation Bias: we love to agree with people who agree with us. It’s an unconscious act of referencing only those perspectives that fuel our preexisting views. Be reasonably conservative; follow the most established examples.
In-group Bias: a manifestation of our innate tribalistic tendencies. Appeal to a group of users, criticize competitor's ways and practices.
Gambler's Fallacy: if it worked ones, it'd most likely work again. Imagine if it worked twice... Don't expect your customers to easily fall for something they didn't do before. Hot hand luck. Your outsider position may be a plus.
Post-Purchase Rationalization or Buyer's Stockholm Syndrome: users, who bought into less than perfect solution, will do anything to rationalize using it.

Observational Selection Bias: noticing things we didn't notice that much before, because we bought into those things.

Status-Quo Bias: we like to stick to our routines. If it ain't broke, don't fix it. Negativity Bias. Dwelling on negativity at the expense of genuinely good news. Don't expect users to notice many improvements over remaining flaws.

Bandwagon Effect: if you get at least few of the stakeholders to accept it, chances are you're golden.

Projection Bias: we tend to assume that most people think just like us. Well, they don't. That's why you are not an ideal persona to test for. We assume we're the most normal and typical. False consensus. Using "we", "users in general", etc., when there is no calling for it.

The Current Moment Bias: in general, we prefer healthy food, but now we want chocolate.

Anchoring Effect: we notice the difference in value, but not the value itself. How many times have you heard "this solution is better (faster, more intuitive, easier to learn, looks better, etc.) rather than "do we even need this"? The research found that ignoring part of the information (with a decision), rather than weighing all the options, can actually lead to more accurate decisions.

Apophenia: the experience of seeing patterns or connections in random or meaningless data.

When designing or re-designing the UI, always consider ALL aspects of the heuristic evaluation.

Buttons

Despite of the physical world origin, buttons have survived the general victory over skeuomorphism. They are still there, maybe less physical in appearance. Their design and placement should take into consideration its nature. For example:

Call-to-action (CTA) buttons. The main point is that CTA buttons most often invoke server actions. Some of the actions can cause an irreversible action. Then a prompt "Are you sure.." is in order. Default or affirmative button (normally "OK", "Submit" etc.) should stand out.

Toggle buttons don't work well in groups (i.e. toolbars).

Positioning

In a Form

The obvious answer is "C". "D" and "E" is the second place user would look for a button. "A" and "B" is the last. Study shows that all versions work except for "E".


Spelling out the action. Very often a simple "OK" is not enough. Keep with one of the Jacob Nielsen's top heuristic principles: the user should not have to remember information from one part to another. Label buttons with what they do.

Software as "Canned Intelligence"
Based on a formal definition of the Good Old-Fashioned Artificial Intelligence, we are not there yet. From the other point, software is nothing but a little piece of AI. Let's call it "canned intelligence" (CI). So in reality it's not so much of human-computer interaction (the computer is a simple number crunching monster), but human-humans interaction via this "canned intelligence".

Practically, no matter what your product is designed to do, it's been done before. The goal is to do it better, i.e. faster, more accurate, more intuitive. If you can clearly demonstrate it, users will flock to your tray.

Believe it or not, this UI was used to dispatch ambulances once. How many lives were lost just because of it? It's a radical example. Most of the time bad UX just wastes a lot of users' time. Multiply on number of users and you'll end up with many lifetimes wasted.
Colors

A bit of color theory.

Blue Myth
Only two percent of all retinal cones are blue-sensitive cones and the eye brings blue into focus in front of rather than on the retina, visual acuity for the blue range of the spectrum is poor and it decreases with age. User performance in symbol identification is poorer with blue symbols than with symbols of any other color.

Where to use color-coding:

Using more than 6 colors is not recommended. Color-coding must be consistent throughout the entire UI.

Colors and words have a lot in common. We all learn how to use words at an early age but unfortunately, few learn how to use color effectively. Unless you spend many hours mixing paints and trying out their various effects and nuances, speaking with colors can be like talking in a foreign language.

Most people don't learn the second language. In their color preferences, few ever go beyond primary colors. The following is based on US survey, made by artists Komar and Melamid in 1995.

1st favorite color   2nd favorite color  
Blue
Green
Red
Black
Purple/Violet
Brown
Pink/rose
Beige/Tan
White
Grey
Yellow
Mauve
Fuchsia
Maroon
44%
12%
11%
4%
4%
3%
3%
2%
2%
2%
2%
2%
2%
2%
Blue
Green
Red
Black
Purple/Violet
Brown
Pink/rose
Beige/Tan
White
Grey
Yellow
Mauve
19%
17%
16%
7%
5%
4%
6%
3%
4%
3%
3%
2%

Colors only work in combinations.

Inside (smaller) squares have the same color

"A" and "B" squares are exactly the same


Our mood plays very important role too. Walk in a garden and look around you. Nature doesn't make mistakes with color. No matter how vivid or subtle, they always seem to work together. Why? Because the garden is pleasant..

Komar and Melamed didn't stop with colors. They have sent a long list of questions around the world, then "painted by numbers" the result.

USA Most Liked USA Least Liked

Here are some of the questions:

Do you prefer seeing bold, stark designs or more playful, whimsical designs? bold, stark: 39% playful, whimsical 49%  
Do you tend to favor paintings with sharp angles or ones with soft curves? sharp angles 22% soft curves 66%  
Which patterns do you like better: geometric patterns or more random uneven patterns? geometric 30% random 62%  
Do you like to see colors blend into each other or do you like it when different colors are kept apart? blended 68% separate 18%  
In general, which would you say that you prefer? When the artist uses more vibrant shades, paler shades, or darker shades of color? vibrant 36% paler 32% darker 22%
 
Complex features

"Things should be made as simple as possible, but not any simpler." - Albert Einstein

When adding new features, keep in mind that 80% of users use only 20% of software features.

Accessibility Compliance and ADA
"If you don't know the way, be guided by principles."

People have disabilities. You have to be aware of them. In the case of the UI design, it's mostly visual disabilities: contrast and color blindness. There are other things like support for the tabbed navigation, alt text for every image, etc.

Hopefully, today some UI design apps like Sketch have tools for that, so you can check you text contrast and see how people with different types of color blindness will see your stuff.


From ADA Compliance Rules

US Gov. Section 508 and User Agent Accessibility Guidelines (UAAG).
Confirmation and Progress Indicators
The only actions and situations that don't require visual confirmation are: Way to provide the visual feedback:

Temporary vs. permanent status display. If your work doesn't require display of status, remove status update message after 2-3 seconds.

Response Times and how to use them in Progress Indicators (loaders, installers)

0.1 - 1 second is about the limit for having the user feel that the system is reacting instantaneously, meaning that no special feedback is necessary except to display the result. No progress indicator is needed.

spinner 1 - 3 second is about the limit for the user's flow of thought to stay uninterrupted, even though the user will notice the delay. Normally, no special feedback is necessary during delays of more than 0.1 but less than 1.0 second, but the user does lose the feeling of operating directly on the data. So, having a spinning wheel is recommended.
progress bar 3- 10/12 seconds is about the limit for keeping the user's attention focused on the dialogue. For longer delays, users will want to perform other tasks while waiting for the computer to finish, so they should be given feedback indicating when the computer expects to be done. Feedback during the delay is especially important if the response time is likely to be highly variable, since users will then not know what to expect. For all cases over 1.0 sec. a real progress indicator (bar) is recommended. Progress bar shows either %% of in the form of "XX of XXX is loaded (installed, etc.)"

[Miller 1968; Card et al. 1991]

When waiting time exceeds it, it's a good practice to provide user with notification like: "Your request (application, inquiry, etc.) is in the process (scheduled, etc.). You will be notified (receive an email) when it's ready."

The Power of Convention

"To establish yourself in the world a person must do all they can to appear already established." - La Rochefoucauld

We're creatures of conventions (see the bit about the Behavioral Psych). In UI design they are our most powerful allies, saving us from the necessity to explain everything. It's not only that whatever you do, it's likely been done many times before. It's also a good chance your users did that too.

For example:

Copy box

Use when you wish to present information that the user needs to copy (and later paste into another application). Designate data to be copied in different font. Use block tag.

Object-oriented CSS
Main Principles of OOCSS
Separate structure and skin Define repeating visual features (like background and border styles) as separate “skins” that you can mix-and-match with your various objects to achieve a large amount of visual variety without much code. See the module object and its skins. Separating structure and skin can also mean using classes to name your objects and their components, rather than relying solely on the semantics of HTML. For example, the media object is named with class="media", and its components are named with class="img"(for the image/video component) and class="bd" (for the body/text component). By referencing these classes in your stylesheets (say, rather than directly styling the element), your HTML can be flexible. For instance, if a new media element were to take off in the next few years (for example, SVG), it could be integrated into the HTML without having to touch the CSS. Separate container and content Essentially, this means “rarely use location-dependent styles”. An object should look the same no matter where you put it. So instead of styling a specific <h2> with .myObject h2 {...}, create and apply a class that describes the <h2> in question, like<h2 class="category"> This gives you the assurance that: (1) all un-classed <h2>s will look the same; (2) all elements with the category class (called a mixin) will look the same; and 3) you won’t need to create an override style for the case when you actually do want .myObject h2 to look like the normal <h2>. Avoid location dependent styles So rather than styling a whole page based on the body class you create smaller modules on the page and extend them with subclasses as necessary. This allows you to maximize reuse of code. Reusability is also improved because of the OOCSS Framework encourages abstracting CSS structural styles and skin level styles. .button { width: 200px; height: 50px; } .box { width: 400px; overflow: hidden; } .widget { width: 500px; min-height: 200px; overflow: auto; } .skin { border: solid 1px #ccc; background: linear-gradient(#ccc, #222); box-shadow: rgba(0, 0, 0, .5) 2px 2px 5px; } .skin-alt { border: solid 1px #000; background: none; box-shadow: rgba(0, 0, 0, .9) 2px 2px 5px; } Avoid the descendant selector, attaching classes to elements in stylesheets Instead of using a selector such as .sidebar h3, give the h3 its own class and then style the class itself. <div class="sidebar"> <h3 class="article-heading"></h3> </div> Descendant .sidebar h3 { font-size: 20px } Element in stylesheet h3.article-heading { font-size: 20px; } Class only .article-heading { font-size: 20px; } It’s important to note that there are also levels of strictness in the interpretation of guidelines of OOCSS. Some people will tell you you can never use descendant selectors or that you can never use an ID selector. In other words, almost every HTML element will have at least one class applied to it so that you don’t have to use descendant selectors. <h3> becomes <h3 class="h3"> Project on GitHub.
Always start your projects with HTML5 boilerplate CSS.
Normalize.cssis a customizable CSS file that makes browsers render all elements more consistently and in line with modern standards.
UI Customization

Since it's nearly impossible to satisfy all your users with the same set of features (be it visual style, default settings or else), it's good to have some UI customization available. The more different tasks (user journeys) your app offers, the more is the need for that.

It's largely depends of the degree of freedom of action. Where are you between 100% pre-determined process (say, TurboTax) and 100% free fall (for example, 3d or paint app)?

Sometime (especially for web apps) you can provide automatic role-based customization based on the user login.

Some users like to re-organize things in the UI:

For example, dockable panels
Common in the desktop applications (browsers don't support docking), dockable panels allow user to arrange items on the screen to his liking and for maximum screen real estate utilization. Unlike collapsible panels, docking doesn't remove panels from the view.

Docking Control Less frequently used panels can be minimized and docked to the side


What to dock/undock: In rare cases developers allow user to customize everything by allowing user to dock/remove anything to any of 4 sides.

Dashboards
We're accustomed to dashboards around us, so is a good way to use it as a starting point for command and control. Especially useful for the software with limited and repetitive tasks. Before start, let's figure out:

What to display:

User behavior:

Dashboard Design:

Since full screen or TV-based dashboards don't provide manual (if any) control, you can use:

Sometime having a lot of negative data on one screen can lead to dire consequences. (I designed this Raspberry Pi -based executive dashboard in 01/2019. The mass layoff followed shortly.)

Default Values. What are they for?
Think carefully about the default state of any feature. It can be a great time saver or the most daunting thing to overcome. If not sure, conduct the user testing.

Thorough heuristic evaluation will help you to determine it.
Dieter Rams Ten principles for good design




Good design is innovative. The possibilities for innovation are not, by any means, exhausted. Technological development is always offering new opportunities for innovative design. But innovative design always develops in tandem with innovative technology, and can never be an end in itself.

Good design makes a product useful. A product is bought to be used. It has to satisfy certain criteria, not only functional, but also psychological and aesthetic. Good design emphasises the usefulness of a product whilst disregarding anything that could possibly detract from it.

Good design is aesthetic. The aesthetic quality of a product is integral to its usefulness because products we use every day affect our person and our well-being. But only well-executed objects can be beautiful.

Good design makes a product understandable. It clarifies the product’s structure. Better still, it can make the product talk. At best, it is self-explanatory.

Good design is unobtrusive. Products fulfilling a purpose are like tools. They are neither decorative objects nor works of art. Their design should therefore be both neutral and restrained, to leave room for the user’s self-expression.

Good design is honest. It does not make a product more innovative, powerful or valuable than it really is. It does not attempt to manipulate the consumer with promises that cannot be kept.

Good design is long-lasting. It avoids being fashionable and therefore never appears antiquated. Unlike fashionable design, it lasts many years – even in today’s throwaway society.


Good design is thorough, down to the last detail. Nothing must be arbitrary or left to chance. Care and accuracy in the design process show respect towards the consumer.

Good design is environmentally-friendly. Design makes an important contribution to the preservation of the environment. It conserves resources and minimises physical and visual pollution throughout the lifecycle of the product.

Good design is as little design as possible. Less, but better – because it concentrates on the essential aspects, and the products are not burdened with non-essentials. Back to purity, back to simplicity.

Dockable Panels & Menus


Collapsible gadgets

There are many types of collapsible gadget. They are great space savers, but be careful: the expand/collapse navigation has to be 100% clear. If in doubt that users click/tap on the header, add suggesting icons.

Keep in mind:

Explicit vs. Implied Actions
Scenario: user has to move an item from box 1 (menu, list, etc.) to box 2.

Explicit:

  1. Select item to move
  2. Select "move"
  3. Select move to from the opened directory
  4. Click to act
Implied: drag and drop item from one area to another. This is faster, but consider:



Feedback
Nothing works without feedback, even the government.

  • Show users the system's current state.
  • Tell users how their commands have been interpreted.
  • Tell users what's happening. A background process should never display a dialog or window in which the user is required to change settings or supply information. If a background process must communicate with the user, it should start or bring forward the foreground app. This is important because the user may not know (or remember) that a background process is running and receiving communication from it would be confusing.
  • When used sparingly, animation is one of the best ways to show a user that a requested action is being carried out.

Here is an example of a jarring feedback neglect that affects thousands of people daily:

Filtering

Filtering is necessary to avoid data clutter, server polling and overwhelming user. There are 3 stages of filtering the displayed data.

When designing filters, consider:

Typical data grid (table) filtering:

Display only filter values that apply to the available inventory.

Logic Flows
There is neither standard for logic flows, nor a single file format for them. Flow design apps are endless. So it usually ends up being passed around as a PDF or bitmap. If you app can produce an HTML you can share with others, you're one step up. if it's even interactive, you're a guru.

This is unfortunate, especially because there is an industry standard for it - BPMN (business process management notation). And it's more than just a library of logic elements: icons, objects, connectors, gates, etc. It supports a fully grown industry of Business Process Management applications. If you and your colleagues master it, it'll become a huge time-saver and headache killer.

BPMN flow
  1. Define swimlines. For any web app, it's user(s), front-end, back-end.
  2. Make sure the app you're using to create it has entire library of BPMN symbols. I had to create one for Axure myself.
  3. Using correct components will save you troubles designating different things like pages, gates, users, DBs, etc.
  4. Try to use apps that allow online commenting. See prototypers section.
Forms

If you don't want to collect ANY errors, irrelevant or malformed data, use 100% multiple choice forms, where user can only select from the list, radios or checkboxes.

Single Page Form or Wizard Wizards are good in the following scenarios:

Single Page Forms are good in the following scenarios:

There are plenty of sources for good form templates like this.

+ -
Form elements positioning.

Some eye tracking experiments were performed to determine the best label/data alignment, position and emphasis.


Test A: Left-Aligned Labels to the Left of Input Fields Test B: Right-Aligned Labels to the Left of Input Fields
Test C: Left-Aligned Labels Above Input Fields Test D: Bold Labels Above Input Fields

The winners are B & D. Still most of the time labels are placed on the left, because it conserve the vertical space.

To conserve horizontal space, people often use multi-column forms. This adds nothing to data legibility or speed.

Autocomplete
Do you follow Jacob Nielsen 10 commandments?

  1. The design should always keep users informed about what is going on, through appropriate feedback within a reasonable amount of time.
  2. The design should speak the users' language. Use words, phrases, and concepts familiar to the user, rather than internal jargon. Follow real-world conventions, making information appear in a natural and logical order.
  3. Users often perform actions by mistake. They need a clearly marked "emergency exit" to leave the unwanted action without having to go through an extended process.
  4. Users should not have to wonder whether different words, situations, or actions mean the same thing. Follow platform and industry conventions.
  5. Good error messages are important, but the best designs carefully prevent problems from occuring in the first place. Either eliminate error-prone conditions, or check for them and present users with a confirmation option before they commit to the action.
  6. Minimize the user's memory load by making elements, actions, and options visible. The user should not have to remember information from one part of the interface to another. Information required to use the design should be visible or easily retrievable when needed.
  7. Shortcuts — hidden from novice users — may speed up the interaction for the expert user such that the design can cater to both inexperienced and experienced users. Allow users to tailor frequent actions.
  8. Interfaces should not contain information which is irrelevant or rarely needed. Every extra unit of information in an interface competes with the relevant units of information and diminishes their relative visibility.
  9. Error messages should be expressed in plain language (no error codes), precisely indicate the problem, and constructively suggest a solution.
  10. It’s best if the design doesn’t need any additional explanation. However, it may be necessary to provide documentation to help users understand how to complete their tasks.


Icons

"A sign is something which is itself sensed and which indicates to the mind something beyond the sign itself. To speak is to give a sign by means of an articulate utterance." (St Augustine)

All signs can be grouped into 3 categories:

Index Related to its object by a direct physical connection
Icon Related to its object by likeness
Symbol Relates to its object by convention only

Symbolic signs, by their very nature, will continue to be the most sophisticated method of interacting with computers, at least until our descendants, or another semiotic entity, evolves the next step in the saga of semiosis.

In designing icons consider (in order of importance):

*  "It turns out that users select the undo function from a menu 80% of the time, as the undo "icon" does not adequately convey the idea of undoing." (Dave Kansas "The Icon Crisis: Tiny Pictures Cause Confusion", The Wall Street Journal.)

Layout of Things
"Rivers of White"
Leave plenty of white space around type and graphic elements (an eighth to a quarter inch depending on size relative to the layout).

Leave a little more white space at the bottom of a page relative to the top of the page (e.g., 0.75 inch at the top and 1 inch at the bottom). This will optically balance the page so it won't look like it is slipping off at the bottom.

Create a wide margin to direct the reader's attention into the copy or image area.

Use at least a quarter-inch gutter between columns.

Use left aligned (unjustified) text to create visual relief. Be careful that the "rag" indents on the right are not too big.

Increase leading (white space between lines) to lighten the look of the page.

Invite the reader into the page by leaving open space at the top and along the left margin.

Pixels are not dollars, don't sacrifice the breathing space.

If your developers don't have the luxury of a UX designer service, create layout templates for them. For example:

Alarms, Notifications & Tips

Unlike notifications, alarms are mostly system feature. Color coding and shape variance help to classify them by severity. Use notifications for status change.

Avoid exposing system' own dirty laundry, offering features that reflect the system's internal view of the data rather than users' understanding of the problem space.

For simple info, success or any other type of messages that don't require user response, use timer.

Error messages

No matter how cute, messages like "oops, something went wrong" are sign of very bad UX. It's not useful, when an error message simply says something is wrong, without explaining why and how the user can fix the problem. Such messages leave users stranded.

Error message guidelines:
Explicit indication that something has gone wrong. The very worst error messages are those that don't exist. When users make mistakes and get no feedback, they're completely lost. For example, email offers several situations where explicit indication would be useful. Such as: when you send a message that gets eaten by the system and never reaches the recipient.

Another good example? When you state in an email that you'll include an attachment, but forget to do so.

Finally a job for that annoying paper clip: "You seem to want to attach a file to this message, but you have not done so. Would you like to attach one now?"

The worst usability offense is not clearly indicate what errors user had made, especially in the form filling UI. It's a good practice to specify the total number of errors and highlight (usually with red) all mistakes or omissions. If you can display errors only, so the user doesn't have to scroll to them, it's even better.

Tool tips

Why optics are important in any UI work
For example, when aligning text block with a different background, consider the density of the background:

optics

For more read this.
Prompts
Use "Are you sure you want to clear all data?" prompt for Reset, for it destroys all work in a single click.
Response Times for Progress Indicators

[Miller 1968; Card et al. 1991]
Personas & Roles
Personas
A persona is a narrative that describes the person your product will be used by. It can be a valuable tool, one where the act of creating it has as much value as the artifact you will creating.

A good persona will include information like:

  • behavior patterns
  • goals
  • needs
  • attitudes
  • beliefs
  • workflow
  • skills
  • environment
You hardly need personas when you know your real users.

Each persona should have three or four important needs or goals. Choosing the right needs is an important design decision. They're closely related to the value proposition for your company, and ideally form the rational basis of your product development. Most persona needs should focus on what the person could get out of using a well-designed product or service. Personas:

Personas won't:

Roles
Roles are assigned to the system users by their superiors or system administrators. All roles are pre-defined and kept in Horizon DB. Roles define:

Admin access is usually required for creation/editing or deletion of roles.

Popups
Also frequently called "dialogs", "notifications", "secondary lists", etc.

Popups obstruct smooth UI interaction flow. If possible, they can be replaced with some alternatives like edit in place, anchored overlays, etc. The cases when a popup box is preferable to some other, less disruptive form of notification, are

Modal dialogs are required when an affirmative action has to be taken. Use modal dialogs only if no other solution is possible/allowed. To avoid distraction and focus user on the decision making, use darkening scrims to blackout the rest of the content.

Positioning

Anchored overlay

Progressive vs. Staged Disclosure
Progressive disclosure is good when there is no certainty (or need) to show everything right away. This site is a perfect example of it. Since I never know how interested a potential visitor may be, I show small thumbnails first just to vet the appetite. Clicking on one brings in a bigger picture. And only from there one can go to see the full thing.

Encourage your users to discover functionality by providing cues about how to use user interface elements.
Defer advanced or rarely used features to a secondary screen, making applications easier to learn and less error-prone.

Staged disclosure (wizards) is useful when you can divide a task into distinct steps that have little interaction. It is problematic, when the steps are interdependent and users must alternate between them. To choose between them, consider:

  Progressive Disclosure Staged Disclosure (wizards)
Initial display Core features Features that users access first in the task sequence
Subsequent display(s) Secondary features Features that users access later in the task, even if these features are equally important (or more important)
Do users access subsequent displays? Usually not — most users get what they need on the initial display Yes — unless users stop the task before completing the sequence
Navigation between displays Hierarchical: users start at the initial display and, if necessary, move to the secondary display and then (often) return to the initial display Linear: users progress through the task one step at a time
Main usability benefit Learnability: novice users are focused on the most useful features and confusingly advanced features are hidden Simplicity: each step is simple and its purpose is clear because features that belong to other steps are hidden

Ensure that links and category descriptions explicitly describe what users will find at the destination.

Perceived affordances are actions you understand just by looking at the object, before you start using it. Common symptoms of the lack of perceived affordances are:

Rapid Prototyping
If picture is worth 1000 words, a fully interactive prototype is worth 1000 PowerPoint presentations. if you have time and inclination to do it.

What to prototype?

One can prototype a whole app, a section of it or just a single (usually most debatable) feature. The first situation is rare, - most people have a good idea what are they doing. For the last one you'll need a most versatile prototyper.

What to prototype with?

There is no shortage of interactive prototyping applications, ranging from free to hundreds of dollars. Most of them are simple click-through ones (in that there are no different than, say, PowerPoint). Sketch+Zeplin support this kind of interactivity today, so you don't have to invest into anything less powerful.

Three programs stand out of the crowd: Axure , Justinmind and Hype . Axure is the most powerful one when it comes to design complex interactions with datasets and global variables. Hype is a simplified HTML5 version of Flash. It's a timeline-based program, best suited for tutorials. It can do more if you can write Javascript like a pro.

Pros: Cons:

The future

The more successful your prototyping is, the more chance you'll be asked whether "developers can re-use it". Then you'll have to lower your eyes down and, in sotto voce, say "not really". Aside from Framer most prototypers produce "spaghetti code". And mastering Framer Studio is almost as easy as JavaScript itself. Besides, you've already invested your time into learning too many programs.

If you're a master of Sketch and Zeplin, and a click-through screen flow is enough, don't look any further. In fact, there is a chance we all won't need to look any further with the new Sketch2React app. It produces clean, almost hand-tooled HTML code with external CSSs and JSs. Your wait is over if you don't mind the tedious task of naming all your Sketch layers properly. It's beta, but a very promising one. Right now it generate HTML with Bootstrap and JQuery dependencies only, but in the future it will be full React.
Scroll or Click
Scrolling is easier than clicking, especially considered that on Google search results page, only 6% of all users advance to the second page.

When do a multi-page design, indicate that there is more content with pagination, dot navigation, numbers, etc. "Go to page X" feature is hardly useful - user (especially a new one) often has no idea what's on page X.

Long, endless scrolls are among the most universally hated UI features. if you do a single page UI, use anchors, nav. gadgets or speed scroll via:

function pageScroll() {
window.scrollBy(0,50);
scrolldelay = setTimeout('pageScroll()',100);}
body onLoad="pageScroll()"

To tab or not to tab

Using tabs vs. new pages has to be justified:

Testing
Test as often and as early as possible. To start testing in the development cycle is the most expensive way. Use prototyping as much as you can.

Keep in mind:

"It takes only 5 users to uncover 80% of high-level usability problems."

Jakob Nielsen

When testing, consider:

DO NOT:

Invite people to simply criticize you app or its individual features. They'll do. You can bet your bottom dollar on it. So, avoid questions like:

INSTEAD:

Prepare testing forms, schedule testing session as precise as a rocket launch. For example, this one was made by UserFocus in 2009.
Customizable Toolboxes
Tool bar customization is a must have feature. This is not your garage, keep the screen toolbox lean.

The easiest way is to allow user to drag and drop tools onto the tool bar/row:


© Bohemian Coding Sketch


In a more involved UI, where are hundreds of possible functions, a more sophisticated customization is used:

© Maxon
Tools of Choice

"You've got to start with the customer experience and work backward to the technology. You can't start with the technology and then try to figure out how to sell it". - Steve Jobs

figma logo UI Design - Figma
  • For years we thought nothing can replace Sketch, but here we are: Figma did.
  • Figma can do everything Sketch can and much more
  • It's design, real-time collaboration, prototyping and specs in one place.
  • Yes, it's a cloud app, but that doesn't slow it down a bit. If your company never let you go outside the firewall, it's not for you.
  • And it can open .sketch files as its own.
  • Its pure HTML nature ("frames" as simply DIVs with flexbox applied.
sketch logo UI Design - Sketch
  • Sketch has proven to be imminently faster, more open and intelligent and has more potential to evolve than Invision, Adobe XD,Principal, and many other copycat apps;
  • Especially after they open .sketch format for developers to do anything;
  • And developers DID. SeeSketch2React for example;
Specs, mocks, interactivity - Zeplin
  • Zeplin for designer/designer and designer/developer collaboration is what GitHub is for coders;
  • It cuts time spent on mocks, specs, style guides, presentation work tenfold. No more redline, no more Wiki, PDFs, etc.
  • It's flexibly priced to address your business needs.
  • The level of integration and speed with which they address all Sketch innovations in astonishing. Five star developers.
  • Cons: it's outside your firewall. If this is a deal breaker, use Marketch
Interactivity, animation - Hype
  • Tumult Hype offers 80% of the Flash capabilities with pure HTML5 code;
  • It's smarter and leaner than Adobe Animate (which is nothing else but a re-packaged Flash).
  • It's far better than Adobe Edge ever was. However, if you are more familiar with Flash legacy UI, use Adobe Animate.
  • If you know JS, you can do much more.
  • If you know JS quite well... you don't need Hype.
  • It has the same problem for prototyping as Flash - it's timeline - rather than event-based.
Rapid prototyping, flows, wires - Axure
  • Axure RP is a Mercedes Benz of advanced prototyping (including the price).
  • The only package on par with it - JustInMind - is far less stable or capable.
  • its learning curve could be quite steep, but it's worth it.
  • Community support is great. You can get your problem solved for free.
  • Cons:
    • Playing it locally requires Chrome extension.
    • You can use their AxShare service, but it's outside your corporate firewall.
    • It generates spaghetti code.
HTML, CSS, JS - Espresso
  • I ditched Dreamweaver for this lean, elegant HTML/CSS editor. This site is edited in it.
  • Simply the best CSS editor out there.
  • Its x-ray mode allows to re-skin a site without touching HTML code.
  • You can customize your color scheme, add your own snippets (macros).
  • Flawlessly manages your remote server uploads with parallel streams.
C4Dlogo 3d, animation, video - Cinema 4D
  • Only if you really want to do cool looking custom pics instead of using stock photo.
  • Simply the best 3d app for the money.
  • It's not cheap. Takes time to learn.
If you're still looking to ditch Photoshop (and its landlord - Adobe) for image editing, there is Affinity Photo.And if you're into digital doodling and want to have the same experience on desktop and iPad, here is ArtStudio Pro.

Touch Screen
Apple recommends a minimum target size of 44 x 44 pixels. Since physical pixel size can vary by screen density, Apple's pixel specifications apply best to the iPhone's 320 by 480 pixel, 3.5 inch display (164ppi). Since the release of the iPhone 4's Retina Display (326ppi) Apple has updated these specs to points instead of pixels. Microsoft suggests: a recommended touch target size of 9mm/34px; a minimum touch target size of 7mm/26px; a minimum spacing between elements of 2mm/8px; and the visual size of a UI control to be 60-100% of the touch target size.

Gap between touch elements:

1 mm gaps for index finger usage
2 mm gaps for thumb usage

An MIT Touch Lab study of Human Fingertips to Investigate the Mechanics of Tactile Sense (PDF) found that the average human finger pad is 10-14mm and the average fingertip is 8-10mm.

Touch screen navigation
Swipe navigation can be used for:
Pros: Cons:
One finger operations Poses significant muscular strain compared to finger tap.
Allow partial view of data on both screens (before and after) Hard to use with longer lists
Replaces pagination. No hover actions

Multi-finger operation. There are still a lot of app developers who go bonkers with multi-finger acrobatics, including three finger tap, four finger tap, slow press, etc., etc. that would require a trained piano player skills. Avoid them. Use only what has de facto become The Convention:

Type on low-resolution Screen
To serif or not to serif

In your lifetime you've seen billions of letters and millions of words, yet you might never have consciously noticed the typefaces you read. Chiseled by Romans, letters used to have "serifs" - those specific notches were nothing but the result of chisel cuts in stone. Alas they became de facto standard in text readability for next twenty centuries. Serifs create an imaginary baseline. The first sans-serif typeface was designed in 1812 by William Caslon IV.

Text on the 72-96 ppi screen doesn't have enough resolution to even represent those serifs. On the left is 10 px type.

Text highlighting

Underlined text. It came from the world of typewriters as the only means of highlighting part of the text. Regrettably it found its way into web, mostly as link indicator. If you can avoid it, do it. There are other, more elegant ways.

Bold. The most natural way of emphasizing parts of text. Avoid artificial boldfacing using HTML(<strong> tag). Instead use bolder versions of the same typeface, web fonts usually come with.

Times Regular Times Bold Times Regular with <strong> tag


Against Italic
What looks OK in print, could be a problem in low res.

On the left you can see why only 0°, 45°, 90° lines are looking crisp without antialiasing. So there is no point to italicize text without antialiasing it.

Antialiasing would add extra blur to your text. When all screens become "retina"-type, we would be able to forget about this.



Colorize It
Color is the only way to highlight the part without altering the typeface. Narrow your text colors to 3 colors maximum. The perception that black text on white background is the easiest and fastest to read is a myth. You can read this page as fast as any other web page.
Hating Helvetica
People outside the world of graphic design sometimes develop strange and unexplained attitude toward certain typefaces. Opinions like "ugly", "old tired" or "boring" font are common. Originally designed for Deutsche Bundespost, Helvetica is the typeface now used on IRS forms. Despite of the fact that Helvetica is one of the best and most readable in small sizes sans-serif fonts, what matters is that you've seen that typeface before, and not under the most pleasant circumstances.
3 Classes of Users
Visceral User.
This is rather a window shopper. Although he may not yet know what to ask about, often he is the one you most likely have to sell your product to.

Things he notices and likes:

  • UI elegance, general look-and-feel
  • Price
  • Speed
  • Vendor's reputation
  • Installed base

He doesn't notice and care yet:

  • Navigation shortcuts
  • Useful UI redundancies
  • Accuracy (if applicable)
  • Power features, hidden behind the slick UI

New User. He has started, but still uses manual and help quite often. A landing "how to" screen is for him. A checkbox "don't show this screen on start" is always a good idea.

He likes:

  • Accessibility of Help, Tool Tips, "How to" lessons, tutorials
  • Compatibility with other software. Import/export options
  • Conventionality of UI. Any deviation from an industry convention causes lot of anxiety.

He doesn't have time to notice:

  • Navigation shortcuts
  • Useful UI redundancies
  • Accuracy (if applicable)
  • Power features, hidden behind the slick UI.

Power user. Works often, works long hours, used product for a long time.

He does like:

  • App true power
  • Manufacturer's commitment to improvement
  • Frequency of updates (if free or low cost)
  • Active users groups and on-line communities.

He doesn't like:

  • Changes in UI drive him nuts
  • Functionality removed or disabled
  • Conventionality of UI features.

Collect as much feedback as possible. You'll sort it out later.

Now if you had no chance to collect your users' demographics yet you'd better start now use straw men social personas.

Use post-testing Kano model customer satisfaction (single choice) questionnaire:

Wireframes
There is no established standard for wireframe format. Most often, their style is defined by the program used.

Sketchiness
Balsamiq and OmniGraffle once were the main wireframing tools. Some people use PowerPoint, Adobe Illustrator, Fireworks, InDesign or paper. UX is a truly app agnostic field.

Personally, I find nothing valuable in pursuing that "hand-drawn on whiteboard" look that attract so many people to Balsamiq, but since the most important things are:
I recommend to use whatever software your teammates are most comfortable with. Especially, since those programs are cheap and easy to learn.

Accuracy
Wireframes evolve through the process of application design from very schematic to detailed, "HIFI" ones. There is no standard for them. Often wireframes are mixed with HIFIs when you design for the existing UI.

Be careful using HIFIs in place of wireframes. People would think it's the design (proposed or final) and start criticizing colors, buttons, etc. instead of looking for functionality. I have experienced this on many occasions. For example, with this one.It's a pure concept presentation, but because it looks like HIFI, people start talking about the "buttons size".

Static vs. Interactive wires
Rapid prototyping using tools like Axure, Justinmind and Tumult Hype are changing the game. Check out the Prototyping section.

Things beyond our control

"A lot of convenience and power could be gained, and a lot of unhappiness, irritation and missed opportunities avoided, if the industry thought about design, instead of always making it the last thing on the list." - David Gelertner



UX is many things to many people. While it destined to play a crucial role in matching users' desires, needs, biases, and conventions to the vendor marketing objectives and application architecture, in reality, it routinely swims in scholastically sounding BS, job security rat race and "insurance policy" against the executive ire in case of non-performance at the box office. While you can't change anything in the latter, the following is within your ability to challenge: