【树莓派】yolov5 Lite,目标检测,行人检测入侵报警

news2024/11/18 21:34:10

延续之前的程序:
https://qq742971636.blog.csdn.net/article/details/138172400

文章目录

  • 播放声音
    • pygame
    • 不出声音怎么办(调节音量)
    • 树莓派上的音乐播放器(可选)
    • 命令行直接放歌(尝试放mp3歌曲)
  • 摄像头检测与绑定
    • 如何绑定usb摄像头(我没有绑定成功)
  • 行人入侵后放歌
  • 问询、帮助

播放声音

pygame

可以使用Python的pygame库来在树莓派上播放MP3音频文件。首先,你需要确保你的树莓派上已经安装了pygame库。你可以使用以下命令在树莓派上安装pygame:

sudo apt-get update
sudo apt-get install python3-pygame

python3 -m pip install pygame

安装完成后,你可以使用以下Python代码在树莓派上播放MP3文件:

import pygame

def play_mp3(file_path):
    pygame.mixer.init()
    pygame.mixer.music.load(file_path)
    pygame.mixer.music.play()

if __name__ == "__main__":
    mp3_file = "tts.mp3"  # 替换为你的MP3文件路径
    play_mp3(mp3_file)

这个简单的程序将初始化pygame的音频模块,加载指定的MP3文件,并开始播放。请确保将example.mp3替换为你实际的MP3文件路径。

需要注意的是,这段代码在执行pygame.mixer.init()时会占用音频设备,可能会导致其他音频应用无法使用。

这软件可以播放出音乐:

在这里插入图片描述

不出声音怎么办(调节音量)

我的pygame无法播放,我查了一些播放软件:

alsa-utilsalsa-utils是一个包含了一系列音频工具的软件包,你可以使用其中的工具来管理和调试音频设备。你可以通过以下命令安装:

sudo apt-get install alsa-utils

安装完成后,你可以使用alsamixer命令来打开一个交互式的音频控制界面,可以在这里调整音量和其他设置。

在这里插入图片描述

树莓派上的音乐播放器(可选)

在树莓派上安装播放音乐的软件通常很简单。你可以使用现有的软件包管理器(如apt)来安装各种音乐播放器。以下是几个常用的音乐播放器及其安装方法:

  1. VLC 媒体播放器

    VLC是一个功能强大的跨平台媒体播放器,它支持播放各种音频和视频格式。

    sudo apt-get update
    sudo apt-get install vlc
    

    安装完成后,你可以在图形界面中打开VLC并播放音乐。

  2. MPD(Music Player Daemon)

    MPD是一个轻量级的音乐播放器,它以守护进程的方式运行,可以通过各种客户端控制。

    sudo apt-get update
    sudo apt-get install mpd mpc
    

    安装完成后,你可以通过命令行或MPD的客户端来控制音乐播放。

  3. Mopidy

    Mopidy是一个使用Python编写的音乐播放器,支持各种音乐源和插件。

    sudo apt-get update
    sudo apt-get install mopidy
    

    安装完成后,你可以配置Mopidy以连接到各种音乐源,并使用其扩展功能。

  4. Rhythmbox

    Rhythmbox是一个简单易用的音乐播放器,集成于GNOME桌面环境中。

    sudo apt-get update
    sudo apt-get install rhythmbox
    

    安装完成后,你可以在图形界面中打开Rhythmbox并播放音乐。

这些是一些常见的音乐播放器,在树莓派上安装这些软件非常简单。根据你的偏好和需求选择合适的播放器进行安装即可。

命令行直接放歌(尝试放mp3歌曲)

这个装上:

sudo apt-get update
sudo apt-get install alsa-utils

sudo apt-get update
sudo apt-get install mpg321

命令行放歌:

mpg321 -o alsa tts.mp3

在这里插入图片描述

成功播放!

摄像头检测与绑定

如何绑定usb摄像头(我没有绑定成功)

每次摄像头接入后可能会变,如何绑定usb摄像头?

安装这个:

apt install v4l-utils

查看树莓派的设备:

v4l2-ctl --list-devices

找到摄像头信息:udevadm info /dev/video5

在这里插入图片描述
创建 udev 规则: 使用你喜欢的文本编辑器创建一个新的 udev 规则文件。例如:

vim /etc/udev/rules.d/10-webcam.rules

在文件中添加一条规则,用于匹配你的摄像头,并指定固定的设备名称,比如写入:

SUBSYSTEM=="video4linux", ENV{ID_PATH}=="platform-fd500000.pcie-pci-0000:01:00.0-usb-0:1.3:1.0", SYMLINK+="camera1_name"

