यहां, हम सीखेंगे कि ओपनसीवी में आंख को कैसे ट्रैक किया जाए। डिटेक्टिव आईज के बाद ट्रैकिंग एक आसान और सीधा काम है। हमने पहचानी गई आंखों को घेरने के लिए सर्कल का इस्तेमाल किया। सर्कल के सेंटर को ट्रैक करने का मतलब आंखों के सेंटर को ट्रैक करना है। सर्कल के केंद्र को ट्रैक करने के लिए, हमें दो पूर्णांक चर की आवश्यकता होती है। यह पहली दो पंक्तियों (9 th .) पर किया गया है और 10 वें लाइन) मुख्य () फ़ंक्शन के अंदर। पूर्णांक चर का नाम 'x_axis' और 'y_axis' है।
पंक्ति 42 और 43 में, केंद्र के क्षैतिज और ऊर्ध्वाधर निर्देशांक मानों को 'x_axis' और 'y_axis' चर में कॉपी किया गया है और इनमें वृत्त का केंद्र है। 44 वें . को लाइन, 'cout' कथन का उपयोग करते हुए, हमने केंद्र का मान दिखाया है। इस तरह हम आंख के स्थान को ट्रैक कर सकते हैं।
C++ का उपयोग करके OpenCV में आंखों की स्थिति को ट्रैक करने के लिए निम्न कोड।
उदाहरण
#include<iostream> #include<opencv2/highgui/highgui.hpp> #include<opencv2/imgproc/imgproc.hpp> #include<opencv2/objdetect/objdetect.hpp> using namespace cv; using namespace std; int main() { int x_axis;//Declaring integer variables to store co-ordinate values// int y_axis;//Declaring integer variables to store co-ordinate values// Mat frame;//Declaring a matrix to video frame in it// namedWindow("Detect");//Declaring a window to show our work// VideoCapture image(0);//capturing video from default camera// if (!image.isOpened()){ //Error message if video source is not found// cout << "Couldn't load video from the source.Make sure your camera is working properly." << endl; system("pause"); return 0; } double height = image.set(CAP_PROP_FRAME_HEIGHT, 480);//setting up height of each frame// double width = image.set(CAP_PROP_FRAME_WIDTH, 640);//setting up width of each frame// CascadeClassifier face_cascade, eyes_cascade;//declaring a CascadeClassifier object// face_cascade.load("C:/opencv/sources/data/haarcascades/haarcascade_frontalface_alt.xml");//loading the cascade classifier// eyes_cascade.load("C:/opencv/sources/data/haarcascades/haarcascade_eye.xml"); while (true) { bool temp = image.read(frame);//loading video frames from source to our matrix named frame// std::vector<Rect>faces;//Declaring a vector named faces// face_cascade.detectMultiScale(frame, faces, 1.1, 2, 0 | CASCADE_SCALE_IMAGE, Size(100, 100));//detecting the face for (int i = 0; i < faces.size(); i++){ //for locating the face Point center(faces[i].x + faces[i].width * 0.5, faces[i].y + faces[i].height * 0.5);//getting the center of the face// ellipse(frame, center, Size(faces[i].width * 0.5, faces[i].height * 0.5), 0, 0, 360, Scalar(255, 0, 255), 4, 8, 0);//draw an ellipse on the face// Mat faceROI = frame(faces[i]);//Taking area of the face as Region of Interest for eyes// std::vectoreyes;//declaring a vector named eyes// eyes_cascade.detectMultiScale(faceROI, eyes, 1.1, 2, 0 | CASCADE_SCALE_IMAGE, Size(5, 5));//detect eyes in every face// for (size_t j = 0; j < eyes.size(); j++){ //for locating eyes// Point center(faces[i].x + eyes[j].x + eyes[j].width * 0.5, faces[i].y + eyes[j].y + eyes[j].height * 0.5);//getting the centers of both eyes// int radius = cvRound((eyes[j].width + eyes[j].height) * 0.25);//declaring radius of the eye enclosing circles// circle(frame, center, radius, Scalar(255, 0, 0), 4, 8, 0);//drawing circle around both eyes// x_axis = eyes[j].x;//storing x axis location of eyes in x_axis// y_axis = eyes[j].y;//storing y axis location of eyes in y_axis// cout << "Position of the eyes is:" << "(" << x_axis << "," << y_axis << ")" << endl;//showing co-ordinate values// } } imshow("Detect", frame);//showing result in window named 'Detect'// if (waitKey(30) == 27){ //wait time for each frame is 30 milliseconds// break; } } return 0; }
आउटपुट