使用 OpenCV 和 Python 模糊和匿名化人脸

简介: 使用 OpenCV 和 Python 模糊和匿名化人脸

在本文中,我们将了解如何使用 OpenCV 和 Python 模糊和匿名化人脸。

为此,我们将使用级联分类器来检测人脸。确保从这个链接下载相同的xml文件:

方法

  • 首先,我们使用内置的人脸检测算法,从实时视频或图像中检测人脸。在这里,我们将使用级联分类器方法从实时视频(使用网络摄像头)中检测人脸。
  • 然后,读取来自实时视频的帧。存储最新的帧并转换为灰度,以更好地理解特征。
  • 现在,为了使输出美观,我们将在检测到的人脸周围制作一个彩色边框矩形。但是,我们希望检测到的人脸是模糊的,所以我们使用中值模糊函数来做同样的事情,并提到应该模糊人脸的区域。
  • 而且,现在我们想要显示模糊的脸,使用 imshow 函数读取的帧,我们希望它被显示,直到我们按下一个键。

分步实施:

步骤 1: 导入人脸检测算法,称为级联分类器。

import cv2
# 检测人脸
cascade = cv2.CascadeClassifier("haarcascade_frontalface_default.xml")

步骤 2: 从视频中捕获帧,以便从帧中检测人脸

video_capture = cv2.VideoCapture(0)
while True:
  # 从视频中捕获最新的帧
  check, frame = video_capture.read()

步骤 3: 将捕获的帧更改为灰度。

# 将帧转换为灰度(黑白阴影)
gray_image = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
face = cascade.detectMultiScale(gray_image,
                scaleFactor=2.0,
                minNeighbors=4)

步骤 4: 在检测到的人脸周围绘制一个彩色矩形。

for x, y, w, h in face:
  # 在检测到的人脸周围绘制边框
  # (此处边框颜色为绿色,粗细为3)
  image = cv2.rectangle(frame, (x, y),
            (x+w, y+h),
            (0, 255, 0), 3)

步骤 5: 模糊矩形内的部分(包含检测到的人脸)。

# 模糊矩形中的人脸
image[y:y+h, x:x+w] = cv2.medianBlur(image[y:y+h, x:x+w], 35)

步骤 6: 显示最终输出,即检测到的人脸(矩形内)是模糊的。

# 在视频中显示模糊的脸
cv2.imshow('face blurred', frame)
key = cv2.waitKey(1)

下面是完整的实现:

import cv2
# 检测人脸
cascade = cv2.CascadeClassifier("haarcascade_frontalface_default.xml")
# VideoCapture 是一个函数,用于捕获来自连接到系统的摄像头的视频
# 你可以传递 0 或 1
# 0 用于笔记本电脑网络摄像头
# 1 用于外部网络摄像头
video_capture = cv2.VideoCapture(0)
# 一个while循环运行无限次,为视频捕获无限数量的帧,因为视频是帧的组合
while True:
  # 从视频中捕获最新的帧
  check, frame = video_capture.read()
  # 将帧转换为灰度(黑白阴影)
  gray_image = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
  # 在捕获的帧中检测多个人脸
        # scaleFactor:参数指定在每个图像比例下图像尺寸减小多少。
        # minNeighbors: 参数指定每个矩形应该有多少个邻居来保留它。
        # 矩形包含检测对象。
        # 这里的对象是人脸。
  face = cascade.detectMultiScale(
    gray_image, scaleFactor=2.0, minNeighbors=4)
  for x, y, w, h in face:
    # 在检测到的人脸周围绘制边框。
                #(这里边框颜色为绿色,粗细为3)
    image = cv2.rectangle(frame, (x, y), (x+w, y+h),
              (0, 255, 0), 3)
    # 模糊矩形中的人脸
    image[y:y+h, x:x+w] = cv2.medianBlur(image[y:y+h, x:x+w],
                      35)
  # 在视频中显示模糊的脸
  cv2.imshow('face blurred', frame)
  key = cv2.waitKey(1)
  # 该语句每帧仅运行一次。
        # 基本上,如果我们得到一个密钥,而那个密钥是一个 q
  if key == ord('q'):
    break
