视频文件读写


#include "cv.h"
#include "highgui.h"

// Convert a video to grayscale
// argv[1]: input video file
// argv[2]: name of new output file

int main( int argc, char* argv[] ) 
{
	cvNamedWindow( "Original", CV_WINDOW_AUTOSIZE );
	cvNamedWindow( "New", CV_WINDOW_AUTOSIZE );
	CvCapture* capture = cvCreateFileCapture( argv[1] );
	if (!capture)
	{
		return -1;
	}   
	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));  
	CvVideoWriter* writer = cvCreateVideoWriter(
		argv[2], CV_FOURCC('D','I','V','X'),fps,size);
	IplImage* gray_frame = cvCreateImage(size, IPL_DEPTH_8U,3);
	IplImage* bgr_frame;
	while( (bgr_frame=cvQueryFrame(capture)) != NULL ) 
	{
		cvShowImage( "Original", bgr_frame );
		cvConvertImage(bgr_frame,gray_frame,0); 
		cvShowImage( "New", gray_frame );  
		cvWriteToAVI( writer, gray_frame);
		char c = cvWaitKey(10);
		if( c == 27 ) break;
	}
	cvReleaseVideoWriter( &writer );
	cvReleaseImage( &gray_frame );  
	cvReleaseCapture( &capture );
}

#include "cv.h"
#include "highgui.h"

// Convert a video to grayscale
// argv[1]: input video file
// argv[2]: name of new output file

int main( int argc, char* argv[] ) 
{
	cvNamedWindow( "Original", CV_WINDOW_AUTOSIZE );
	cvNamedWindow( "New", CV_WINDOW_AUTOSIZE );
	CvCapture* capture = cvCreateFileCapture( argv[1] );
	if (!capture)
	{
		return -1;
	}   
	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));  
	CvVideoWriter* writer = cvCreateVideoWriter(
		argv[2], CV_FOURCC('D','I','V','X'),fps,size);
	IplImage* bgr_frame;
	IplImage* gray_frame;
	while( (bgr_frame=cvQueryFrame(capture)) != NULL ) 
	{
		cvShowImage( "Original", bgr_frame );		
		gray_frame=bgr_frame;
		cvShowImage( "New", gray_frame );  
		cvWriteToAVI( writer, gray_frame);
		char c = cvWaitKey(10);
		if( c == 27 ) break;
	}
	cvReleaseVideoWriter( &writer );
	cvReleaseCapture( &capture );
}

#include "cv.h"
#include "highgui.h"

// Convert a video to grayscale
// argv[1]: input video file
// argv[2]: name of new output file

int main( int argc, char* argv[] ) 
{
	cvNamedWindow( "Original", CV_WINDOW_AUTOSIZE );
	cvNamedWindow( "New", CV_WINDOW_AUTOSIZE );
	CvCapture* capture = cvCreateFileCapture( argv[1] );
	if (!capture)
	{
		return -1;
	}   
	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));  
	CvVideoWriter* writer = cvCreateVideoWriter(
		argv[2], CV_FOURCC('D','I','V','X'),fps,size);
	IplImage* bgr_frame;	
	while( (bgr_frame=cvQueryFrame(capture)) != NULL ) 
	{
		cvShowImage( "Original", bgr_frame );		
		cvShowImage( "New", bgr_frame );  
		cvWriteToAVI( writer, bgr_frame);
		char c = cvWaitKey(10);
		if( c == 27 ) break;
	}
	cvReleaseVideoWriter( &writer );
	cvReleaseCapture( &capture );
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值