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.