使用Python和OpenCV构建具有人体检测功能的摄像头录制器

简介: 使用Python和OpenCV构建具有人体检测功能的摄像头录制器

介绍


在本教程中,我们将探讨如何使用Python和OpenCV构建一个具有人体检测功能的摄像头录制应用程序。该应用程序允许我们从计算机的摄像头录制视频,并自动检测和提取人体存在的部分。借助YOLO目标检测算法的强大功能,我们可以轻松识别和隔离人体动作。让我们逐步深入,看看如何创建这个应用程序。


前提条件


在开始之前,请确保系统上安装了以下依赖:

  • Python 3.x
  • OpenCV库
  • 预训练的YOLO模型(yolov3.cfg和yolov3.weights)
  • VLC媒体播放器(或任何其他兼容的媒体播放器)
  • ffmpeg(命令行工具)用于视频提取


强大的技术:Python、OpenCV、YOLO和FFmpeg


项目配置


  1. 从GitHub上克隆项目存储库。
  2. 您可以在这里找到存储库。
  3. 在存储库中,您将找到一个详细的README文件,其中提供了有关设置项目的逐步说明。它包括有关先决条件、安装步骤和其他资源的信息。
  4. 按照README文件中的说明安装所需的Python包,下载预训练的YOLO模型,并在系统上设置VLC媒体播放器和ffmpeg。
  5. README文件还提供了如何配置项目的指南,包括YOLO模型文件的放置和应用程序的使用。

项目代码文件:用于摄像头录制和人体检测的Python脚本代码链接:https://github.com/g4lb/camera-recorder-with-human-detection


从摄像头录制视频

  1. 在您喜欢的代码编辑器中打开camera_recorder.py文件。
  2. 在文件内,您将找到使用OpenCV捕获摄像头视频所需的代码。这包括初始化视频捕获、设置所需的视频分辨率和配置视频编解码器。
  3. 您可以根据需要修改配置参数。例如,您可以通过更改frame_width和frame_height变量的值来调整分辨率。此外,您可以通过修改fourcc变量来尝试不同的视频编解码器。
  4. 运行camera_recorder.py脚本以开始从摄像头录制视频。您将看到来自摄像头的实时视频源,并且将创建一个新的视频文件并保存在"records"文件夹中。


通过参考项目存储库中的camera_recorder.py文件,您将找到所有必要的配置详细信息和录制视频的代码实现,使用Python和OpenCV从摄像头录制视频。


提取人体运动


在视频中检测到人体后,我们将提取存在人体的部分。所有的配置详细信息和代码实现都可以在项目存储库的human_detection.py文件中找到。


  1. 在您喜欢的代码编辑器中打开human_detection.py文件。
  2. 在文件内,您将找到使用YOLO进行人体检测并提取表示人体运动的帧所需的代码。这包括初始化YOLO模型、设置置信度阈值(conf_threshold)和定义后处理步骤。
  3. 您可以根据需要修改配置参数。例如,您可以通过更改conf_threshold变量的值来调整置信度阈值。较高的值将导致更严格的检测,而较低的值可能包括更多的假阳性。

通过参考项目存储库中的human_detection.py文件,您将找到所有必要的配置详细信息和代码实现,使用YOLO和OpenCV从录制的视频中提取人体运动。

演示:人体检测在实际操作中 — 出现并消失两次


将检测到的人体部分保存为视频


一旦我们有了表示人体运动的帧,我们将它们保存为单独的视频文件。所有的配置详细信息和代码实现都可以在项目存储库的human_detection.py文件中找到。


  1. 在您喜欢的代码编辑器中打开human_detection.py文件。
  2. 在文件内,您将找到将表示人体运动的帧保存为单独的视频文件所需的代码。这包括配置输出文件名、格式和文件路径。
  3. 您可以根据需要修改配置参数。例如,您可以更改输出文件格式、调整文件命名约定或指定不同的输出目录。
  4. 运行human_detection.py脚本以开始人体检测过程。脚本将分析"records"文件夹中的录制视频文件,检测人体运动并标识表示人体存在的帧。
  5. 视频的检测部分将以"video_timestamp_human.mp4"(例如,"video_2023–07–06_11–52–34_human.mp4")的格式保存为单独的MP4文件。

通过参考项目存储库中的human_detection.py文件,您将找到所有必要的配置详细信息和代码实现,使用OpenCV和ffmpeg将表示人体运动的帧保存为单独的视频文件。录制的视频和检测到的人体部分:records与output文件夹


挑战:subprocess.run与subprocess.call


在项目的实施过程中,使用子进程模块执行ffmpeg命令时,您可能会遇到一个挑战。子进程模块中有两个常用的函数:subprocess.run和subprocess.call。这两个函数都可以用于运行外部命令,但它们在行为和返回值方面存在一些差异。


subprocess.run函数在Python 3.5中引入,与subprocess.call相比,提供了更强大和灵活的接口。它允许捕获命令的输出,处理错误,设置超时等。另一方面,subprocess.call是一个更简单的函数,运行命令并等待其完成,不捕获输出或处理错误。


