树莓派+摄像头实现对移动物体的检测

作者:Wang哈哈 时间:2022-05-28 19:57:26 

在上一篇文章中实现了树莓派下对摄像头的调用,有兴趣的可以看一下:python+opencv实现摄像头调用的方法

接下来,我们将使用python+opencv实现对移动物体的检测

一、环境变量的配置

我们可以参照上一篇文章对我们的树莓派进行环境的配置

当我们将cv2的库安装之后,就可以实现对摄像头的操作

二、摄像头的连接

在此实验中,我使用的为usb摄像头

当我们连接摄像头之后,终端输入


ls /dev/video*

如果终端提示如下:

树莓派+摄像头实现对移动物体的检测

则表示摄像头连接成功

三、编码实现对移动物体的检测

使用python编写程序,实现对移动物体的检测,代码如下


#encoding=utf-8
import RPi.GPIO as GPIO
import cv2
import time
import os

GPIO.setmode(GPIO.BCM)
GPIO.setup(18,GPIO.OUT)

camera = cv2.VideoCapture(0)
if camera is None:
print('please connect the camera')
exit()

fps = 30
pre_frame = None

led = False

while True:
start = time.time()
res, cur_frame = camera.read()
if res != True:
break
end = time.time()
seconds = end - start
if seconds < 1.0/fps:
time.sleep(1.0/fps - seconds)

cv2.namedWindow('img',0);
#cv2.imshow('img', cur_frame)
key = cv2.waitKey(30) & 0xff
if key == 27:
break

gray_img = cv2.cvtColor(cur_frame, cv2.COLOR_BGR2GRAY)
gray_img = cv2.resize(gray_img, (500, 500))
gray_img = cv2.GaussianBlur(gray_img, (21, 21), 0)

if pre_frame is None:
pre_frame = gray_img
else:
img_delta = cv2.absdiff(pre_frame, gray_img)
thresh = cv2.threshold(img_delta, 25, 255, cv2.THRESH_BINARY)[1]
thresh = cv2.dilate(thresh, None, iterations=2)

contours, hierarchy = cv2.findContours(thresh.copy(),cv2.RETR_LIST,cv2.CHAIN_APPROX_SIMPLE)
for c in contours:
 if cv2.contourArea(c) < 1000:
 continue
 else:
(x,y,w,h) = cv2.boundingRect(c)
cv2.rectangle(cur_frame,(x,y),(x+w,y+h),(0,255,0),2)

print("something is moving!!!")
led = True
if led == True:
for i in range(30):
GPIO.output(18,GPIO.HIGH)
time.sleep(0.03)
GPIO.output(18,GPIO.LOW)
time.sleep(0.03)
 break

cv2.imshow('img', cur_frame)
pre_frame = gray_img

camera.release()
cv2.destroyAllWindows()

我的树莓派终端不能显示中文,因此会出现乱码

Ubuntu下的运行结果如下

树莓派+摄像头实现对移动物体的检测

树莓派下执行结果如下:

树莓派+摄像头实现对移动物体的检测

此外,在检测物体移动的同时,添加了led闪烁以及框选移动部分的功能,led安装方法请移步之前的博客

文章参考链接:OpenCV检测场景内是否有移动物体

来源:https://blog.csdn.net/Wangguang_/article/details/89875170

标签:树莓派,摄像头
0
投稿

猜你喜欢

  • MYSQL事件查看器使用介绍

    2024-01-15 07:33:04
  • python使用matplotlib绘制图片时x轴的刻度处理

    2022-05-05 01:38:56
  • python中如何使用正则表达式的非贪婪模式示例

    2022-08-28 08:43:49
  • Python实现画图软件功能方法详解

    2023-08-29 06:35:49
  • Python中装饰器的基本功能理解

    2021-05-26 05:17:56
  • 详细讲解HTTP协议工作方式

    2022-01-08 11:55:59
  • 解决MySQL8.0安装第一次登陆修改密码时出现的问题

    2024-01-21 16:19:49
  • JS中的THIS和WINDOW.EVENT.SRCELEMENT详解

    2023-07-20 20:48:51
  • Python开发时报TypeError: ‘int‘ object is not iterable错误的解决方式

    2023-08-23 20:30:05
  • 关于Python下的Matlab函数对应关系(Numpy)

    2023-03-15 07:25:32
  • 判断Session的过期时间 采用JavaScript实时显示剩余多少秒

    2011-04-04 10:48:00
  • Python实现操作Redis所有类型的方法详解

    2022-05-11 13:48:35
  • python已协程方式处理任务实现过程

    2022-05-10 03:12:56
  • JavaScript 中断请求几种方案详解

    2024-05-09 10:35:51
  • python基于urllib实现按照百度音乐分类下载mp3的方法

    2022-03-07 21:07:38
  • go学习笔记读取consul配置文件详解

    2024-05-09 10:08:14
  • 作为PHP程序员你要知道的另外一种日志

    2023-11-15 02:06:59
  • go语言中的协程详解

    2024-03-13 00:42:24
  • Python 中的异步 for 循环示例详解

    2021-07-09 10:27:30
  • Go之集合slice的实现

    2024-04-26 17:33:06
  • asp之家 网络编程 m.aspxhome.com