Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/parneet-sandhu/virtual-try-on
This project uses OpenCV, Mediapipe, and NumPy to create an interactive virtual try-on experience. The application overlays a virtual accessory (e.g., glasses) onto the user's face using webcam input and allows users to control the brightness of the camera feed and capture screenshots using hand gestures.
https://github.com/parneet-sandhu/virtual-try-on
computer-vision mediapipe numpy opencv python tkinter
Last synced: about 2 months ago
JSON representation
This project uses OpenCV, Mediapipe, and NumPy to create an interactive virtual try-on experience. The application overlays a virtual accessory (e.g., glasses) onto the user's face using webcam input and allows users to control the brightness of the camera feed and capture screenshots using hand gestures.
- Host: GitHub
- URL: https://github.com/parneet-sandhu/virtual-try-on
- Owner: Parneet-Sandhu
- License: mit
- Created: 2024-11-13T08:45:09.000Z (2 months ago)
- Default Branch: main
- Last Pushed: 2024-11-13T14:13:06.000Z (2 months ago)
- Last Synced: 2024-11-28T04:07:31.933Z (about 2 months ago)
- Topics: computer-vision, mediapipe, numpy, opencv, python, tkinter
- Language: Python
- Homepage:
- Size: 442 KB
- Stars: 3
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Virtual Try-On Project
This project uses **OpenCV**, **Mediapipe**, and **NumPy** to create an interactive virtual try-on experience. The application overlays a virtual accessory (e.g., glasses) onto the user's face using webcam input and allows users to control the brightness of the camera feed and capture screenshots using hand gestures.
## Features
- **Virtual Accessory Placement**: Automatically places a virtual accessory (such as glasses) on the user's face, aligned with their eyes.
- **Brightness Control**: Use hand gestures to adjust the brightness of the live video feed.
- **Screenshot Capture**: Capture a screenshot by performing a thumbs-up gesture with the left hand.
- **Real-Time Interaction**: Live webcam feed with real-time adjustments and accessory placement.
- **Accessory Customization**: Load and apply custom accessories (PNG images with an alpha channel) from a folder.## Requirements
- **Python 3.x** (Tested on Python 3.7 and above)
- **OpenCV**: For webcam feed and image processing
- **Mediapipe**: For face and hand landmark detection
- **NumPy**: For numerical operations and image manipulation
- **Tkinter**: For the user interface to apply accessoriesTo install the required dependencies, you can use the following `pip` command:
```bash
pip install opencv-python mediapipe numpy
```
## Assets Folder
The project relies on an accessory image (e.g., glasses or mask) that should be placed inside the `assets` folder.
- assets/mask.png: This is the virtual accessory image used for the try-on. You can replace it with any image (e.g., glasses, hats) that has a transparent background (alpha channel).## Running the Application
To run the application, simply execute the `main.py` file:
```bash
python main.py
```
The webcam will open, and the system will start processing the video feed. The virtual accessory will be placed on the user's face in real-time, and hand gestures will control brightness and allow for screenshot capture.- Right Hand: Adjusts brightness by controlling the distance between the thumb and index finger.
- Left Hand: Captures a screenshot when a thumbs-up gesture is detected.Press 'q' to exit the program.
## How It Works
- **Face Landmark Detection**: The program uses Mediapipe’s FaceMesh solution to detect face landmarks, particularly the eyes, to position the virtual accessory.
- **Hand Landmark Detection**: The program uses Mediapipe’s Hands solution to track the user's hand movements. The right hand controls brightness, and the left hand triggers screenshots with a thumbs-up gesture.
- **Accessory Placement**: The accessory image is resized based on the distance between the user's eyes and overlaid on the webcam feed. Transparency is respected using the alpha channel of the accessory image.
- **Brightness Control**:The right hand’s thumb and index finger distance is used to control the brightness of the video feed in real time.
- **Screenshot Functionality**: When the left hand forms a thumbs-up gesture, a screenshot is taken and saved with a timestamped filename.## Working Demo:
![Screenshot 2024-11-13 194320](https://github.com/user-attachments/assets/c2f3637d-5379-4d59-929d-0628ee4411fe)## License
This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for more details.