首页 > 编程学习 > 《OpenCV:行人检测简单示例》

《OpenCV:行人检测简单示例》

发布时间:2022/5/14 15:51:44

行人检测(图片)

//本代码只能在Release模式下运行
#include <opencv2/opencv.hpp>
#include <iostream>

using namespace std;
using namespace cv;

int main()
{
	Mat image=imread("1.jpg");
	if (image.empty())
	{
		cout << "--------- 加载图像失败 ----------";
		return -1;
	}
	vector<Rect> found;
	
	HOGDescriptor defaultHog;
	//设置线性SVM分类器系数
	defaultHog.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());
	//多尺度检测目标
	defaultHog.detectMultiScale(image,found,0,Size(8,8), Size(32,32),1.1,2.0,false);
	// 画出长方形,框出人
	for (int i = 0; i < found.size(); i++) 
	{
		Rect r=found[i];
		rectangle(image, r.tl(), r.br(), Scalar(0,255,0), 1,CV_AA);
	}
	cout << "people size:" << found.size() <<endl;
	namedWindow("Detect pedestrain", WINDOW_AUTOSIZE);
	imshow("Detect pedestrain", image);
	waitKey(0);
		
	return 0;
}

Release模式运行效果图 

Debug模式运行效果图 

Copyright © 2010-2022 ngui.cc 版权所有 |关于我们| 联系方式| 豫B2-20100000