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


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 相关文章推荐
python读取浮点数和读取文本文件示例
May 06 Python
Python中zfill()方法的使用教程
May 20 Python
Python在信息学竞赛中的运用及Python的基本用法(详解)
Aug 15 Python
Python决策树之基于信息增益的特征选择示例
Jun 25 Python
flask入门之文件上传与邮件发送示例
Jul 18 Python
Pandas透视表(pivot_table)详解
Jul 22 Python
python实现屏保程序(适用于背单词)
Jul 30 Python
快速查找Python安装路径方法
Feb 06 Python
Django bulk_create()、update()与数据库事务的效率对比分析
May 15 Python
python 生成正态分布数据,并绘图和解析
Dec 21 Python
python爬不同图片分别保存在不同文件夹中的实现
Apr 02 Python
Python利用Turtle绘制哆啦A梦和小猪佩奇
Apr 04 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/02/19 PHP
使用php-timeit估计php函数的执行时间
2015/09/06 PHP
PHP代码优化技巧小结
2015/09/29 PHP
PHP生成图片验证码功能示例
2017/01/12 PHP
PHP基于双向链表与排序操作实现的会员排名功能示例
2017/12/26 PHP
JavaScript中的new的使用方法与注意事项
2007/05/16 Javascript
基于jquery的分页控件(C#)
2011/01/06 Javascript
Jquery跨域获得Json时invalid label错误的解决办法
2011/01/11 Javascript
js内置对象 学习笔记
2011/08/01 Javascript
微信内置浏览器私有接口WeixinJSBridge介绍
2015/05/25 Javascript
基于jQuery实现二级下拉菜单效果
2016/02/01 Javascript
TypeScript学习之强制类型的转换
2016/12/27 Javascript
jQuery和CSS仿京东仿淘宝列表导航菜单
2017/01/04 Javascript
Angular2实现自定义双向绑定属性
2017/03/22 Javascript
js实现轮播图的两种方式(构造函数、面向对象)
2017/09/30 Javascript
利用JS测试目标网站的打开响应速度
2017/12/01 Javascript
Vue仿今日头条实例详解
2018/02/06 Javascript
浅谈webpack+react多页面开发终极架构
2018/11/11 Javascript
js中的数组对象排序分析
2018/12/11 Javascript
通过layer实现可输入的模态框的例子
2019/09/27 Javascript
python 实现堆排序算法代码
2012/06/05 Python
windows系统下Python环境搭建教程
2017/03/28 Python
Python中enumerate()函数编写更Pythonic的循环
2018/03/06 Python
python3+dlib实现人脸识别和情绪分析
2018/04/21 Python
详解Python 解压缩文件
2019/04/09 Python
使用python修改文件并立即写回到原始位置操作(inplace读写)
2020/06/28 Python
python字典的值可以修改吗
2020/06/29 Python
HTML5 本地存储和内容按需加载的思路和方法
2011/04/07 HTML / CSS
Nayomi官网:沙特阿拉伯王国睡衣和内衣品牌
2020/12/19 全球购物
Linux机考试题
2015/07/17 面试题
餐饮采购员岗位职责
2014/03/15 职场文书
学校教师读书活动总结
2014/07/08 职场文书
关于读书的演讲稿400字
2014/08/27 职场文书
教师群众路线心得体会
2014/11/04 职场文书
Nginx的反向代理实例详解
2021/03/31 Servers
PostgreSQL聚合函数介绍以及分组和排序
2022/04/12 PostgreSQL