gpt4 book ai didi

opencv - (Opencv)在IplImage上获取轮廓

转载 作者:行者123 更新时间:2023-12-02 17:13:29 25 4
gpt4 key购买 nike

我正在做一个运动检测项目,我想问一下我是否想在相机中获取图像,是否需要使用IplImage而不是mat图像,我也想知道我是否可以使用vector <如果将图像定义为IplImage,则使用vector> Contours而不是cvseq。这是一个寻找轮廓程序

#include <iostream>
#include <OpenCV/cv.h>
#include <OPenCV/highgui.h>

using namespace cv;
using namespace std;

CRect rect;
CvSeq* contours = 0;
CvMemStorage* storage = NULL;
CvCapture *cam;
IplImage *currentFrame, *currentFrame_grey, *differenceImg, *oldFrame_grey;

bool first = true;

int main(int argc, char* argv[])
{
//Create a new movie capture object.
cam = cvCaptureFromCAM(0);

//create storage for contours
storage = cvCreateMemStorage(0);

//capture current frame from webcam
currentFrame = cvQueryFrame(cam);

//Size of the image.
CvSize imgSize;
imgSize.width = currentFrame->width;
imgSize.height = currentFrame->height;

//Images to use in the program.
currentFrame_grey = cvCreateImage( imgSize, IPL_DEPTH_8U, 1);

while(1)
{
currentFrame = cvQueryFrame( cam );
if( !currentFrame ) break;

//Convert the image to grayscale.
cvCvtColor(currentFrame,currentFrame_grey,CV_RGB2GRAY);

if(first) //Capturing Background for the first time
{
differenceImg = cvCloneImage(currentFrame_grey);
oldFrame_grey = cvCloneImage(currentFrame_grey);
cvConvertScale(currentFrame_grey, oldFrame_grey, 1.0, 0.0);
first = false;
continue;
}

//Minus the current frame from the moving average.
cvAbsDiff(oldFrame_grey,currentFrame_grey,differenceImg);

//bluring the differnece image
cvSmooth(differenceImg, differenceImg, CV_BLUR);

//apply threshold to discard small unwanted movements
cvThreshold(differenceImg, differenceImg, 25, 255, CV_THRESH_BINARY);

//find contours
cvFindContours( differenceImg, storage, &contours );

//draw bounding box around each contour
for(; contours!=0; contours = contours->h_next)
{
rect = cvBoundingRect(contours, 0); //extract bounding box for current contour

//drawing rectangle
cvRectangle(currentFrame,
cvPoint(rect.x, rect.y),
cvPoint(rect.x+rect.width, rect.y+rect.height),
cvScalar(0, 0, 255, 0),
2, 8, 0);
}

//display colour image with bounding box
cvShowImage("Output Image", currentFrame);

//display threshold image
cvShowImage("Difference image", differenceImg);

//New Background
cvConvertScale(currentFrame_grey, oldFrame_grey, 1.0, 0.0);

//clear memory and contours
cvClearMemStorage( storage );
contours = 0;

//press Esc to exit
char c = cvWaitKey(33);
if( c == 27 ) break;

}

// Destroy the image & movies objects
cvReleaseImage(&oldFrame_grey);
cvReleaseImage(&differenceImg);
cvReleaseImage(&currentFrame);
cvReleaseImage(&currentFrame_grey);
//cvReleaseCapture(&cam);

return 0;
}

最佳答案

是的,您可以使用Mat通过以下代码从相机捕获图像:

VideoCapture cap(0);
for(;;)
{
Mat frame;
cap >> frame;
}

而且,是的,您可以使用 vector来获取轮廓。

关于opencv - (Opencv)在IplImage上获取轮廓,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22794027/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com