Learning OpenCV: cvSmooth processing

本文介绍了一个使用C++和OpenCV进行视频文件处理的应用实例。该程序读取一个视频文件,通过滑动条来选择播放帧的位置,并展示了如何应用高斯模糊效果。此程序为理解OpenCV中的视频捕获和图像平滑提供了实践指南。
#include "stdafx.h"
#include <iostream>
#include <fstream>
using namespace std;
#include "cv.h"
#include "highgui.h"


int g_slider_position = 0;
CvCapture * g_capture = NULL;


void onTrackbarSlide(int pos)
{
cvSetCaptureProperty(g_capture,CV_CAP_PROP_POS_FRAMES,pos);
}


int main(void)
{
cvNamedWindow("video",CV_WINDOW_AUTOSIZE);
g_capture = cvCreateFileCapture("E:\\test\\fish1.avi");
int frames = (int)cvGetCaptureProperty(g_capture,CV_CAP_PROP_FRAME_COUNT);
if(frames != 0)
{
cvCreateTrackbar("position","video",&g_slider_position,frames,onTrackbarSlide);
}
IplImage * frame = NULL;
frame = cvQueryFrame(g_capture);
if(g_capture == NULL)
{
cout<<"read video file error!"<<endl;
}
IplImage * outFrame = NULL;
outFrame = cvCreateImage(cvGetSize(frame),IPL_DEPTH_8U,frame->nChannels);
cvNamedWindow("outvideo",CV_WINDOW_AUTOSIZE);
while(1)
{
frame = cvQueryFrame(g_capture);
if(frame == NULL)
{
break;
}
cvShowImage("video",frame);
cvSmooth(frame,outFrame,CV_GAUSSIAN,3);
cvShowImage("outvideo",outFrame);
char c = cvWaitKey(33);
if(c == 27)
{
break;
}
}
cvReleaseCapture(&g_capture);
g_capture = NULL;
cvDestroyWindow("video");
cvDestroyWindow("outvideo");
cvReleaseImage(&outFrame);
outFrame = NULL;
return 0;
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值