我尝试使用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);
}
但是在调用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
有人可以指出错误吗?
答案 0 :(得分:14)
断言src.channels() == 1
表示图像应该有1个通道,即它必须是灰色的,而不是彩色的。您在countNonZero
上呼叫roi
,binaryImage
是src
的子图像,它是cvtColor(binaryImage, binaryImage, CV_BGR2GRAY);
的副本,最初是彩色的。
我想你想写src
。在这种情况下,它是有道理的。但是,我没有看到你再次使用cv::reduce
,所以也许你不需要这个中间图像。如果你这样做,不要叫“二进制”,因为计算机视觉中的“二进制”通常代表黑白图像,只有两种颜色。你的图像是“灰色的”,因为它有黑色和白色的所有色调。
关于您的原始任务,Miki是对的,您应该使用BottomSheet bottomSheet = new BottomSheet.Builder(getActivity())
.title(R.string.sharing_warning_note)
.sheet(R.id.menu_facebook, facebookDrawable,
getString(R.string.publishing_settings_facebook))
.sheet(R.id.menu_vkontakte, vkontakteDrawable,
getString(R.string.publishing_settings_vkontakte))
.divider()
.listener(new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
switch (which) {
case R.id.menu_facebook:
share(SocialNetworkType.FACEBOOK);
break;
case R.id.menu_vkontakte:
share(SocialNetworkType.VK);
break;
default:
}
}
})
.build();
bottomSheet.show();
。他已经举例说明了如何使用它。
答案 1 :(得分:0)
顺便说一句,您可以使用reduce
作为参数CV_REDUCE_SUM
来计算水平投影。
一个最小的例子:
Mat1b mat(4, 4, uchar(0));
mat(0,0) = uchar(1);
mat(0,1) = uchar(1);
mat(1,1) = uchar(1);
// mat is:
//
// 1100
// 0100
// 0000
// 0000
// Horizontal projection, result would be a column matrix
Mat1i reducedHor;
cv::reduce(mat, reducedHor, 1, CV_REDUCE_SUM);
// reducedHor is:
//
// 2
// 1
// 0
// 0
// Vertical projection, result would be a row matrix
Mat1i reducedVer;
cv::reduce(mat, reducedVer, 0, CV_REDUCE_SUM);
// reducedVer is:
//
// 1200
// Summary
//
// 1100 > 2
// 0100 > 1
// 0000 > 0
// 0000 > 0
//
// vvvv
// 1200
您可以将此功能用于以下图片:
// RGB image
Mat3b img = imread("path_to_image");
// Gray image, contains values in [0,255]
Mat1b gray;
cvtColor(img, gray, CV_BGR2GRAY);
// Binary image, contains only 0,1 values
// The sum of pixel values will equal the count of non-zero pixels
Mat1b binary;
threshold(gray, binary, 1, 1, THRESH_BINARY);
// Horizontal projection
Mat1i reducedHor;
cv::reduce(binary, reducedHor, 1, CV_REDUCE_SUM);
// Vertical projection
Mat1i reducedVer;
cv::reduce(binary, reducedVer, 0, CV_REDUCE_SUM);