Gamifying personal goal achievement
Rapid prototyping a mobile app focused on fostering habits
In a Rapid Software Prototyping course (CS 397), my team and I built three mobile apps, each in three weeks. We applied Agile team processes to rapidly and iteratively develop full-stack web software applications with React and Firebase using Javascript, HTML, and CSS.
An Overview
CHALLENGE
Keeping up with habits can often be challenging. We wanted to make habit creation fun for our users by framing it as a lighthearted commitment and to encourage people to form their desired lifestyle by creating habits over time.
Breaking down the problem, people often neglect or fail to maintain habits or goals they want to achieve due to:
Lack of motivation
Having goals that are too abstract
Physical or mental stress & burnout
ROLE
UI/UX Designer & Developer
DURATION
September - December 2022
SKILLS
UI/UX Design, Figma,
React, HTML/CSS, Javascript, Jira
TEAM
Project Manager, Engineers
SOLUTION
Pokéto is a habit tracker based on the 21/90 rule, a method that states it takes 21 days to create a habit, and 90 days to make it a part of your lifestyle.
We gamified habit tracking by letting users level up Pokémon for each habit every day and evolve their Pokémon after 21 and 90 days. Users are able to track their progress for up to 6 daily tasks as habits to complete, training 6 Pokémon at a time to maintain a healthy pace.
Directly addressing pain points
01
Lack of Motivation
Find intrinsic motivation by recognizing the goal's importance
Knowing long-term goal
Knowing reasons behind choosing the goal
Being reminded of those reasons
02
Goals are too abstract
Follow a concrete plan by having structured steps toward success
Using the 21/90 Rule to structure and measure progress
Set achievable, concrete action to do daily
03
Feeling Overwhelmed
Make it lighthearted by making it a game
Go at a practical pace
Focusing on creating less than 6 habits at a time
Make it fun--make it a game!
Programming with Agile Methods
Our process within each week composed of sprints through Agile methodology of breaking down user stories into slices, slices into design and coding sprints, and mob programming to create the app using React over rotations of programmers every 15 minutes during team meetings.
Retrospectives
User testing and feedback with airport coordinators and passenger service assistants at the airport helped us understand their needs for communication throughout the service process. We iterated on how we could best display information and integrate efficient forms of communication into our high-fidelity prototype.
Learnings & Reflections
User Research & Testing
Going into purely a CS-based course, we were not required to conduct needfinding and user research, but I recognized that this would negatively affect how our app could help our users due to a gap in our understanding of our users' needs.
Being the only designer on the team, I pushed ourselves to prioritize our users' needs through design thinking for the purpose of creating an app that was both functional (to build our technical skills) and meaningful (to understand and target user’s needs, applying design research and thinking). We took the time to research and understand the user's pain points to improve our design choices for our prototype.
However, other design methods could have been incorporated into our prototyping process, as well as more iteration of low-fidelity prototypes before moving onto high-fidelity. Despite the time constraints, it would have given us a better understanding of how we can design not for the purpose of creating a functional app, but for our users instead.
Further iteration of our Agile processes
In our last retrospective meeting, we identified further ways in which we could improve on our teamwork and Agile methods.
To gain a better understanding of our progress and growth of our abilities, measuring and comparing the types of components in our apps over time, such as the number of data-displaying items/widgets, sources of data, complexity of user interaction, and "function points" would give us better insight into how our design and technical thinking can and has evolved, and to ultimately expand and grow beyond our abilities.