8

我正在开发一个 Android 应用程序,该应用程序使用 OpenCV for Android 计算正在看到的多米诺骨牌碎片的所有点的总和 - 如图所示。

一个样品

问题是,我找不到过滤其他轮廓并只计算我在多米诺骨牌中看到的点的方法,我尝试使用 Canny 边缘查找然后使用 HoughCircles,但没有结果,因为我没有绝对的顶部岩石视图和 HoughCircles 仅检测完美圆圈 :)

这是我的代码:

public Mat onCameraFrame(Mat inputFrame) {
    inputFrame.copyTo(mRgba);

    Mat grey = new Mat();
    // Make it greyscale
    Imgproc.cvtColor(mRgba, grey, Imgproc.COLOR_RGBA2GRAY);

    // init contours arraylist
    List<MatOfPoint> contours = new ArrayList<MatOfPoint>(200);     

    //blur
    Imgproc.GaussianBlur(grey, grey, new Size(9,9), 10);        
    Imgproc.threshold(grey, grey, 80, 150, Imgproc.THRESH_BINARY);


    // because findContours modifies the image I back it up
    Mat greyCopy = new Mat();
    grey.copyTo(greyCopy);


    Imgproc.findContours(greyCopy, contours, new Mat(), Imgproc.RETR_TREE, Imgproc.CHAIN_APPROX_NONE);      
    // Now I have my controus pefectly


    MatOfPoint2f mMOP2f1 = new MatOfPoint2f();

    //a list for only selected contours
    List<MatOfPoint> SelectedContours = new ArrayList<MatOfPoint>(400);     

    for(int i=0;i<contours.size();i++)
    {

        if(here I should put a condition that distinguishes my spots, eg: if contour inside is black and is a black disk)
        {
            SelectedContours.add(contours.get(i));
        }
    }
    Imgproc.drawContours(mRgba, SelectedContours, -1, new Scalar(255,0,0,255), 1);       
    return mRgba;        
}

编辑:

阈值后轮廓的一个独特特征是它们从内部完全是黑色的,无论如何我可以计算给定轮廓的平均颜色/强度吗?

4

1 回答 1

5

SO上有一个类似的问题和可能的解决方案,名为Detection of coin (and fit ellipses) on an image。在这里你会发现一些关于 opencv 函数的建议fitEllipse

你应该看看这个以获得更多关于 opencv 函数的信息fitEllipse

此外,要仅检测图像中的黑色元素,您可以使用 HSV 颜色模型,仅查找黑色。你可以在这里找到解释

于 2012-12-28T07:28:01.287 回答