视频文件写入转换之图像处理-OpenCV应用学习笔记五

时间:2023-03-09 07:32:48
视频文件写入转换之图像处理-OpenCV应用学习笔记五

视频文件写入转换之图像处理-OpenCV应用学习笔记五

在《笔记二》中我们做了视频播放和控制的实现,仅仅算是完成了对视频文件的读取操作;今天我们来一起练习下对视频文件的写入操作:格式转换。

实现功能:

打开一个视频文件play.avi,读取文件内容,将每一帧图像转换为对数极坐标格式最后将转换后的图像序列写入新的视频文件play1.avi中。如下图对比效果:

视频文件写入转换之图像处理-OpenCV应用学习笔记五

视频文件写入转换之图像处理-OpenCV应用学习笔记五

函数精析:

  • CvVideoWriter* cvCreateVideoWriter(const char* filename, int fourcc, double fps, CvSize frameSize, int isColor=1 )

  • 创建视频文件写入器
  • filename:新建视频文件的名称,fourcc:视频压缩的编码格式,fps:视频播放帧率,size:帧尺寸
  • isColor=0:希望得到灰度帧进行编码;!=0:希望得到彩色帧进行编码
  • OpenCV用宏CV_FOURCC()来制定编码格式:CV_FOURCC('P','I','M,'1')—MPEG;CV_FOURCC('M','J','P','G')motion-jpeg
  • cvLogPolar(const CvArr* src, CvArr* dst, CvPoint2D32f center, double M, int  flags=CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS )

  • 将图像映射到极坐标;
  • src:原图像,dst:输出图像,center:转换中心
  • 函数模仿人眼中心凹注视,用在旋转不变的模板匹配和物体追踪上
  • cvWriteFrame(CvVideoWriter* writer, const IplImage* image)

  • 将指定的图像写入到视频文件中,必须是在打开视频写入器之前已经定义的相同图像尺寸
  • writer:视频写入器,image:写入的视频帧
  • 附源代码:

#include "stdafx.h"
#include "cv.h"
#include "highgui.h" int main(int argc,char** argv)
{
if(argc == )
{ CvCapture* capture = ;
capture = cvCreateFileCapture(argv[]); //从指定文件获取视频流
if(!capture) return -;
IplImage *bgr_frame = cvQueryFrame(capture); //从读取的视频流capture中读取一帧
double fps = cvGetCaptureProperty(capture,CV_CAP_PROP_FPS);//获取视频帧率
CvSize size = cvSize((int)cvGetCaptureProperty(capture,CV_CAP_PROP_FRAME_WIDTH),
(int)cvGetCaptureProperty(capture,CV_CAP_PROP_FRAME_HEIGHT));
//获取视频流中帧的尺寸 /*cvCreateVideoWriter(新建视频文件名,视频压缩编码格式,帧率,尺寸)*/
CvVideoWriter * writer = cvCreateVideoWriter(argv[],CV_FOURCC('M','J','P','G'),
fps,size); //创建视频文件写入器 IplImage* logpolar_frame = cvCreateImage(size,IPL_DEPTH_8U,);
while((bgr_frame = cvQueryFrame(capture)) != NULL)
{
/* 将图像映射到极坐标cvLogPolar(原图像,输出图像,转换中心,量级水平,标志位)*/
cvLogPolar(bgr_frame,logpolar_frame,cvPoint2D32f(bgr_frame->width/,
bgr_frame->height/),,CV_INTER_LINEAR+CV_WARP_FILL_OUTLIERS);
cvWriteFrame(writer,logpolar_frame);//(视频写入器,要吸入的帧)
}
cvReleaseVideoWriter(&writer);
cvReleaseImage(&logpolar_frame);
cvReleaseCapture(&capture);
}
return ;
}