/run-track

RunTrack is a Running Tracking app made using Modern Android Development (MAD), including Jetpack Compose, MVVM architecture, and Google Maps API. The app allows users to track their running activities and displaying real-time routes on an interactive map.

Primary LanguageKotlin

RunTrack

RunTrack is a Fitness Tracking app utilizing modern Android technologies, including Jetpack Compose, MVVM architecture, and Google Maps API. The app allows users to track their running activities, displaying real-time routes on an interactive map while storing essential statistics using Room database.

Features

  1. Live tracking of running activity using GPS.
  2. Tracking of user's running path in Map using Google Map Compose library.
  3. Using Foreground Service, even the user closed the app and remove from the background, this app stills continue to track user running stats.
  4. Room database to store and manage running statistics.
  5. Handling nested navigation, Deep linking, conditional navigation to on boarding screen using Jetpack Navigation Component.
  6. New Jetpack Compose image picker - helps to pick image without any permission.
  7. Paging3 integration.
  8. Dynamic color support in dark and light theme.
  9. Weekly Statistics with filters in graph.

Screenshot

run_track_home_ss runtrack_live_tracking_ss runtrack_running_info_ss
run_track_statistics_ss runtrack_profile_ss runtrack_all_run_screen_ss

Package Structure

  • background: Handles background related process like service.
  • data: Responsible for producing data. Contains entity, database and tracking related classes.
    • tracking: Classes that handles tracking like location tracking.
  • di : Hilt Modules.
  • domain: Contains common use case and interfaces.
  • ui: UI Layer of the app.
    • nav: Contains app navigation and destinations.
    • screen: Contains UI.
    • theme: Material3 theme.
    • common: UI utility classes and common components.
  • common: Utility class used across the app.

Build With

Kotlin: As the programming language.

Jetpack Compose : To build UI.

Jetpack Navigation : For navigation between screens and deep linking.

Room : To store and manage running statistics.

Google Maps API : To track user's running activity such as speed, distance and path on the map.

Hilt : For injecting dependencies.

Preferences DataStore : To store user related data.

Coil : To load image asynchronously.

Vico : To show graphs in statistics screen.

Architecture

This app follows MVVM architecture, Uni Directional Flow (UDF) pattern and Single architecture pattern. HLD of tracking architecture is shown in the below image: tracking_architecture

Installation

Simple clone this app and open in Android Studio.

Google Map Integration

Do these steps if you want to show google maps. The tracking functionalities will work as usual even if you don't do these step.

  1. Create and Get Google Maps API key by using this official guide
  2. Open local.properties file.
  3. Enter your API key like this:
MAPS_API_KEY=your_maps_api_key

Project Status

These features are left to be implemented:

  1. Profile menu implementation.
  2. Unit Tests
  3. Currently, we are storing (maps screenshot) bitmap directly into db in form of bytes which is not good. Save the image to the storage and store only its uri or id.
  4. App Icon
  5. Suitable markers for the start, end, and current position.