Human-machine interfaces (
IHM = Ìnterfaces Homme-machine) are interfaces connecting the interactions between humans and machines. For instance, this could be a program or a website.
You must think a lot about how you should create one, and that's the purpose of this course.
You will need
- to think about where you put the elements of your interfaces, by creating
- you will need to think about what elements you need in your interfaces
- you must think about how you will sort things like your menus to make them simple and intuitive
A wireframe is literally a frame of your application, you can draw it by yourself or use tools like
- PowerPoint (no, don't 🙄)
- Diagrams (fast, but quite poor quality)
- Sketch (macOS)
- Photoshop (paid, for professionals)
- Justinmind (trial available but paid, the best of all 🚀)
- Moqups (the best for free, account required)
- Or simply in HTML using Bootstrap, simple and efficient (my favorite alternative)
You can use this great website to think about menus or make optimal choices : optimalworkshop.
Before coding some application, you must think about what kinds of persons will use it
- Color-blind, partially sighted ...
- Devices (computer? Keyboard? Mouse?)
- Screen orientation, the size on tablet/phone
- Day/Night mode
- Knowledge about computers/...
You can't make something that would be perfect for everyone, but try to make some categories of users and provide them an application, that would aim to satisfy most of their requests. For instance, you can
- Make a website/app per country,
- Add a settings tab to enable the day/night mode,
- Think about the color-blind users when designing,
- Make your website/app responsive
- Create some categories of users
- Ask persons matching your categories where they would go to find XXX in the menus, ... to test your interface.
- Create UML's diagrams to formalize the interactions between the application and users
- Make a static mock-up
- Test your mock-up
- Make a dynamic mock-up (links working, some code, ...)
- Test again
OR you can follow my steps
- Create a dynamic mock-up
- And repeat these steps
- Test and reviews by users
- Filter changes to be made
- Implement one or more changes
Jakob Nielsen wrote the 10 principles that you should
MUST 😠 take into account.
Keep the user updated on what's happening
- if something is being loaded, ... tell it to the user.
- the user should know where he is (ex: which page?)
- buttons should have a visual change when they are hovered/pressed/...
Do not do something complex, follow the conventions
- ex: the close button is at the top-right of the screen
- Skeuomorph design: we are expecting an online book to work the same as a real one
Let the user be free
- allow the user to cancel an action
- user must see they can "escape"
Norms, directives, habits
- ex: we are expecting a software of the same family to be similar
- we are expecting a 🛒 shopping cart on a marketing website to see the list of our items
- do not let the user make mistakes, you should code or use the right kind of input field if you expect a specific kind of value.
- asking the user confirmation might also be a good practice.
- you may add a small help, an example, or a message saying what you are expecting
Users shouldn't need to learn
A MCQ is easier than an open question... Make it so that the user will recognize instead of remembering. You may use a particular kind of style or you may add tips.
- make it easy to learn
- and easy for pros to skip some steps, for example using shortcuts.
Do not write hundreds of words, add useless images, ... to say something that would fit in less than 10 words. Be clear and concise.
You should handle any kind of error or mistake.
As a last resort, you may add documentation for complex applications.
It may be better to load everything needed at the start of the application, rather than using lazy practices and making the user wait a lot of times.
A screen will most likely have more width than height, so you should exploit the width.
If you need more than 3 clicks to do one action, and you do this action often, then you MUST re-think your interface.