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


Posted in Python onJune 22, 2019

在上一篇文章中实现了树莓派下对摄像头的调用,有兴趣的可以看一下: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检测场景内是否有移动物体

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
使用Django的模版来配合字符串翻译工作
Jul 27 Python
详解Python中的Descriptor描述符类
Jun 14 Python
深度定制Python的Flask框架开发环境的一些技巧总结
Jul 12 Python
Python:Scrapy框架中Item Pipeline组件使用详解
Dec 27 Python
Django框架模板注入操作示例【变量传递到模板】
Dec 19 Python
python基于C/S模式实现聊天室功能
Jan 09 Python
python使用writerows写csv文件产生多余空行的处理方法
Aug 01 Python
matplotlib.pyplot画图并导出保存的实例
Dec 07 Python
Django接收照片储存文件的实例代码
Mar 07 Python
keras读取h5文件load_weights、load代码操作
Jun 12 Python
Python基于xlutils修改表格内容过程解析
Jul 28 Python
django中cookiecutter的使用教程
Dec 03 Python
Python数据结构与算法(几种排序)小结
Jun 22 #Python
python+opencv实现摄像头调用的方法
Jun 22 #Python
python算法与数据结构之冒泡排序实例详解
Jun 22 #Python
分析运行中的 Python 进程详细解析
Jun 22 #Python
机器学习实战之knn算法pandas
Jun 22 #Python
解决py2exe打包后,总是多显示一个DOS黑色窗口的问题
Jun 21 #Python
pyinstaller打包单个exe后无法执行错误的解决方法
Jun 21 #Python
You might like
PHP操作数组的一些函数整理介绍
2011/07/17 PHP
Symfony核心类概述
2016/03/17 PHP
使用composer安装使用thinkphp6.0框架问题【视频教程】
2019/10/01 PHP
通过PHP实现用户注册后邮箱验证激活
2020/11/10 PHP
枚举JavaScript对象的函数
2006/12/22 Javascript
[转]JS宝典学习笔记
2007/02/07 Javascript
为指定的元素添加遮罩层的示例代码
2014/01/15 Javascript
JQuery性能优化的几点建议
2014/05/14 Javascript
jQuery的文档处理程序详解
2016/05/10 Javascript
基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转
2016/06/12 Javascript
利用JS判断字符串是否含有数字与特殊字符的方法小结
2016/11/25 Javascript
使用jQuery.Pin垂直滚动时固定导航
2017/05/24 jQuery
详解AngularJS跨页面传值(ui-router)
2017/08/23 Javascript
angular4模块中给标签添加背景图的实现方法
2017/09/15 Javascript
浅谈用Webpack路径压缩图片上传尺寸获取的问题
2018/02/22 Javascript
使用Python脚本在Linux下实现部分Bash Shell的教程
2015/04/17 Python
使用Python的Django框架实现事务交易管理的教程
2015/04/20 Python
python中迭代器(iterator)用法实例分析
2015/04/29 Python
使用Python压缩和解压缩zip文件的教程
2015/05/06 Python
python实现斐波那契数列的方法示例
2017/01/12 Python
在Python的一段程序中如何使用多次事件循环详解
2017/09/07 Python
对Python 检查文件名是否规范的实例详解
2019/06/10 Python
如何基于Python实现自动扫雷
2020/01/06 Python
python super函数使用方法详解
2020/02/14 Python
浅谈python量化 双均线策略(金叉死叉)
2020/06/03 Python
详解Windows下PyCharm安装Numpy包及无法安装问题解决方案
2020/06/18 Python
中国高端鲜花第一品牌:roseonly(一生只送一人)
2017/02/12 全球购物
Yankee Candle官网:美国最畅销蜡烛品牌之一
2020/01/05 全球购物
初二政治教学反思
2014/01/12 职场文书
《云雀的心愿》教学反思
2014/02/25 职场文书
2014年银行员工年终自我评价
2014/09/19 职场文书
八项规定个人对照检查材料思想汇报
2014/09/25 职场文书
大二学生自我检讨书
2014/10/23 职场文书
2014年学生会个人工作总结
2014/11/07 职场文书
2014年银行年终工作总结
2014/12/19 职场文书
工作犯错保证书
2015/05/11 职场文书