2013-03-14 17:10:54 +01:00
|
|
|
#include "opencv2/core.hpp"
|
|
|
|
#include <opencv2/core/utility.hpp>
|
|
|
|
#include "opencv2/imgproc.hpp"
|
2011-05-21 20:32:34 +02:00
|
|
|
#include "opencv2/video/background_segm.hpp"
|
2014-07-10 16:27:32 +02:00
|
|
|
#include "opencv2/videoio.hpp"
|
2013-03-14 17:10:54 +01:00
|
|
|
#include "opencv2/highgui.hpp"
|
2010-11-29 15:00:49 +01:00
|
|
|
#include <stdio.h>
|
2010-12-28 22:28:34 +01:00
|
|
|
|
2011-08-10 10:56:27 +02:00
|
|
|
using namespace std;
|
2010-12-28 22:28:34 +01:00
|
|
|
using namespace cv;
|
|
|
|
|
2012-06-07 19:21:29 +02:00
|
|
|
static void help()
|
2010-11-30 02:26:29 +01:00
|
|
|
{
|
2010-12-04 09:30:10 +01:00
|
|
|
printf("\nDo background segmentation, especially demonstrating the use of cvUpdateBGStatModel().\n"
|
2011-06-09 14:01:47 +02:00
|
|
|
"Learns the background at the start and then segments.\n"
|
|
|
|
"Learning is togged by the space key. Will read from file or camera\n"
|
2011-08-10 10:56:27 +02:00
|
|
|
"Usage: \n"
|
|
|
|
" ./bgfg_segm [--camera]=<use camera, if this key is present>, [--file_name]=<path to movie file> \n\n");
|
2010-11-30 02:26:29 +01:00
|
|
|
}
|
2010-11-29 15:00:49 +01:00
|
|
|
|
2012-10-17 09:12:04 +02:00
|
|
|
const char* keys =
|
2011-08-10 10:56:27 +02:00
|
|
|
{
|
2012-09-07 11:24:48 +02:00
|
|
|
"{c camera | | use camera or not}"
|
2014-08-10 21:24:16 +02:00
|
|
|
"{m method |mog2 | method (knn or mog2) }"
|
|
|
|
"{s smooth | | smooth the mask }"
|
2014-09-13 16:28:41 +02:00
|
|
|
"{fn file_name|../data/tree.avi | movie file }"
|
2011-08-10 10:56:27 +02:00
|
|
|
};
|
|
|
|
|
2010-11-29 15:00:49 +01:00
|
|
|
//this is a sample for foreground detection functions
|
2011-08-10 10:56:27 +02:00
|
|
|
int main(int argc, const char** argv)
|
2010-11-29 15:00:49 +01:00
|
|
|
{
|
2012-10-17 09:12:04 +02:00
|
|
|
help();
|
2011-08-10 10:56:27 +02:00
|
|
|
|
2012-10-17 09:12:04 +02:00
|
|
|
CommandLineParser parser(argc, argv, keys);
|
2012-09-07 11:24:48 +02:00
|
|
|
bool useCamera = parser.has("camera");
|
2014-08-10 21:24:16 +02:00
|
|
|
bool smoothMask = parser.has("smooth");
|
2012-10-17 09:12:04 +02:00
|
|
|
string file = parser.get<string>("file_name");
|
2014-08-10 21:24:16 +02:00
|
|
|
string method = parser.get<string>("method");
|
2010-12-28 22:28:34 +01:00
|
|
|
VideoCapture cap;
|
2010-11-29 15:00:49 +01:00
|
|
|
bool update_bg_model = true;
|
|
|
|
|
2011-08-10 10:56:27 +02:00
|
|
|
if( useCamera )
|
2010-12-28 22:28:34 +01:00
|
|
|
cap.open(0);
|
2010-11-29 15:00:49 +01:00
|
|
|
else
|
2012-10-17 09:12:04 +02:00
|
|
|
cap.open(file.c_str());
|
2012-09-07 11:24:48 +02:00
|
|
|
|
|
|
|
parser.printMessage();
|
2011-08-10 10:56:27 +02:00
|
|
|
|
2010-12-28 22:28:34 +01:00
|
|
|
if( !cap.isOpened() )
|
2010-11-29 15:00:49 +01:00
|
|
|
{
|
|
|
|
printf("can not open camera or video file\n");
|
|
|
|
return -1;
|
|
|
|
}
|
2012-10-17 09:12:04 +02:00
|
|
|
|
2013-04-07 20:45:38 +02:00
|
|
|
namedWindow("image", WINDOW_NORMAL);
|
|
|
|
namedWindow("foreground mask", WINDOW_NORMAL);
|
|
|
|
namedWindow("foreground image", WINDOW_NORMAL);
|
|
|
|
namedWindow("mean background image", WINDOW_NORMAL);
|
2010-11-29 15:00:49 +01:00
|
|
|
|
2014-08-10 21:24:16 +02:00
|
|
|
Ptr<BackgroundSubtractor> bg_model = method == "knn" ?
|
|
|
|
createBackgroundSubtractorKNN().dynamicCast<BackgroundSubtractor>() :
|
|
|
|
createBackgroundSubtractorMOG2().dynamicCast<BackgroundSubtractor>();
|
2012-10-17 09:12:04 +02:00
|
|
|
|
2014-08-10 21:24:16 +02:00
|
|
|
Mat img0, img, fgmask, fgimg;
|
2011-06-03 16:13:03 +02:00
|
|
|
|
2010-12-28 22:28:34 +01:00
|
|
|
for(;;)
|
2010-11-29 15:00:49 +01:00
|
|
|
{
|
2014-08-10 21:24:16 +02:00
|
|
|
cap >> img0;
|
2012-10-17 09:12:04 +02:00
|
|
|
|
2014-08-10 21:24:16 +02:00
|
|
|
if( img0.empty() )
|
2010-12-28 22:28:34 +01:00
|
|
|
break;
|
2012-10-17 09:12:04 +02:00
|
|
|
|
2014-08-10 21:24:16 +02:00
|
|
|
resize(img0, img, Size(640, 640*img0.rows/img0.cols), INTER_LINEAR);
|
2012-10-17 09:12:04 +02:00
|
|
|
|
2011-06-03 16:13:03 +02:00
|
|
|
if( fgimg.empty() )
|
|
|
|
fgimg.create(img.size(), img.type());
|
|
|
|
|
|
|
|
//update the model
|
2013-03-20 16:51:49 +01:00
|
|
|
bg_model->apply(img, fgmask, update_bg_model ? -1 : 0);
|
2014-08-10 21:24:16 +02:00
|
|
|
if( smoothMask )
|
|
|
|
{
|
|
|
|
GaussianBlur(fgmask, fgmask, Size(11, 11), 3.5, 3.5);
|
|
|
|
threshold(fgmask, fgmask, 10, 255, THRESH_BINARY);
|
|
|
|
}
|
2011-06-03 16:13:03 +02:00
|
|
|
|
|
|
|
fgimg = Scalar::all(0);
|
|
|
|
img.copyTo(fgimg, fgmask);
|
|
|
|
|
|
|
|
Mat bgimg;
|
2013-03-20 16:51:49 +01:00
|
|
|
bg_model->getBackgroundImage(bgimg);
|
2011-06-03 16:13:03 +02:00
|
|
|
|
2010-12-28 22:28:34 +01:00
|
|
|
imshow("image", img);
|
|
|
|
imshow("foreground mask", fgmask);
|
2011-06-03 16:13:03 +02:00
|
|
|
imshow("foreground image", fgimg);
|
|
|
|
if(!bgimg.empty())
|
|
|
|
imshow("mean background image", bgimg );
|
|
|
|
|
2010-12-28 22:28:34 +01:00
|
|
|
char k = (char)waitKey(30);
|
2010-11-29 15:00:49 +01:00
|
|
|
if( k == 27 ) break;
|
|
|
|
if( k == ' ' )
|
2010-11-30 02:26:29 +01:00
|
|
|
{
|
2010-11-29 15:00:49 +01:00
|
|
|
update_bg_model = !update_bg_model;
|
2010-11-30 02:26:29 +01:00
|
|
|
if(update_bg_model)
|
2012-10-17 09:12:04 +02:00
|
|
|
printf("Background update is on\n");
|
2010-11-30 02:26:29 +01:00
|
|
|
else
|
2012-10-17 09:12:04 +02:00
|
|
|
printf("Background update is off\n");
|
2010-11-30 02:26:29 +01:00
|
|
|
}
|
2010-11-29 15:00:49 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|