我是 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
当与绘制的矩形具有相同的值时,为什么会出现此错误?
请原谅我的任何新手错误,我们都从某个地方开始。感谢您的阅读,祝您有美好的一天!