⛔️ DEPRECATED - This project is no longer maintained by the author. If you wish to continue working on this, feel free to fork and continue improving on it.
Thanks for your love and support! 🫶🏻
Yoga Guru is your personalized yoga trainer app based on Flutter. It uses posenet, a pre-trained deep learning model, to estimate body poses in real time and predict yoga asanas.
Open terminal and type
git clone https://github.com/adityaas26/Yoga-Guru.git
Connect your device or start the emulator and run the following code
# change directories
cd Yoga-Guru
# gets all the dependencies
flutter pub get
# run the app
flutter run
The project structure is quite primitive right now.
Let's look at the lib folder
Don't worry, we'll take a brief look at all the files in a minute! Let's start with main.dart
main.dart loads data from shared preferences and the camera module. It also defines routes for home, login and register pages. If the user is already logged in, it sets the initial route to home.dart else login.dart.
login.dart defines a Login class, which is a stateful widget. It contains the textfields required to login into the app. The Login button calls the _login() method which routes to home.dart. Also contains a button to send the user to register.dart.
register.dart defines a Register class, which is a stateful widget. It contains the textfields required to login into the app. The Login button calls the _register() method which routes to home.dart. Also contains a button to send the user to login.dart.
home.dart defines a Home class, which is a stateless widget. It contains buttons which routes the user to poses.dart according to the button they press. Each button (beginner, intermediate, advance) call a method _onPoseSelect().
This _onPoseSelect() method is quite important as the arguments given to this function decides which list of poses needs to be shown on the poses page.
poses.dart defines a Poses class, which is a stateless widget. It shows a list of available poses as swipable cards. The code of the custom cards can be found in yoga_card.dart file. Each card is clickable and calls the _onSelect() method which directs the user to the InferencePage (inference.dart).
inference.dart defines a InferencePage class, which is a stateful widget. It is the class which loads the posenet model. It initializes the Camera object with the camera instance and _setRecognitions() callback function. The _setRecognitions() method is responsibe for saving the predicted output of the PoseNet model into a List (_recognitions). This list of predicted values (_recognitions) is then passed to BndBox's constructor.
You can read more about the implementation here.
camera.dart defines a Camera class, which is a stateful widget. It contains code related to camera initialization and calls Tflite.runPoseNetOnFrame() method by passing in the current CameraImage as an argument. The output (predictions) of this method is given as an argument to the _setRecognitions() method, which was passed to Camera() as callback.
bndbox.dart defines a BndBox class, which is a stateless widget. It takes the List of predictions (_recognitions) and plot keypoints on the screen. It also prints the accuracy of the model in %.
profile.dart defines a Profile class, which is a stateful widget. It contains the code for viewing and updating the user's profile data.
Reach out to me at any of the following platforms:
- Portfolio Website: adityasharma.live
- Email: adityaas26@gmail.com
- Twitter: @BetaPundit
- LinkedIn: aditya-sharma26
A few resources to get you started if this is your first Flutter project:
For help getting started with Flutter, view online documentation, which offers tutorials, samples, guidance on mobile development, and a full API reference.