如何在Java OpenCV中找到最大的轮廓

5

我已经使用了findContours和boundingRect并在我的项目中显示了它。然后我想找到最大的轮廓并显示它。这是可能的吗?我是OpenCV Java语言的新手。

以下是我目前的代码:

@Override
public void onCameraViewStarted(int width, int height) {
    mRgba = new Mat(height, width, CvType.CV_8UC4);
    mHsv = new Mat(height,width,CvType.CV_8UC3);
    hierarchy = new Mat();
    mHsvMask = new Mat();
    mDilated = new Mat();
    mEroded = new Mat();
}

@Override
public void onCameraViewStopped() {
    mRgba.release();
    mHsv.release();
    mHsvMask.release();
    mDilated.release();
    hierarchy.release();

}

@Override
public Mat onCameraFrame(CameraBridgeViewBase.CvCameraViewFrame inputFrame) {

    mRgba =inputFrame.rgba();
    contours = new ArrayList<MatOfPoint>();
    hierarchy =new Mat();
    mHsv = new Mat();
    mHsvMask =new Mat();

    Imgproc.cvtColor(mRgba, mHsv, Imgproc.COLOR_RGB2HSV);

    Scalar lowerThreshold = new Scalar ( 0, 0, 0 ); // Blue color – lower hsv values
    Scalar upperThreshold = new Scalar ( 179, 255, 10 ); // Blue color – higher hsv values
    Core.inRange ( mHsv, lowerThreshold , upperThreshold, mHsvMask );

     //just some filter
   //Imgproc.dilate ( mHsvMask, mDilated, new Mat() );
    //Imgproc.erode(mDilated,mEroded,new Mat());


    Imgproc.findContours(mHsvMask, contours, hierarchy, Imgproc.RETR_TREE, Imgproc.CHAIN_APPROX_SIMPLE);

    for ( int contourIdx=0; contourIdx < contours.size(); contourIdx++ )
    {
        //Minimun size allowed for consideration
        MatOfPoint2f approxCurve = new MatOfPoint2f();
        MatOfPoint2f contour2f = new MatOfPoint2f(contours.get(contourIdx).toArray());

      //Processing on mMOP2f1 which is in type MatOfPoint2f
        double approxDistance = Imgproc.arcLength(contour2f,true)*0.02;
        Imgproc.approxPolyDP(contour2f,approxCurve,approxDistance,true);

        //convert to MatofPoint
        MatOfPoint point = new MatOfPoint(approxCurve.toArray());

        //get boundingrect from contour
        Rect rect = Imgproc.boundingRect(point);

        Imgproc.rectangle(mRgba,new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height), new Scalar(255, 0, 0, 255),3);
        //bisa Imgproc.rectangle(mRgba, rect.tl(), rect.br(), new Scalar(255, 0, 0),1, 8,0);


        //show contour kontur
        if(Imgproc.contourArea(contours.get(contourIdx))>100) {
            Imgproc.drawContours(mRgba, contours, contourIdx, new Scalar(0,255,0), 5);
        }
    }
    return mRgba;

希望有人在这方面有经验。谢谢。

是的,这肯定是可能的。您能更精确地定义“最大轮廓”是什么意思吗?您是想找到具有最大面积(白色像素)的轮廓,还是只需要具有其 boundingRect() 最大面积的轮廓? - ZdaR
@ZadR 我想展示边界框中最大的那个。希望你能帮我。抱歉,我对此还很陌生。 - Bagus W
1个回答

14

使用函数Imgproc.contourArea,您可以轻松查找所有轮廓的面积,具有最大面积的轮廓将是最大的一个。

绘制最大轮廓的代码如下:

double maxVal = 0;
int maxValIdx = 0;
for (int contourIdx = 0; contourIdx < contours.size(); contourIdx++)
{
    double contourArea = Imgproc.contourArea(contours.get(contourIdx));
    if (maxVal < contourArea)
    {
        maxVal = contourArea;
        maxValIdx = contourIdx;
    }
}

Imgproc.drawContours(mRgba, contours, maxValIdx, new Scalar(0,255,0), 5);

嗯,我会尝试,但我想找到最大的矩形面积。不要用contourArea,你能帮我吗?使用boundingrect来显示最大的边界框。谢谢。 - Bagus W
这样,您也可以找到边界矩形的最大面积。只需遍历所有矩形,通过将其高度和宽度相乘计算它们的面积并找到最大值即可。 - Dainius Šaltenis
一旦你有了这个,是否可以获取它的角落?详细问题-> https://stackoverflow.com/questions/55311775/opencv-finding-corners-of-contours - mirzak

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接