Quantcast
Channel: Background substraction using opencv mogdetector and c++ from live camera feed - Stack Overflow
Viewing all articles
Browse latest Browse all 2

Background substraction using opencv mogdetector and c++ from live camera feed

$
0
0

I am trying to use this code for background subtraction for a live camera feed. but this code is giving a white image in both the windows. the problem is that when tested with a video file from the same camera it is working fine, without any error but when the video file is replaced by a camera feed it becomes white and in the running window terminal it displays error as:

HIGHGUI ERROR: V4L2: Unable to get property (1) - Invalid argument

The above error is continuously being repeated when the video is taken from camera feed. Please help to solve this problem.

#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/video/background_segm.hpp>
#include <cv.h>
#include <iostream>
#include <sstream>

using namespace cv;
using namespace std;

Mat frame; //current frame
Mat fgMaskMOG; //fg mask generated by MOG method
Mat fgMaskMOG2; //fg mask fg mask generated by MOG2 method
Ptr<BackgroundSubtractor> pMOG; //MOG Background subtractor
Ptr<BackgroundSubtractor> pMOG2; //MOG2 Background subtractor
int keyboard;

int main()
{
//create GUI windows
namedWindow("Frame",0);
//namedWindow("FG Mask MOG",0);
namedWindow("FG Mask MOG 2",0);
namedWindow("eroded",0);
namedWindow("eroded2",0);
//create Background Subtractor objects

pMOG= new BackgroundSubtractorMOG(); //MOG approach
pMOG2 = new BackgroundSubtractorMOG2(); //MOG2 approach

//create the capture object
VideoCapture capture(0);

//read input data. ESC or 'q' for quitting
while( (char)keyboard != 'q' && (char)keyboard != 27 )
{
    //read the current frame
    if(!capture.read(frame))
    {
        cerr << "Unable to read next frame." << endl;
        cerr << "Exiting..." << endl;
        exit(EXIT_FAILURE);
    }
   //update the background model
   //AND HERE!!!
   //pMOG->operator()(frame, fgMaskMOG);
   pMOG2->operator()(frame, fgMaskMOG2);
   //get the frame number and write it on the current frame
   stringstream ss;
   rectangle(frame, cv::Point(10, 2), cv::Point(100,20),
   cv::Scalar(255,255,255), -1);
   ss << capture.get(CV_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));
   //show the current frame and the fg masks
   imshow("Frame", frame);


   imshow("FG Mask MOG", fgMaskMOG);
   imshow("FG Mask MOG 2", fgMaskMOG2);
   //get the input from the keyboard
   keyboard = waitKey( 30 );


}

 //delete capture object
capture.release();

//destroy GUI windows
distroyAllWindows();
return EXIT_SUCCESS;
}

Viewing all articles
Browse latest Browse all 2

Latest Images

Trending Articles





Latest Images