重新加载 udev 规则: 保存文件后,重新加载 udev 规则以使更改生效:

sudo udevadm control --reload-rules  # 这步骤好像没用 我重启了

重新插入摄像头: 现在,重新插入你的摄像头,它应该被分配到指定的设备名称 /dev/camera1_name。

行人入侵后放歌

之前的代码加上这个代码即可:

import cv2
import os
import time
from datetime import datetime
from v5lite_e_onnx_end2end import yolov5_lite
import threading


def play_audio_thread(file_path):
    """在新线程中播放音频文件"""
    os.system(f'mpg321 -o alsa {file_path}')  # 使用os.system调用命令行播放音频


def play_audio(file_path):
    """播放音频文件"""
    threading.Thread(target=play_audio_thread, args=(file_path,)).start()


def take_screenshot(frame, folder='images'):
    """保存截图"""
    os.makedirs(folder, exist_ok=True)  # 创建文件夹
    now = datetime.now().strftime('%Y%m%d_%H%M%S')  # 当前日期时间作为文件名
    img_name = f'{folder}/{now}.jpg'
    cv2.imwrite(img_name, frame)
    print(f'Screenshot saved as {img_name}')


def main():
    cap = cv2.VideoCapture(0)
    modelpath = 'v5lite-e_end2end.onnx'
    classfile = 'coco.names'
    net = yolov5_lite(modelpath, classfile)

    last_alert_time = 0  # 上次报警的时间

    while True:
        ret, frame = cap.read()
        if not ret:
            break

        detected_img, haveobj = net.detect(frame)

        cv2.imshow('Intrusion Alert', detected_img)

        current_time = time.time()
        if haveobj and current_time - last_alert_time > 5:  # 如果检测到人且距离上次报警超过5秒
            play_audio('tts.mp3')  # 播放音频
            last_alert_time = current_time  # 更新报警时间
            # 确保音频播放结束通常需要音频播放器的支持,这里简化处理直接截图
            take_screenshot(detected_img)

        if cv2.waitKey(1) & 0xFF == ord('q'):
            break

    cap.release()
    cv2.destroyAllWindows()


if __name__ == '__main__':
    main()

问询、帮助

https://docs.qq.com/sheet/DUEdqZ2lmbmR6UVdU?tab=BB08J2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1624825.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

分类算法——模型评估(八)

1混淆矩阵 在分类任务下,预测结果与正确标记之间存在四种不同的组合,构成混淆矩阵(适用于多分类) TP True Possitive FN False Negative 2精确率(Precision)与召回率(Recall) 精…

第11章 Android特色开发——基于位置的服务

第11章 Android特色开发——基于位置的服务 本章中,将要学习一些全新的Android技术,这些技术有别于传统的PC或Web领域的应用技术,是只有在移动设备上才能实现的。 基于位置的服务(Location Based Service)。由于移动…

智能穿戴终端设备安卓主板方案_MTK平台智能手表PCBA定制开发

新移科技智能手表方案兼容WiFi、BLE、2~5G等多种通信能力。支持多个功能模块,包括:通话、计步、定位、睡眠监测、心率监测、血氧监测等。智能手表通过滑动与功能性按键提供高度直观的体验感受,从腕间即可掌控日常生活。形态支持定制包括&…

数据结构篇其二---单链表(C语言+超万字解析)

目录 前言: 一、顺序表的缺点和链表的引入。 二、链表概述 实现一个简单的链表 空链表的概念 三、链表的功能实现 链表的打印 链表节点的创建 链表的头插(自上而下看完分析,相信你会有所收获) 头插的前置分析 传值调用和…

【韩国】UE5的MetaHuman确实可以导入Blender进行编辑。

UE5的MetaHuman确实可以导入Blender进行编辑。根据网络上的信息,你可以将MetaHuman模型导出为FBX文件,然后在Blender中进行修改。修改完成后,你可以将其重新导入到Unreal Engine 5中4。请注意,当你在Blender中编辑模型时&#xff…

debian配置四叶草输入法

效果展示 一、前言 在linux下体验比较好的输入法只有两款:搜狗输入法、四叶草输入法。 ubuntu下可以成功配置搜狗输入法,但debian下从来没有成功过。 今天在用fcitx5 四叶草时发现VNC远程输入法会失灵,于是改用了ibus 四叶草&#xff0c…

Java | 冒泡排序算法实现

