1

我正在尝试使用 android-opencv 2.3.1 来识别图像中的圆圈(硬币)。但是,通过执行 Imgproc.cvtColor 方法会发生错误(org.opencv.cvException)。

File imgFile = new File(Environment.getExternalStorageDirectory() + "/test.jpg");
imageBmp = BitmapFactory.decodeFile(imgFile.getAbsolutePath());

Mat mImg = new Mat();
mImg = Utils.bitmapToMat(imageBmp);        
Mat mGray = new Mat(mImg.rows(), mImg.cols(), CvType.CV_8UC1, new Scalar(0));
Imgproc.cvtColor(mImg , mGray, Imgproc.COLOR_BGRA2GRAY, 4); 
Imgproc.GaussianBlur( mGray , mGray , new Size(9, 9), 2, 2);
Mat circles = new Mat();
Imgproc.HoughCircles(mGray , circles, Imgproc.CV_HOUGH_GRADIENT, 1d, (double)  
                    mGray.height() / 70, 200d, 100d);   

我究竟做错了什么?手机:三星 Galaxy S i9000


只是用新代码更新我的问题。“Imgproc.cvtColor”方法仍然给出同样的错误。

File imgFile = new File(Environment.getExternalStorageDirectory() + "/test.jpg");
imageBmp = BitmapFactory.decodeFile(imgFile.getAbsolutePath());
Mat mImg = new Mat();
mImg = Utils.bitmapToMat(imageBmp);
Mat mGray = new Mat(mImg.rows(), mImg.cols(), CvType.CV_8UC1);
Imgproc.cvtColor(mImg, mGray, Imgproc.COLOR_BGRA2GRAY);
Imgproc.GaussianBlur(mGray, mGray, new Size(9, 9), 2, 2);
Mat circleImage = new Mat(mGray.rows(), mGray.cols(), CvType.CV_8UC1);
Imgproc.HoughCircles(mGray, circleImage, Imgproc.CV_HOUGH_GRADIENT, 1d,
         (double) mGray.height() / 70, 200d, 100d);
4

1 回答 1

2

我不是 Java 程序员,但可以在您的代码中看到两个问题。首先,cvtColor() 中最后一个参数的值不应该是 4。改变这个

Imgproc.cvtColor(mImg , mGray, Imgproc.COLOR_BGRA2GRAY, 4);

对此

Imgproc.cvtColor(mImg , mGray, Imgproc.COLOR_BGRA2GRAY);

由于它正在从 BGRA 转换为灰度,它理解目标 ( mGray) 是单通道。

二、你为什么要new Scalar(0)传给

Mat mGray = new Mat(mImg.rows(), mImg.cols(), CvType.CV_8UC1, new Scalar(0));

? 那可能是把事情搞砸了。我会调用为图像分配内存的构造函数:

Mat mGray = new Mat(mImg.rows(), mImg.cols(), CvType.CV_8UC1);

编辑:现在问题可能出在您阅读图像并转换为Mat. 我会替换这个

imgFile.getAbsolutePath()
mImg = Utils.bitmapToMat(imageBmp);

这样

Mat mImg = Highgui.imread(imgFile.getAbsolutePath());

然后确保mImg.rows()返回正确的值。请让我知道情况如何。

于 2012-05-06T06:38:54.223 回答