OpenCV人脸检测 人脸打码

本文介绍了一种使用OpenCV库进行面部检测的方法。通过加载预训练的级联分类器,该程序能够从图片中检测并标记出人脸位置,并对检测到的人脸区域进行模糊处理。文中提供了一个简单的示例程序,演示了如何读取图片、进行灰度转换、直方图均衡化等预处理步骤,然后利用级联分类器进行面部检测。

.xml文件路径为本地绝对路径,应用代码时需要修改。
代码如下:


#include "opencv2/objdetect/objdetect.hpp"
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
#include <iostream>
#include <stdio.h>


using namespace std;
using namespace cv;

void detectAndDisplay( Mat frame );

String face_cascade_name = "C:\\Program Files\\OpenCV2.4.11\\opencv\\sources\\data\\lbpcascades\\lbpcascade_frontalface.xml";
String eyes_cascade_name = "C:\\Program Files\\OpenCV2.4.11\\opencv\sources\\data\\haarcascades\\haarcascade_eye_tree_eyeglasses.xml";
CascadeClassifier face_cascade;
CascadeClassifier eyes_cascade;
string window_name = "detectionresult";

RNG rng(12345);


int main( int argc, const char** argv )
{
	Mat frame;
	face_cascade.load( face_cascade_name );
	if( !face_cascade.load( face_cascade_name ) )
	{ printf("--(!)Error loading\n"); return -1; };
   frame = imread("1.png");
   detectAndDisplay(frame);
   waitKey(0);
	return 0;
}
void detectAndDisplay( Mat frame )
{
	std::vector<Rect> faces;
	Mat frame_gray;
	cvtColor( frame, frame_gray, CV_BGR2GRAY );
	equalizeHist( frame_gray, frame_gray );
	face_cascade.detectMultiScale( frame_gray, faces, 1.1, 2, 0, Size(20, 20) );
	for( int i = 0; i < faces.size(); i++ )
	{
		Mat faceROI = frame_gray( faces[i] );
		Mat faceOrg = frame( faces[i] );
		blur(faceOrg, faceOrg, Size(25,25));  
		std::vector<Rect> eyes;
	}
	imshow( window_name, frame );
}


效果图:
这里写图片描述

### 使用Java和OpenCV实现视频中人脸检测与马赛克效果 为了实现在视频流中对人脸进行检测并应用马赛克效果,可以采用基于Haar特征的级联分类器来定位面部位置,并通过修改像素值的方式创建模糊或马赛克的效果。具体方法如下: #### 准备工作 确保已经安装配置好OpenCV库环境,在项目里引入必要的依赖项。 #### 加载预训练好的Haar级联文件 使用`CascadeClassifier`类加载XML格式的haar特征数据集,这里推荐使用`haarcascade_frontalface_alt_tree.xml`作为脸部识别模型[^2]。 ```java String faceDetectorPath = "path/to/haarcascade_frontalface_alt_tree.xml"; CascadeClassifier faceDetector = new CascadeClassifier(faceDetectorPath); if (faceDetector.empty()) { System.out.println("Error loading cascade classifier"); } ``` #### 获取视频源 可以通过读取本地视频文件或者调用设备摄像头获取实时影像输入。对于后者而言,通常借助于`VideoCapture`对象完成初始化操作。 ```java // 打开默认摄像机 VideoCapture capture = new VideoCapture(0); Mat frame = new Mat(); ``` #### 进行人脸检测及绘制矩形框 遍历每一帧图片,将其转换成灰度模式以提高效率;接着调用detectMultiScale函数查找可能存在的多个人脸区域,返回一系列矩形坐标集合表示各个目标的位置范围。 ```java while(capture.read(frame)){ Mat grayFrame = new Mat(); Imgproc.cvtColor(frame, grayFrame, Imgproc.COLOR_BGR2GRAY); // Detect faces in the image MatOfRect faces = new MatOfRect(); faceDetector.detectMultiScale(grayFrame, faces); List<Rect> faceList = faces.toList(); for(Rect rect : faceList){ // Draw a rectangle around each detected face. Core.rectangle( frame, new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height), new Scalar(0, 255, 0)); applyMosaicEffect(frame.submat(rect)); // 对检测到的脸部区域施加马赛克效应 } HighGui.imshow("Face Detection", frame); char key = (char)HighGui.waitKey(10); if(key == 'q'){ break; } } capture.release(); ``` #### 应用马赛克特效 定义辅助性的applyMosaicEffect() 方法用于处理指定子矩阵内的图像内容,即把原图按照一定比例缩小再放大回原来尺寸从而形成粗糙颗粒状视觉感受。 ```java private static void applyMosaicEffect(Mat subImg){ int mosaicSize = Math.max(subImg.cols()/8,subImg.rows()/8); Size size = new Size(mosaicSize,mosaicSize); Imgproc.resize(subImg, subImg, size); Imgproc.resize(subImg, subImg, subImg.size()); } ``` 上述过程实现了基本的功能需求——从捕获视频流开始直到最终显示带有遮挡效果的画面输出为止。值得注意的是实际开发过程中还需要考虑更多细节优化比如性能调整、异常情况捕捉等方面的工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值