An Application to help you remind to blink and protect your eyes!
A cross platform application built using electron Js and python to generate desktop notifications to remind users to blink.
People spending large amount of time on screens, suffer from various eye sight related problems, major one of them being dryness of eyes caused dropped blinking rate.
We developed an application that can be useful to remind people when to blink, also another feature includes the famous 20-20-20 rule reminder.
The notifications are displayed over any application that you're currently using, even if this application is minimised. The notification frequency is completely adjustable according to personal needs in the settings section.
The application also provides a feature to completely turn off notifications, so as to not disturb or distract the user. But it maintains the blink count of user and the user can watch his blink rate of past 24 hrs on a live graph.
- Node JS
- Electron JS
- python 3.x with following modules installed
- numpy
- imutils
- scipy
- dlib
- opencv2
-
Step 1: Clone this repo into your system
git clone https://github.com/zenithexpo/iblink.git
-
Step 2: Download the shape_predictor_68_face_landmarks.dat here
Save this intoengine
folder -
Step 3:
cd iblink
npm init
(You will be asked few details in this steps, you can skip them by pressing return key a few times)
npm install
npm start
Using 68 Face Landmarks, we're figuring out the location of eyes in the camera feed, once we've the points around eyes, we calculate the Eye Aspect ratio (EAR). If the EAR value is less than a particular threshold, we assume that the eye is closed. Whenever we find a sequence of closing and opening of eyes, we increment the blink count and at the end of the minute a total count of blinks is displayed.
For detailed explanation about EAR calculation please visit Akshay Bahadur's Drowsiness Detection
This code's core algorithm of detecting eye blinks has been borrowed from this repository.
P.S. : Thank you Akshay for amazing projects :)