大家可以关注一下专栏,方便大家需要的时候直接查找,专栏将持续更新~ 题目描述 编写一个Java程序,实现冒泡排序算法。程序需要能够接收一个整型数组作为输入,并输出排序后的数组。 冒泡排序是一种简单的排序算法,它…

详解23种设计模式——工厂模式

工厂模式 | CoderMast编程桅杆工厂模式 设计思想 工厂模式是最常用的设计模式之一,属于创建型模式,将创建对象的权利交给了一个工厂类,从而提供了一种不使用构造方法的情况下创建对象的途径,无需指定要创建的具体类,将…

【可下载】CDA 1级教材《精益业务数据分析》2023最新版

CDA一级认证教材:《精益业务数据分析》 全面、系统地讲述业务描述性分析为企业决策行为创造价值的全流程技能,涵盖描述性数据分析方法、业务分析方法、数据分析结果应用方法等内容。 条理清晰的结构、通俗易懂的语言、完整立体的知识框架为读者铺开一幅…

word添加行号

打开页面设置,找到行号

制造型企业 如何实现便捷的机台文件统一管理?

机台文件统一管理,这是生产制造型企业都需要去做的,机台文件需要统一管理的原因主要包括以下几点: 1、提高效率:统一管理可以简化文件的访问和使用过程,提高工作效率,尤其是在需要频繁访问或更新机台文件的…

数据库MySQL的初级基础操作

文章目录 1. 介绍2. 数据库相关概念3. 启动4. 数据模型5. SQL6. DDL数据库DDL-表操作DDL-表操作-数据类型DDL-表操作-修改DDL-表操作-删除 7. 图形化界面工具DataGrip8. DML(数据操作语言)DML-添加数据DML-修改数据 9. DQL(数据查询语言)基本查询条件查询…

如何把经验变成可以销售的“知识产品”?

知识付费,很多人想做,但是不知道如何把自己在某方面的“经验”,变成一个“知识产品”,那么这篇文章,我们就来聊聊如何从0打造一个知识产品 非常简单,一共六个步骤: 第一步:取名字&…

【安卓13-Framework】SystemUI定制之屏蔽下拉状态栏部分快捷按钮

1、需求 屏蔽下拉状态栏谷歌录屏、省电模式、二维码扫描器等快捷按钮。 2、修改路径 普及:安卓的SystemUI包提供了状态栏、导航栏、通知中心等重要的用户界面元素。 状态栏小部件UI显示修改路径:frameworks/base/packages/SystemUI/src/com/android/s…

政安晨:【Keras机器学习示例演绎】(十七)—— 用于图像分类的 RandAugment 可提高鲁棒性

目录 导入与设置 加载 CIFAR10 数据集 定义超参数 初始化 RandAugment 对象 创建 TensorFlow 数据集对象 可视化使用 RandAugment 增强的数据集 可视化使用 simple_aug 增强的数据集 定义模型构建实用功能 使用 RandAugment 训练模型 用 simple_aug 训练模型 加载 C…

Rime 如何通过 iCloud 实现词库多端同步,Windows、iOS、macOS

Rime 如何通过 iCloud 实现词库多端同步,Windows、iOS、macOS 一、设备环境 最理想的输入环境就是在多端都使用同一个词库,这样能保持多端的输入习惯是一致的。 以我为例,手头每天都要用到的操作平台和对应的输入法: 操作系统设…

Spring Boot | Spring Boot “自定义“ Redis缓存 “序列化机制“

目录: Spring Boot "自定义" Redis缓存 "序列化机制" :一、基于 "注解" 的 "Redis缓存管理" 的 "默认序列化机制" 和 "自定义序列化机制"1.1 基于 "注解" 的 "Redis缓存管理" 的 …

抽象代理模式2.0版本

前言: 1.0版本的核心 代理的定义 A proxy, in its most general form, is a class functioning as an interface to something else. The proxy could interface to anything: a network connection, a large object in memory, a file, or some other resource t…

金融级国产化替代中间件有哪些?

过去,国内中间件市场一直由IBM、Oracle等国际大型企业所主导,这在一定程度上限制了对国内企业多样化和个性化需求的满足,尤其是在实现底层硬件与上层应用软件之间高效、精准匹配方面。面对日益复杂的国际局势,金融安全已成为国家整…

akSmart大带宽服务器基础配置科普

在数字化时代,服务器的性能和网络带宽成为业务发展的关键因素。RakSmart作为知名的服务器提供商,其大带宽服务器备受用户青睐。那么,RakSmart大带宽服务器的基础配置究竟有哪些呢?本文将为您揭开这一神秘面纱。 首先,我们来看看R…