译者 | 布加迪
审校 | 重楼
出于几个原因,您可能使用人脸模糊来隐藏视频或图像中的人脸。隐私和安全问题是最主要的原因。大多数视频分享平台和视频编辑软件都内置了人脸模糊功能。
您可以使用Python、OpenCV和NumPy库从头创建自己的人脸模糊程序。
1、建立环境
要完成本文的学习,您需要熟悉Python的基础知识,并对NumPy库的使用有一番基本的了解。
打开任何您熟悉的Python IDE。创建一个虚拟环境,用来安装所需的库。创建一个新的Python文件。进入到终端,运行以下命令来安装所需的库。将库作为以空格分隔的列表来传递。
pip install OpenCV-python NumPy
您将使用OpenCV获取并预处理视频输入,使用NumPy处理数组。
一旦您安装了库,等待IDE更新项目骨干部分。更新完成、环境准备就绪后,您就可以开始编码了。
注意:完整的源代码可以在GitHub代码库中找到(https://github.com/makeuseofcode/Face-Blurring)。
2、导入所需的库
首先,导入OpenCV库和NumPy库。这将使您能够调用和使用它们支持的任何函数。导入OpenCV-python作为cv2。
import cv2 import numpy as np
OpenCV-python模块使用名称cv2作为OpenCV社区建立的约定。OpenCV- Python是OpenCV库的Python包装器,用C++编写。
3、获取输入
创建一个变量,并初始化VideoCapture对象。如果您想使用计算机的主摄像头作为输入源,应传递0作为参数。要使用连接到计算机上的外部摄像头,请传递1。要对预先录制的视频执行人脸模糊处理,请改而传递视频的路径。若要使用远程摄像头,传递摄像头的URL,其中含有IP地址和端口号。
cap = cv2.VideoCapture(0)
要对输入执行人脸模糊,您需要这三个函数:
- 对输入进行预处理的函数。
- 将模糊输入中的人脸的函数。
- 将控制程序流程并显示输出的main函数。
4、视频输入预处理
创建一个输入预处理函数,将输入视频的每一帧作为其输入。初始化CascadeClassifier类,您将用这个类检测人脸。将帧大小调整为640 * 640像素。将调整大小的帧转换成灰度以便处理,最后检测输入中的人脸,并将其与矩形绑定。
def image_preprocess(frame): face_detector = cv2.CascadeClassifier(cv2.data.haarcascades + 'haarcascade_frontalface_default.xml') resized_image = cv2.resize(frame, (640, 640)) gray_image = cv2.cvtColor(resized_image, cv2.COLOR_BGR2GRAY) face_rects = face_detector.detectMultiScale( gray_image, 1.04, 5, minSize=(20, 20)) return resized_image, face_rects
该函数返回一个元组,含有调整大小的图像和表示检测到的人脸的矩形列表。
5、模糊人脸
创建一个模糊函数,将模糊输入中的人脸。该函数将调整大小的帧和预处理函数返回的包围人脸的矩形列表作为输入。循环处理人脸矩形。计算每个矩形的中心和模糊圆的半径。通过将所有像素初始化为0,创建一个与调整大小的帧具有相同尺寸的黑色图像。使用计算出的半径,在中心位于人脸矩形的黑色图像上绘制白圆。最后,它模糊白圆上的图像。
def face_blur(resized_frame, face_rects): for (x, y, w, h) in face_rects: # Specifying the center and radius # of the blurring circle center_x = x + w // 3 center_y = y + h // 3 radius = h // 1 # creating a black image having similar # dimensions as the frame mask = np.zeros((resized_frame.shape[:3]), np.uint8) # draw a white circle in the face region of the frame cv2.circle(mask, (center_x, center_y), radius, (255, 255, 255), -1) # blurring the whole frame blurred_image = cv2.medianBlur(resized_frame, 99) # reconstructing the frame: # - the pixels from the blurred frame if mask > 0 # - otherwise, take the pixels from the original frame resized_frame = np.where(mask > 0, blurred_image, resized_frame) return resized_frame
该函数使用NumPy where()函数在模糊过程中重建帧。
6、控制程序流程
创建一个主函数,充当程序的入口点。然后它将控制程序流程。该函数将开始一个无限循环,不断捕获视频输入的帧。调用cap对象的读取方法,从摄像头读取帧。
然后,该函数将帧传递给预处理函数,并将返回值传递给另一个函数face_blur,以获得模糊后的图像。然后,它调整模糊函数返回的帧的大小,并显示输出。
def main(): while True: success, frame = cap.read() resized_input, face_rects = image_preprocess(frame) blurred_image = face_blur(resized_input, face_rects) # Diplaying the blurred image cv2.imshow("Blurred image", cv2.resize(blurred_image, (500, 500))) if cv2.waitKey(1) == ord("q"): break
该函数还在用户按下q键时终止输出显示。
7、运行程序
确保在运行脚本时先运行main函数。如果将脚本作为另一个程序中的模块导入,该条件将为假。
if __name__ == "__main__": main()
这允许您将脚本作为模块来使用或作为独立程序来运行。当程序运行时,您应该看到类似这样的输出:
人脸已经过模糊处理,辨认不出来。
8、人脸模糊的实际应用
您可以在许多类型的应用环境中运用人脸模糊来保护隐私。街景和地图服务使用模糊技术来模糊图像中人物的脸部。执法部门使用人脸模糊技术来保护证人的身份。
许多视频分享平台也为用户整合了人脸模糊功能。比较人脸模糊在这些领域的使用可以帮助您观察其他平台如何整合这项技术。
原文链接:https://www.makeuseof.com/python-blur-human-faces-real-time/
以上是如何使用Python实时模糊人脸的详细内容。更多信息请关注PHP中文网其他相关文章!

拥抱Face的OlympicCoder-7B:强大的开源代码推理模型 开发以代码为中心的语言模型的竞赛正在加剧,拥抱面孔与强大的竞争者一起参加了比赛:OlympicCoder-7B,一种产品

你们当中有多少人希望AI可以做更多的事情,而不仅仅是回答问题?我知道我有,最近,我对它的变化感到惊讶。 AI聊天机器人不仅要聊天,还关心创建,研究

随着智能AI开始融入企业软件平台和应用程序的各个层面(我们必须强调的是,既有强大的核心工具,也有一些不太可靠的模拟工具),我们需要一套新的基础设施能力来管理这些智能体。 总部位于德国柏林的流程编排公司Camunda认为,它可以帮助智能AI发挥其应有的作用,并与新的数字工作场所中的准确业务目标和规则保持一致。该公司目前提供智能编排功能,旨在帮助组织建模、部署和管理AI智能体。 从实际的软件工程角度来看,这意味着什么? 确定性与非确定性流程的融合 该公司表示,关键在于允许用户(通常是数据科学家、软件

参加Google Cloud Next '25,我渴望看到Google如何区分其AI产品。 有关代理空间(此处讨论)和客户体验套件(此处讨论)的最新公告很有希望,强调了商业价值

为您的检索增强发电(RAG)系统选择最佳的多语言嵌入模型 在当今的相互联系的世界中,建立有效的多语言AI系统至关重要。 强大的多语言嵌入模型对于RE至关重要

特斯拉的Austin Robotaxi发射:仔细观察Musk的主张 埃隆·马斯克(Elon Musk)最近宣布,特斯拉即将在德克萨斯州奥斯汀推出的Robotaxi发射,最初出于安全原因部署了一支小型10-20辆汽车,并有快速扩张的计划。 h

人工智能的应用方式可能出乎意料。最初,我们很多人可能认为它主要用于代劳创意和技术任务,例如编写代码和创作内容。 然而,哈佛商业评论最近报道的一项调查表明情况并非如此。大多数用户寻求人工智能的并非是代劳工作,而是支持、组织,甚至是友谊! 报告称,人工智能应用案例的首位是治疗和陪伴。这表明其全天候可用性以及提供匿名、诚实建议和反馈的能力非常有价值。 另一方面,营销任务(例如撰写博客、创建社交媒体帖子或广告文案)在流行用途列表中的排名要低得多。 这是为什么呢?让我们看看研究结果及其对我们人类如何继续将


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),