Sam*_*nga 8 c++ opencv assertion projection-matrix
我尝试使用countNonZero()函数进行水平投影,如下所示.
Mat src = imread(INPUT_FILE, CV_LOAD_IMAGE_COLOR);
Mat binaryImage = src.clone();
cvtColor(src, src, CV_BGR2GRAY);
Mat horizontal = Mat::zeros(1,binaryImage.cols, CV_8UC1);
for (int i = 0; i<binaryImage.cols; i++)
{
Mat roi = binaryImage(Rect(0, 0, 1, binaryImage.rows));
horizontal.at<int>(0,i) = countNonZero(roi);
cout << "Col no:" << i << " >>" << horizontal.at<int>(0, i);
}
Run Code Online (Sandbox Code Playgroud)
但是在调用countonZero()函数时出现错误.错误如下.
OpenCV Error: Assertion failed (src.channels() == 1 && func != 0) in cv::countNo
nZero, file C:\builds\2_4_PackSlave-win32-vc12-shared\opencv\modules\core\src\st
at.cpp, line 549
Run Code Online (Sandbox Code Playgroud)
有人可以指出错误吗?
Mik*_*ail 15
断言src.channels() == 1
意味着图像应该有1个通道,即它必须是灰色的,而不是彩色的.你调用countNonZero
上roi
,这是一个子图像binaryImage
,这是一个克隆src
,这是原来的颜色.
我想你想写cvtColor(binaryImage, binaryImage, CV_BGR2GRAY);
.在这种情况下,它是有道理的.但是,我没有看到你src
再次使用,所以也许你不需要这个中间图像.如果你这样做,不要叫"二进制",因为计算机视觉中的"二进制"通常代表黑白图像,只有两种颜色.你的图像是"灰色的",因为它有黑色和白色的所有色调.
关于你的原始任务,Miki是对的,你应该使用cv::reduce
它.他已经给你一个如何使用它的例子.
归档时间: |
|
查看次数: |
10687 次 |
最近记录: |