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


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查找函数f(x)=0根的解决方法
May 07 Python
python3中函数参数的四种简单用法
Jul 09 Python
对python GUI实现完美进度条的示例详解
Dec 13 Python
Python二叉树的遍历操作示例【前序遍历,中序遍历,后序遍历,层序遍历】
Dec 24 Python
Python函数式编程指南:对生成器全面讲解
Nov 19 Python
利用pandas将非数值数据转换成数值的方式
Dec 18 Python
Python 使用threading+Queue实现线程池示例
Dec 21 Python
基于Python和C++实现删除链表的节点
Jul 06 Python
python Cartopy的基础使用详解
Nov 01 Python
如何将Pycharm中调整字体大小的方式设置为&quot;ctrl+鼠标滚轮上下滑&quot;
Nov 17 Python
python搜索算法原理及实例讲解
Nov 18 Python
Python爬虫之爬取最新更新的小说网站
May 06 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
上海无线电三厂简史修改版
2021/03/01 无线电
php生成图片缩略图的方法
2015/04/07 PHP
jquery 经典动画菜单效果代码
2010/01/26 Javascript
得到form下的所有的input的js代码
2013/11/07 Javascript
JavaScript 学习笔记之数据类型
2015/01/14 Javascript
ion content 滚动到底部会遮住一部分视图的快速解决方法
2016/09/06 Javascript
通俗易懂地解释JS中的闭包
2017/10/23 Javascript
原生JavaScript实现remove()和recover()功能示例
2018/07/24 Javascript
JavaScript函数节流和函数去抖知识点学习
2018/07/31 Javascript
vue 使用axios 数据请求第三方插件的使用教程详解
2019/07/05 Javascript
vue实现循环滚动列表
2020/06/30 Javascript
JavaScript常用工具函数库汇总
2020/09/17 Javascript
[04:09]显微镜下的DOTA2第十二期—NaVi美如画的团战
2014/06/23 DOTA
[57:09]DOTA2-DPC中国联赛 正赛 Phoenix vs Dynasty BO3 第一场 1月26日
2021/03/11 DOTA
Python isinstance函数介绍
2015/04/14 Python
Python+matplotlib+numpy绘制精美的条形统计图
2018/01/02 Python
python批量替换多文件字符串问题详解
2018/04/22 Python
Python处理中文标点符号大集合
2018/05/14 Python
Python 找到列表中满足某些条件的元素方法
2018/06/26 Python
python实现连续图文识别
2018/12/18 Python
解决pycharm 安装numpy失败的问题
2019/12/05 Python
tf.concat中axis的含义与使用详解
2020/02/07 Python
Numpy 多维数据数组的实现
2020/06/18 Python
django跳转页面传参的实现
2020/09/17 Python
详解Pycharm第三方库的安装及使用方法
2020/12/29 Python
澳大利亚领先的在线机械五金、园艺和存储专家:Edisons
2018/03/24 全球购物
美国奢侈品购物平台:Orchard Mile
2018/05/02 全球购物
应聘护士自荐信
2013/10/21 职场文书
市场营销专科应届生求职信
2013/11/24 职场文书
播音主持专业个人自我评价
2014/01/09 职场文书
房屋出租协议书
2014/04/10 职场文书
疾病防治方案
2014/05/31 职场文书
基层党员对照检查材料
2014/09/24 职场文书
党员自我评议对照检查材料
2014/09/27 职场文书
西安事变观后感
2015/06/12 职场文书
Vite + React从零开始搭建一个开源组件库
2022/06/25 Javascript