#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;
}
#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;
}