OpenCV入门七:OpenCV打开视频文件,并对其中的每一帧图像进行Canny算子边缘化提取,并将结果保存为视频文件

本文介绍如何使用OpenCV对视频中的每一帧应用Canny边缘检测算法,并将处理后的帧保存为新的视频文件。代码示例展示了如何读取视频、进行边缘检测及输出处理后的视频。

OpenCV打开视频文件,并对其中的每一帧图像进行Canny算子边缘化提取

 

#include <iostream> 
#include <opencv2/core/core.hpp> 
#include<opencv2/highgui/highgui.hpp> 
#include <opencv2/opencv.hpp>
using namespace cv; 
using namespace std;
int main() 
{ 
	//打开第一个摄像头
	//VideoCapture cap(0);
	VideoCapture cap("F:/视频教程/孙鑫VC++视频教程 共20讲/2(C++经典语法与应用).rmvb");
	//检查摄像头是否成功打开
	if (!cap.isOpened())
	{
		cout<<"摄像头未成功打开"<<endl;
	}
	//创建Mat对象
	Mat M;
	//创建窗口
	namedWindow("打开摄像头",1);
	//读取摄像头中的帧
	for (;;)
	{
		Mat frame;
		//从cap中读取一帧存到frame中
		cap>>frame;
		//判断是否读取到
		if (frame.empty())
		{
			break;
		}
		//将摄像头读取到的图像转化为灰度图
		cvtColor(frame,M,CV_BGR2GRAY);
		//进行canny算子边缘化提取
		Canny(M,M,0,30,3);
		//在窗口中显示视频中每一帧被边缘化的图像
		imshow("打开摄像头",M);
		//等待300秒,如果按键则退出循环
		if (waitKey(300)>=0)
		{
			break;
		}
	}
	         
}

 

有码友提问:现在根据视频每一帧利用canny算子提取轮廓,但是我想把提取轮廓后的每一帧连贯起来保存为视频文件改怎么办呢?所以今天就重新改写了代码,可以将提取后的canny画面保存为一个视频文件,下面是示例代码,输入的视频文件必须为.avi格式,试了rmvb不行,可以采用格式工厂等软件进行转换,原因未知。

 

 

#include <iostream> 
#include <opencv2/core/core.hpp> 
#include<opencv2/highgui/highgui.hpp> 
#include <opencv2/opencv.hpp>
using namespace cv; 
using namespace std;
int main() 
{ 
	//打开输入视频文件
	VideoCapture cap("C:/Users/Administrator/Desktop/jpg/2(C++经典语法与应用).avi");
	
	//创建窗口
	//namedWindow("打开摄像头",1);
	if (cap.isOpened())
	{
		VideoWriter writer=VideoWriter("E:/Canny.avi",//输出路径以及文件名
			(int)cap.get(CV_CAP_PROP_FOURCC),//根据输入视频得到其编解码器
			(int)cap.get(CV_CAP_PROP_FPS),//根据输入视频得到帧率
			Size((int)cap.get( CV_CAP_PROP_FRAME_WIDTH ),//根据输入视频得到视频宽度
			(int)cap.get(CV_CAP_PROP_FRAME_HEIGHT)),//根据输入视频得到视频高度
			false//输出不为彩色,因为canny后的为灰度图
			);
		//如果创建输出视频文件成功
		if (writer.isOpened())
		{
			for(;;)
			{
				//创建Mat对象
				Mat M;
				Mat frame;
				//从cap中读取一帧存到frame中
				cap>>frame;
				//判断是否读取到
				if (frame.empty())
				{
					cout<<"frame  is empty!"<<endl;
					break;
				}
				////将摄像头读取到的图像转化为灰度图
				cvtColor(frame,M,CV_BGR2GRAY);
				////进行canny算子边缘化提取
				Canny(M,M,0,30,3);
				//在窗口中显示视频中每一帧被边缘化的图像
				imshow("打开摄像头",M);
				if (waitKey(300)>=0)  
				{  
					break;  
				} 
				//写入被canny算子处理后的视频帧
				writer<<M;
			}
		}
	}
	else
	{
		cout<<"打开视频错误!"<<endl;
	}
	cap.release();
}


结果

 

如果您觉得这篇博文有用,请访问我的个人站:http://www.stubbornhuang.com,更多博文干货等着您。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HW140701

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值