1

我在 Android 上使用 OpenCV 2.4.0 并尝试在二进制图像中查找轮廓。

List<MatOfPoint> contours = new ArrayList<MatOfPoint>();
Mat mIntermediateMat = new Mat();
Imgproc.Canny(img, mIntermediateMat, 50, 100);
Imgproc.findContours(mIntermediateMat, contours, new Mat(), Imgproc.RETR_LIST, Imgproc.CHAIN_APPROX_SIMPLE);

但是该函数会引发“函数 CvMat ... 中无法识别或不支持的数组类型”异常。

我也尝试将此 Mat 作为输入:

Mat mIntermediateMat = new Mat(height, width, CvType.CV_8UC1, new Scalar(0));

但我得到了同样的例外。

4

2 回答 2

1

试试这个功能来寻找轮廓:

public static ArrayList<Rect> detection_contours(Mat outmat) {
    Mat v = new Mat();
    Mat vv = outmat.clone();
    List<MatOfPoint> contours = new ArrayList<MatOfPoint>();
    Imgproc.findContours(vv, contours, v, Imgproc.RETR_LIST,
            Imgproc.CHAIN_APPROX_SIMPLE);

    double maxArea = 100;
    int maxAreaIdx = -1;
    Rect r = null;
    ArrayList<Rect> rect_array = new ArrayList<Rect>();

    for (int idx = 0; idx < contours.size(); idx++) {
        Mat contour = contours.get(idx);
        double contourarea = Imgproc.contourArea(contour);
        if (contourarea > maxArea) {
            // maxArea = contourarea;
            maxAreaIdx = idx;
            r = Imgproc.boundingRect(contours.get(maxAreaIdx));
            rect_array.add(r);
          //  Imgproc.drawContours(imag, contours, maxAreaIdx, new Scalar(0,0, 255));
        }

    }

    v.release();

    return rect_array;

}
于 2014-09-15T02:30:30.410 回答
0

确保在 Canny() 调用之后,您的 mIntermediateMat 是 CvType.CV_8* 类型

于 2012-09-18T11:00:10.087 回答