在使用ffmpeg从检测到的帧创建视频时,您可能需要在subprocess.run和subprocess.call之间做出选择。如果需要捕获输出或在视频创建过程中处理潜在的错误,subprocess.run是推荐的选择。但是,如果只需要执行命令并等待其完成而不捕获输出,subprocess.call可以是一个更简单的选择。

ffmpeg命令:从帧创建检测到的人体视频剪辑

根据您的具体需求使用适当的函数。请确保处理在执行ffmpeg命令时可能发生的错误或异常。比较:subprocess.run与subprocess.call

结论
在本教程中,我们使Python和OpenCV构建了一个具有人体检测功能的摄像头录制应用程序。我们学会了如何从摄像头录制视频,使用YOLO检测人体,并提取具有人体运动的部分。借助OpenCV和YOLO的强大功能,我们可以自动化检测和隔离人体运动的过程,为各种应用开辟了可能性,如监视、活动监测等。

相关文章
|
2月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
342 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
9月前
|
运维 监控 算法
时间序列异常检测:MSET-SPRT组合方法的原理和Python代码实现
MSET-SPRT是一种结合多元状态估计技术(MSET)与序贯概率比检验(SPRT)的混合框架,专为高维度、强关联数据流的异常检测设计。MSET通过历史数据建模估计系统预期状态,SPRT基于统计推断判定偏差显著性,二者协同实现精准高效的异常识别。本文以Python为例,展示其在模拟数据中的应用,证明其在工业监控、设备健康管理及网络安全等领域的可靠性与有效性。
1047 13
时间序列异常检测:MSET-SPRT组合方法的原理和Python代码实现
|
5月前
|
监控 编译器 Python
如何利用Python杀进程并保持驻留后台检测
本教程介绍如何使用Python编写进程监控与杀进程脚本,结合psutil库实现后台驻留、定时检测并强制终止指定进程。内容涵盖基础杀进程、多进程处理、自动退出机制、管理员权限启动及图形界面设计,并提供将脚本打包为exe的方法,适用于需持续清理顽固进程的场景。
|
9月前
|
人工智能 编解码 算法
如何在Python下实现摄像头|屏幕|AI视觉算法数据的RTMP直播推送
本文详细讲解了在Python环境下使用大牛直播SDK实现RTMP推流的过程。从技术背景到代码实现,涵盖Python生态优势、AI视觉算法应用、RTMP稳定性及跨平台支持等内容。通过丰富功能如音频编码、视频编码、实时预览等,结合实际代码示例,为开发者提供完整指南。同时探讨C接口转换Python时的注意事项,包括数据类型映射、内存管理、回调函数等关键点。最终总结Python在RTMP推流与AI视觉算法结合中的重要性与前景,为行业应用带来便利与革新。
540 5
|
11月前
|
监控 网络安全 开发者
Python中的Paramiko与FTP文件夹及文件检测技巧
通过使用 Paramiko 和 FTP 库,开发者可以方便地检测远程服务器上的文件和文件夹是否存在。Paramiko 提供了通过 SSH 协议进行远程文件管理的能力,而 `ftplib` 则提供了通过 FTP 协议进行文件传输和管理的功能。通过理解和应用这些工具,您可以更加高效地管理和监控远程服务器上的文件系统。
412 20
|
10月前
|
监控 Java 计算机视觉
Python图像处理中的内存泄漏问题:原因、检测与解决方案
在Python图像处理中,内存泄漏是常见问题,尤其在处理大图像时。本文探讨了内存泄漏的原因(如大图像数据、循环引用、外部库使用等),并介绍了检测工具(如memory_profiler、objgraph、tracemalloc)和解决方法(如显式释放资源、避免循环引用、选择良好内存管理的库)。通过具体代码示例,帮助开发者有效应对内存泄漏挑战。
506 1
|
11月前
|
XML 机器学习/深度学习 人工智能
使用 OpenCV 和 Python 轻松实现人脸检测
本文介绍如何使用OpenCV和Python实现人脸检测。首先,确保安装了OpenCV库并加载预训练的Haar特征模型。接着,通过读取图像或视频帧,将其转换为灰度图并使用`detectMultiScale`方法进行人脸检测。检测到的人脸用矩形框标出并显示。优化方法包括调整参数、多尺度检测及使用更先进模型。人脸检测是计算机视觉的基础技术,具有广泛应用前景。
532 10
|
机器学习/深度学习 PyTorch TensorFlow
使用Python实现智能食品质量检测的深度学习模型
使用Python实现智能食品质量检测的深度学习模型
578 1
|
缓存 监控 计算机视觉
视频监控笔记(三):opencv结合ffmpeg获取rtsp摄像头相关信息
本文介绍了如何使用OpenCV结合FFmpeg获取RTSP摄像头信息,包括网络架构、视频监控系统组成、以及如何读取和显示网络摄像头视频流。
528 1
|
计算机视觉 Python
python利用pyqt5和opencv打开电脑摄像头并进行拍照
本项目使用Python的PyQt5和OpenCV库实现了一个简单的摄像头应用。用户可以通过界面按钮打开或关闭摄像头,并实时预览视频流。点击“拍照”按钮可以捕捉当前画面并保存为图片文件。该应用适用于简单的图像采集和处理任务。
829 0
python利用pyqt5和opencv打开电脑摄像头并进行拍照

推荐镜像

更多