运行环境:win10+visual studio1015 +opencv3.4
实现程序如下:
#include<opencv2/opencv.hpp>
#include<iostream>
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(dfra