您的位置:首页 > 运维架构

使用OpenCV实现WebCam摄像头保存JPEG图片

2010-03-16 14:15 811 查看
本次的代码(OpenCV是2.0的,在2.0中的cvSaveImage函数里多了一个参数可以设置保存图片的质量)从上次实现从电脑上的摄像头捕捉视频并一秒保存一张图片的效果并可以修改保存的图片的像素功能出发,实现了毫秒级保存图片的功能,代码如下(本程序在OpenCV1.0下编译不通过):
//使用OpenCV实现获取摄像头数据并毫秒级(在我的机上70ms左右保存一张,连续保存)保存成一张jpg图片,jpg图片的大小可调,文件名为test.c
//编译方法为:g++ `pkg-config opencv --libs --cflags opencv` test.c -o test
#include<stdio.h>
#include <sys/stat.h>
#include <sys/types.h>
#include<time.h>
#include <sys/timeb.h>
#include<stdlib.h>
#include<cv.h>
#include<cxcore.h>
#include<highgui.h>
int main( int argc,char ** argv )
{
//声明IplImage指针
IplImage* pFrame=NULL;
IplImage* pSaveFrame=NULL;
CvCapture* pCapture=NULL;
static char filename[40];
struct tm * tm_ptr;
struct timeb tp;
int p[3];
p[0] = CV_IMWRITE_JPEG_QUALITY;
p[1] = 10; //质量值
p[2] = 0;
//创建窗口
cvNamedWindow("video",1);
//打开摄像头
if( !(pCapture=cvCaptureFromCAM(-1)) ) //此处值为-1表示自动搜索到的第一个摄象头,而0则表示第一个,1则表示第2个,以此类推。
{
fprintf(stderr,"Can not open camera./n");
return -1;
}
if(mkdir("./Alert",0755)==-1)
{
//创建时存在该目录会返回错误码,如不存在则创建它,但由于我们需要该目录,则出错也不处理
}
//逐帧读取视频
while(pFrame=cvQueryFrame(pCapture))
{
cvShowImage("video",pFrame);
if(cvWaitKey(2)>=0) break;
pSaveFrame=cvCreateImage(cvSize(320,240),pFrame->depth,pFrame->nChannels);
//get file name
ftime(&tp);
tm_ptr=localtime(&tp.time);
snprintf(filename, 40, "./Alert/%04d%02d%02d%02d%02d%02d%04d.jpg",tm_ptr->tm_year-100+2000, tm_ptr->tm_mon + 1, tm_ptr->tm_mday, tm_ptr->tm_hour,tm_ptr->tm_min, tm_ptr->tm_sec,tp.millitm);
cvResize(pFrame,pSaveFrame,CV_INTER_LINEAR);
cvSaveImage(filename,pSaveFrame,p);
cvReleaseImage(&pSaveFrame);
}
cvDestroyWindow("video");
cvReleaseCapture(&pCapture);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: