Learning OpenCV:cvCvtColor and cvCanny

#include "stdafx.h"
#include <iostream>
#include <fstream>
using namespace std;
#include "cv.h"
#include "highgui.h"
#include <assert.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;
}
cvNamedWindow("outvideo",CV_WINDOW_AUTOSIZE);
IplImage * grayImage = NULL;
grayImage = cvCreateImage(cvSize(frame->width,frame->height),IPL_DEPTH_8U,1);
cvNamedWindow("grayVideo",1);
IplImage * outFrame = NULL;
outFrame = cvCreateImage(cvSize(frame->width,frame->height),frame->depth,1);
while(1)
{
frame = cvQueryFrame(g_capture);
if(frame == NULL)
{
break;
}
cvCvtColor(frame,grayImage,CV_BGR2GRAY);
cvCanny(grayImage,outFrame,1.2,3.0,3);
cvShowImage("video",frame);
cvShowImage("grayVideo",grayImage);
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;
cvReleaseImage(&grayImage);
grayImage = NULL;
cvDestroyWindow("grayVideo");
return 0;
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值