我正在使用Openframeworks中的OpenCV来跟踪某种颜色。如果您不熟悉颜色跟踪代码,我的问题可能会很困难,但我会尽力解释。
现在代码所做的是使用带有红色圆圈的特定颜色,我正在创建一条基本相同的行,但每个点都将被存储,以便创建一个波浪形的绘图应用程序。现在它是你可以拉的直线。
如果有必要,我会发布更多代码。任何建议都会有所帮助。谢谢!
tespApp.cpp
void testApp::draw(){
ofSetColor(255,255,255);
//draw coloured cv image
rgb.draw(0,0);
contours.draw(0,480);
// draw line that follows the blobs
for (int i=0; i<contours.nBlobs; i++) {
ofSetColor(0);
ofLine( contours.blobs[i].pos.x, contours.blobs[i].pos.y, contours.blobs[i].lastpos.x, contours.blobs[i].lastpos.y );
}
}
ofxCvContourFinder.cpp
for( int i = 0; i < MIN(nConsidered, (int)cvSeqBlobs.size()); i++ ) {
blobs.push_back( ofxCvBlob() );
float area = cvContourArea( cvSeqBlobs[i], CV_WHOLE_SEQ, bFindHoles ); // oriented=true for holes
CvRect rect = cvBoundingRect( cvSeqBlobs[i], 0 );
cvMoments( cvSeqBlobs[i], myMoments );
blobs[i].area = bFindHoles ? fabs(area) : area; // only return positive areas
blobs[i].length = cvArcLength(cvSeqBlobs[i]);
blobs[i].boundingRect.x = rect.x;
blobs[i].boundingRect.y = rect.y;
blobs[i].boundingRect.width = rect.width;
blobs[i].boundingRect.height = rect.height;
blobs[i].centroid.x = (myMoments->m10 / myMoments->m00);
blobs[i].centroid.y = (myMoments->m01 / myMoments->m00);
blobs[i].pos.x =0;
blobs[i].pos.y =0;
blobs[i].lastpos.x = blobs[i].pos.x;
blobs[i].lastpos.y = blobs[i].pos.y;
blobs[i].pos.x =(myMoments->m10 / myMoments->m00);
blobs[i].pos.y = (myMoments ->m01 / myMoments->m00);
答案 0 :(得分:1)
您可以在此处找到您要实现的目标的完整示例:
https://github.com/kylemcdonald/ofxCv/tree/master/example-contours-color
它使用了xCv,这是一个附加组件,可让您以干净的方式将openframeworks与openCv集成。此外,您可以使用本机OpenCV调用,而无需任何类型的包装器。互联网上充满了使用纯OpenCV代码的类似示例,使用这些附加内容,您可以原样使用这些代码段,没有任何问题,它提供了一些从OpenCV数据结构到Openframeworks数据结构的简单方法,反之亦然。太棒了!