# 我们将暂停退出 while 循环,
# 然后运行:
video_capture.release()
cv2.destroyAllWindows()

输出:

22.png

目录
相关文章
|
3月前
|
数据采集 Python
Python实用记录(七):通过retinaface对CASIA-WebFace人脸数据集进行清洗,并把错误图路径放入txt文档
使用RetinaFace模型对CASIA-WebFace人脸数据集进行清洗,并将无法检测到人脸的图片路径记录到txt文档中。
57 1
|
3月前
|
计算机视觉
Opencv学习笔记(八):如何通过cv2读取视频和摄像头来进行人脸检测(jetson nano)
如何使用OpenCV库通过cv2模块读取视频和摄像头进行人脸检测,并提供了相应的代码示例。
151 1
|
5月前
|
计算机视觉 Windows Python
windows下使用python + opencv读取含有中文路径的图片 和 把图片数据保存到含有中文的路径下
在Windows系统中,直接使用`cv2.imread()`和`cv2.imwrite()`处理含中文路径的图像文件时会遇到问题。读取时会返回空数据,保存时则无法正确保存至目标目录。为解决这些问题,可以使用`cv2.imdecode()`结合`np.fromfile()`来读取图像,并使用`cv2.imencode()`结合`tofile()`方法来保存图像至含中文的路径。这种方法有效避免了路径编码问题,确保图像处理流程顺畅进行。
495 1
|
6月前
|
机器学习/深度学习 人工智能 算法
Python在计算机视觉(CV)中扮演重要角色,得益于其丰富的库如OpenCV、Pillow和Scikit-image。
【7月更文挑战第5天】Python在计算机视觉(CV)中扮演重要角色,得益于其丰富的库如OpenCV、Pillow和Scikit-image。CV涉及图像处理、模式识别和机器学习,用于图像理解和生成。Python的跨平台特性和活跃社区使其成为CV的理想工具。基本流程包括图像获取、预处理、特征提取、分类识别及图像生成。例如,面部识别通过预处理图像,使用如`cv2.CascadeClassifier`进行检测;物体检测类似,但需适应不同目标;图像生成则利用GAN创造新图像。
77 4
|
3月前
|
机器学习/深度学习 计算机视觉
目标检测笔记(六):如何结合特定区域进行目标检测(基于OpenCV的人脸检测实例)
本文介绍了如何使用OpenCV进行特定区域的目标检测,包括人脸检测实例,展示了两种实现方法和相应的代码。
102 1
目标检测笔记(六):如何结合特定区域进行目标检测(基于OpenCV的人脸检测实例)
|
3月前
|
计算机视觉 Python
python利用pyqt5和opencv打开电脑摄像头并进行拍照
本项目使用Python的PyQt5和OpenCV库实现了一个简单的摄像头应用。用户可以通过界面按钮打开或关闭摄像头,并实时预览视频流。点击“拍照”按钮可以捕捉当前画面并保存为图片文件。该应用适用于简单的图像采集和处理任务。
204 0
python利用pyqt5和opencv打开电脑摄像头并进行拍照
|
3月前
|
机器学习/深度学习 算法 计算机视觉
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
【Python篇】Python + OpenCV 全面实战:解锁图像处理与视觉智能的核心技能
135 2
|
4月前
|
机器学习/深度学习 计算机视觉 Python
opencv环境搭建-python
本文介绍了如何在Python环境中安装OpenCV库及其相关扩展库,包括numpy和matplotlib,并提供了基础的图像读取和显示代码示例,同时强调了使用Python虚拟环境的重要性和基本操作。
|
5月前
|
算法 计算机视觉 Python
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
该文章详细介绍了使用Python和OpenCV进行相机标定以获取畸变参数,并提供了修正图像畸变的全部代码,包括生成棋盘图、拍摄标定图像、标定过程和畸变矫正等步骤。
python利用opencv进行相机标定获取参数,并根据畸变参数修正图像附有全部代码(流畅无痛版)
|
5月前
|
存储 编解码 API
python多种方法压缩图片,opencv、PIL、tinypng、pngquant压缩图片
python多种方法压缩图片,opencv、PIL、tinypng、pngquant压缩图片
368 1