背景差分法 -- 基于opencv

运行环境:win10+visual studio1015 +opencv3.4

实现程序如下: 

#include
#include
using namespace std;
using namespace cv;

int main()//差分法
{
	VideoCapture capture("bike.avi");//获取视频
	if (!capture.isOpened())
	{
		return -1;
	}
	double rate = capture.get(CV_CAP_PROP_FPS);//获取视频帧率
	int delay = 500 / rate;
	Mat framepro, frame, dframe;
	bool flag = false;
	namedWindow("image");
	namedWindow("test");

	while (capture.read(frame))  //还有视频为1,,否则为0
	{
		if (flag == false)
		{
			framepro = frame.clone();//将第一帧图像拷贝给framepro
		    imwrite("first.jpg", framepro);  //保存第一帧视频作为背景
			flag = true;
		}
		else

		//Mat framepro;
		//framepro = imread("first.jpg", IMREAD_COLOR);

		{
			absdiff(frame, framepro, dframe);//帧间差分计算两幅图像各个通道的相对应元素的差的绝对值。
//			framepro = frame.clone();//将当前帧拷贝给framepro
			threshold(dframe, dframe, 90, 255, CV_THRESH_TOZERO);//阈值分割
			imshow("image1", framepro);   //显示第一帧
			imshow("image", frame);       //显示视频帧
			imshow("test", dframe);
			waitKey(delay);
		}
	}
	waitKey();
	return 0;
}

需要bike.avi的可以私信我。

实现效果:

背景差分法 -- 基于opencv_第1张图片 原始帧 背景差分法 -- 基于opencv_第2张图片 差分结果 背景差分法 -- 基于opencv_第3张图片 背景

 可能现在效果看着不太明显,再加上一个二值化就可以了。

 

你可能感兴趣的:(C++,视觉)