/** * @file bg_sub.cpp * @brief Background subtraction tutorial sample code * @author Domenico D. Bloisi */ #include #include #include #include #include #include #include using namespace cv; using namespace std; const char* params = "{ help h | | Print usage }" "{ input | ../data/vtest.avi | Path to a video or a sequence of image }" "{ algo | MOG2 | Background subtraction method (KNN, MOG2) }"; int main(int argc, char* argv[]) { CommandLineParser parser(argc, argv, params); parser.about( "This program shows how to use background subtraction methods provided by " " OpenCV. You can process both videos and images.\n" ); if (parser.has("help")) { //print help information parser.printMessage(); } //! [create] //create Background Subtractor objects Ptr pBackSub; if (parser.get("algo") == "MOG2") pBackSub = createBackgroundSubtractorMOG2(); else pBackSub = createBackgroundSubtractorKNN(); //! [create] //! [capture] VideoCapture capture(parser.get("input")); if (!capture.isOpened()){ //error in opening the video input cerr << "Unable to open: " << parser.get("input") << endl; return 0; } //! [capture] Mat frame, fgMask; while (true) { capture >> frame; if (frame.empty()) break; //! [apply] //update the background model pBackSub->apply(frame, fgMask); //! [apply] //! [display_frame_number] //get the frame number and write it on the current frame rectangle(frame, cv::Point(10, 2), cv::Point(100,20), cv::Scalar(255,255,255), -1); stringstream ss; ss << capture.get(CAP_PROP_POS_FRAMES); string frameNumberString = ss.str(); putText(frame, frameNumberString.c_str(), cv::Point(15, 15), FONT_HERSHEY_SIMPLEX, 0.5 , cv::Scalar(0,0,0)); //! [display_frame_number] //! [show] //show the current frame and the fg masks imshow("Frame", frame); imshow("FG Mask", fgMask); //! [show] //get the input from the keyboard int keyboard = waitKey(30); if (keyboard == 'q' || keyboard == 27) break; } return 0; }