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.
- Live tracking of running activity using GPS.
- Tracking of user's running path in Map using Google Map Compose library.
- Using Foreground Service, even the user closed the app and remove from the background, this app stills continue to track user running stats.
- Room database to store and manage running statistics.
- Handling nested navigation, Deep linking, conditional navigation to on boarding screen using Jetpack Navigation Component.
- New Jetpack Compose image picker - helps to pick image without any permission.
- Paging3 integration.
- Dynamic color support in dark and light theme.
- Weekly Statistics with filters in graph.
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.
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.
This app follows MVVM architecture, Uni Directional Flow (UDF) pattern and Single architecture pattern. HLD of tracking architecture is shown in the below image:
Simple clone this app and open in Android Studio.
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.
- Create and Get Google Maps API key by using this official guide
- Open
local.properties
file. - Enter your API key like this:
MAPS_API_KEY=your_maps_api_key
These features are left to be implemented:
- Profile menu implementation.
- Unit Tests
- 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.
- App Icon
- Suitable markers for the start, end, and current position.