我是 OpenCV 的新手,我想练习一个简单的人脸检测和图像裁剪。
具体来说,我使用 加载文件夹中的图像cv::glob
,然后检测人脸,在检测到的人脸上绘制一个矩形,然后仅裁剪检测到的人脸区域。
一切正常,检测到人脸,在现场绘制矩形。除了最后一部分:裁剪。我得到了臭名昭著的 Assertion Failed
错误。下面是我的代码和我遇到的错误:
void faceDetectFolder()
{
Mat source;
CascadeClassifier face_cascade;
face_cascade.load("C:/OpenCV-3.2.0/opencv/sources/data/haarcascades/haarcascade_frontalface_alt2.xml");
String path(path on my PC);
std::vector<cv::String> fn;
glob(path, fn, true);
for (size_t i = 0; i < fn.size(); i++)
{
source = imread(fn[i]);
if (source.empty()) continue;
std::string imgname = fn[i].substr(45, std::string::npos); //File name
std::vector<Rect> faces;
face_cascade.detectMultiScale(source, faces, 1.1, 2, 0 | CV_HAAR_SCALE_IMAGE, Size(30, 30));
for (int i = 0; i < faces.size(); i++)
{
if (faces[i].width > 80 && faces[i].height*0.5 > 80) //Threshold, some detections are false
{
int x = faces[i].x;
int y = faces[i].y;
int h = y + faces[i].height;
int w = x + faces[i].width;
rectangle(source, Point(x, y), Point(w, h), Scalar(255, 0, 0), 2, 8, 0); //Drawing rectangle on detected face
imshow(imgname, source);
Rect roi;
roi.x = x;
roi.y = y;
roi.height = h;
roi.width = w;
Mat detectedface = source(roi);
imshow("cropped image", detectedface);
waitKey(0);
}
}
}
}
和错误:
OpenCV 错误:断言失败(0 <= roi.x && 0 <= roi.width && roi.x + roi.width <= m.cols && 0 <= roi.y && 0 <= roi.height && roi.y + roi.height <= m.rows) 在 cv::Mat::Mat,文件 C:\build\master_winpack-build-win64-vc14\opencv\modules\core\src\matrix.cpp,第 522 行
现在我明白错误出现是因为roi
超出了范围。不过,这就是困扰我的地方。
当我首先尝试绘制矩形时,我不应该收到此错误吗?为什么roi
我在绘制的矩形上出现错误而不是在我绘制的矩形上?
为什么roi
越界了?我显示了上面绘制了矩形的图像,一切看起来都很好。当roi
与绘制的矩形具有相同的值时,为什么会出现此错误?
请原谅我的任何菜鸟错误,我们都从某个地方开始。感谢您的阅读,祝您有美好的一天!
在roi.height
and 中roi.width
,分别尝试给出faces[i].height
和faces[i].width
。实际上,您会认为错误应该出现在之前,但它适用于绘图,因为矩形将两个对角相对的顶点作为参数,而不是宽度/高度,在您的Rect roi
. 你可以Rect
用Point(x, y)
and初始化Point(w,h)
它,它应该可以正常工作。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句