2

我已经阅读了许多教程和指南,并且能够转换其中的一部分。但我不知道如何将最后一行转换为 javacv。那么请有人帮我把这段代码转换成javacv吗?

img = cv2.imread('sofud.jpg')

gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)

ret,thresh = cv2.threshold(gray,127,255,1)

contours,hierarchy = cv2.findContours(thresh,cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)

  for cnt in contours:
    x,y,w,h = cv2.boundingRect(cnt)
    if 10 < w/float(h) or w/float(h) < 0.1:
    cv2.rectangle(img,(x,y),(x+w,y+h),(0,0,255),2)
4

1 回答 1

0

您可以在 Java CV 中使用最后一行:

opencv_core.cvRectangle(image, opencv_core.cvPoint(m,n), opencv_core.cvPoint(i,j), opencv_core.cvScalar(0,0,255,0), thickness, 8, 0);

其中参数的含义:

opencv_core.cvRectangle(CvArr* img, CvPoint , CvPoint, CvScalar color, int thickness=1, int lineType=8, int shift=0)

并查看此链接以获取更多信息。

编辑:

这是一个寻找轮廓的例子:

cvFindContours(grayImage, memory, contours, sizeof(CvContour.class) , CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE, cvPoint(0,0));

其中参数的意思是:

cvFindContours(CvArr* image, CvMemStorage* storage, CvSeq** first_contour, int header_size=sizeof(CvContour), int mode=CV_RETR_LIST, int method=CV_CHAIN_APPROX_SIMPLE, CvPoint offset=cvPoint(0,0) )

有关参数的更多信息,请查看此链接部分FindContours

您也可以使用该cvDrawContours函数,以与我们使用cvFindContours函数相同的方式绘制轮廓。

看看这个链接。这是该网站上的另一篇文章,他们在其中解释了在斑点检测中寻找轮廓的用途。

希望这可以帮助。

于 2012-07-07T05:07:31.957 回答