Chapter 5: A GUI is better than two thousand words
Last updated
Last updated
(By Mario Linares-Vásquez, Vivian Gómez, Mariana Villamizar, Juan Santiago Acevedo, Gustavo Alegría, and Sergio Velásquez)
Mobile apps are user-interaction driven, because the user interacts with the app through the GUI, gestures and sensors. The context canvas, the VD-map, and the scenarios description are not focused on the app GUI. Therefore, there is still a missing element in our mobile app development toolbox, because there is no way to have an app without a GUI.
Actually it is possible to have mobile apps without GUIs. This type of applications have background services or broadcast receivers that are running in background (on the device) and do not react to GUI actions, because there is no GUI, but react to other actions as system calls, intents, or other events.
OK, lets rephrase it, there is no way to have a GUI-dependent app without a GUI. Consequently, during all the design thinking steps it is really important to take into account the GUI of your mobile apps, because mobile apps are a particular type of software that are highly-dependent on the GUI.
Now, the question is how to design the GUI of a mobile app. The answer is that there are many artifacts and tools available. However, the most important elements to consider are the Design Metaphors promoted by each platform and how they are applied in the Design Systems and GUI.
First, let's understand these new concepts.
A Design System is a comprehensive set of guidelines, principles, components, and rules that govern the creation and maintenance of a product's user interface. It typically includes design elements such as colors, typography, spacing, layout grids, iconography, components (like buttons, form elements, cards), and usage guidelines. Examples of design systems include Google's Material Design, IBM Design Language, and Airbnb's Design System.
A Design Metaphor is a shared language, a set of principles of style that guide the creation of a Design System and a GUI. It can be understood as a conceptual framework or analogy used to convey the underlying principles, functionality, or purpose of a product or system. An example of design metaphor is the use of "material" concept in the Google's Material Design System. This metaphor is inspired by the physical world and is based on the idea that the user interface should mimic the experience of physical material, using shadows, depth, and motion to create a visually appealing and coherent experience.
For instance, in the particular case of Android apps, the design metaphor is the concept of "Material" and its applied in the "Material Design System". You can see all the Metaphor and Design System documentation in Material io.
Material Design is inspired in tactile and physical qualities of materials (paper and ink), including physical laws of movement. It emphasizes on user actions to ensure that main functionality is clear, because user actions are reflected naturally in the GUI. Check the following videos to get an idea of Material Design.
(Taken from "Making Material Design: Crafting Material" Video available at YouTube. The video is published under the Standard YouTube license )
(Video by Google Design available at YouTube. The video is published under the Standard YouTube license )
The composition foundations are geometric forms based on circles, squares, diagonal and orthogonal strokes, in a three-dimensional space in which the light and the shadows reflect the elevation of the elements that make up a view.
But, what is elevation? Material design was thought in a three-dimensional space, in which the components are located at some place in the three axis. There is a key value for the components called elevation, that reflects the component position in the Z-axis. When a user interacts with a component it is reflected by changing the position of the component in the Z-axis. How is it possible to do that? Using shadows and light.
Material Design is not just a set of rules that someone came up with. It is the result of a set of experiments on how we as people relate to objects, and how we can take advantage of the phone screen to not only show elements to the users, but also to let them feel how they can interact with the elements. Watch the following video about how material design was developed.
(Video by Google Design available at YouTube. The video is published under the Standard YouTube license )
In the case of iOS, the design is based on specific Human interface guidelines that are close to a "Flat Design" metaphor.
There are three essential characteristics of the iOS design metaphor:
Clarity: Legible text at every size, lucid an precise icons, and design motivated on functionality.
Deference: Fluid motion and a crisp interface help people understand and interact with content while never competing with it.
Depth: Distinct visual layers and realistic motion hierarchy facilitate understanding. Transitions provide a sense of depth as you navigate through content.
The iOS metaphor tries to follow an "intentional design"; when designing for iOS you should always keep a focus on the people that you are designing for. You will want to create apps that feel simple, that make the users believe that the app is an extension of what they already know. You need to create comfort and confidence; to do that you should take into account the following five elements of intentional design:
Radical Simplification: The UI could be as simple as one screen with one functionality, it does not matter if it is enough to fulfill the app's goal.
Deep Understanding: Understand the real problem, do not just assume that you know everything. Try to get to the why, and create solutions that will answer the real problems.
Extreme Focus: What might seem as extreme case could be the point or focus to redesign your solution.
Personal Connection: Try to find ways of recreating feelings. Think of how the way a user relates with your app is a reminiscence of some feelings or moments.
Direct Communication: Draw on what people already know, be as clear and specific as possible, try not to make the user doubt about what your app does.
Check the Intentional Design video from the WWDC18: https://developer.apple.com/videos/play/wwdc2018/802/
Metaphors exist so that you can rely on them to extend the utility or value of your app. It is not about following some rules so that every app is perfectly design; it is about understanding the capabilities of the platform you are building your app upon.
Note that the metaphor provides the principles of its own GUI components, usually available in Design Systems. Thus, having a generic design that is expected to work on both platforms is a challenging task to achieve because there are differences in how an app will look on the two platforms. One way to achieve GUI consistency across platforms is by implementing mobile web or hybrid apps instead of native apps. Another option is to design the app by considering only the GUI components that are mirrored on both platforms (e.g., buttons); however, this option limits the user experience on each platform.