gpt4 book ai didi

image-processing - 多边形到 OpenCV 中的轮廓?例如cvApproxPoly() 的对立面?

转载 作者:太空宇宙 更新时间:2023-11-03 21:04:31 25 4
gpt4 key购买 nike

是否有一种简单快速的 OpenCV 解决方案可以将定义多边形的一组 CvPoint 顶点转换为具有更多顶点的轮廓?

我在一个空间中有简单的多边形,我想将多边形转换到另一个空间中,直线会变成曲线。因此,向直线添加更多顶点很重要。这与 cvApproxPoly() 相反。

内部 cvPolyLine() 正在做我想要的。有什么办法可以访问它吗?

我正在使用 OpenCV 1.1。

最佳答案

所以我编写了自己的函数 GetLineFromEndPts(),它应该以一种笨拙的方式解决这个问题。给定两个点 a 和 b,此函数输出连接 a 和 b 的直线上的点列表。因此,要从由几个顶点定义的多边形中找到具有多个点的轮廓,我可以在连续的顶点对上运行此函数。

 /*
* Given two points a and b , and a sequence of CvPoints
* this function will find the points that walk the line
* between a and b and append those
* the end of the sequence
*
* Note that the output includes point a, but not point b.
*/
int GetLineFromEndPts(CvPoint a, CvPoint b, CvSeq* contour){
if (contour==NULL) {
printf("ERROR! contour in GetLineFromEndPts() is NULL!\n");
return -1;
}
float d=dist(a,b);
/** Normalized vector with components i and j pointing along the line**/
float ihat= ( (float) (b.x -a.x) ) /d;
float jhat= ( (float) (b.y -a.y) ) /d;

CvPoint currPt; /* Current Point On integer grid*/
CvPoint prevPt=a; /* Prev Point on integer grid */
currPt=a;

/** Prepare Writer for Appending Points to Seq **/
CvSeqWriter writer;
cvStartAppendToSeq( contour, &writer );

int t;
float tempPtx;
float tempPty;
int signx=1;
int signy=1;

for (t = 0; t < (int) (d+0.5) ; ++t) {

/** Our target point is now defined by a parametric equation **/
tempPtx=(float) t * ihat + (float) a.x;
tempPty=(float) t * jhat + (float) a.y;

/** We will want to round and we need to know the number's sign to round correctly **/
if (tempPtx<0) {
signx=-1;
} else {
signx=1;
}
if (tempPty<0) {
signy=-1;
} else{
signy=1;
}


/** Round to an integer value. Note that we need the sign before we add/subtract .5 **/
currPt=cvPoint((int) ( tempPtx + (float) signx * 0.5 ) ,
(int) ( tempPty + (float) signy * 0.5 ));


/** If first point, OR the current approx point is not the same as prev **/
if ( t==0 || !( currPt.x == prevPt.x && currPt.y == prevPt.y ) ){

/** Write out the point **/
CV_WRITE_SEQ_ELEM( currPt, writer );

printf(" t=%d\n",t);
printf(" currPt.x=%d\n",currPt.x);
printf(" currPt.y=%d\n",currPt.y);


}
prevPt=currPt;
}
cvEndWriteSeq( &writer );
return 1;
}

及相关函数:

/*
* Returns the squared distance between two points
*/
int sqDist(CvPoint pta, CvPoint ptb){
return ( ((pta.x - ptb.x)*(pta.x - ptb.x) ) + ((pta.y - ptb.y)*(pta.y - ptb.y) ) );
}

最后:

/*
* Finds the distance between two points
* and returns the value as a float
*/
float dist(CvPoint a, CvPoint b){
return ( sqrt( (float) sqDist(a,b)) );
}

因此,例如,如果调用:

GetLineFromEndPts(cvPoint(0,0),cvPoint(10,15),test);

函数输出:

 t=0
currPt.x=0
currPt.y=0
t=1
currPt.x=1
currPt.y=1
t=2
currPt.x=1
currPt.y=2
t=3
currPt.x=2
currPt.y=2
t=4
currPt.x=2
currPt.y=3
t=5
currPt.x=3
currPt.y=4
t=6
currPt.x=3
currPt.y=5
t=7
currPt.x=4
currPt.y=6
t=8
currPt.x=4
currPt.y=7
t=9
currPt.x=5
currPt.y=7
t=10
currPt.x=6
currPt.y=8
t=11
currPt.x=6
currPt.y=9
t=12
currPt.x=7
currPt.y=10
t=13
currPt.x=7
currPt.y=11
t=14
currPt.x=8
currPt.y=12
t=16
currPt.x=9
currPt.y=13
t=17
currPt.x=9
currPt.y=14

关于image-processing - 多边形到 OpenCV 中的轮廓?例如cvApproxPoly() 的对立面?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1959551/

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