樹莓派+攝像頭實(shí)現(xiàn)對移動(dòng)物體的檢測
在上一篇文章中實(shí)現(xiàn)了樹莓派下對攝像頭的調(diào)用,有興趣的可以看一下:python+opencv實(shí)現(xiàn)攝像頭調(diào)用的方法
接下來,我們將使用python+opencv實(shí)現(xiàn)對移動(dòng)物體的檢測
一、環(huán)境變量的配置
我們可以參照上一篇文章對我們的樹莓派進(jìn)行環(huán)境的配置
當(dāng)我們將cv2的庫安裝之后,就可以實(shí)現(xiàn)對攝像頭的操作
二、攝像頭的連接
在此實(shí)驗(yàn)中,我使用的為usb攝像頭
當(dāng)我們連接攝像頭之后,終端輸入
ls /dev/video*
如果終端提示如下:

則表示攝像頭連接成功
三、編碼實(shí)現(xiàn)對移動(dòng)物體的檢測
使用python編寫程序,實(shí)現(xiàn)對移動(dòng)物體的檢測,代碼如下
#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()
我的樹莓派終端不能顯示中文,因此會(huì)出現(xiàn)亂碼
Ubuntu下的運(yùn)行結(jié)果如下

樹莓派下執(zhí)行結(jié)果如下:

此外,在檢測物體移動(dòng)的同時(shí),添加了led閃爍以及框選移動(dòng)部分的功能,led安裝方法請移步之前的博客
文章參考鏈接:OpenCV檢測場景內(nèi)是否有移動(dòng)物體
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何取消pyecharts繪制地圖時(shí)默認(rèn)顯示小圓點(diǎn)標(biāo)識(shí)
這篇文章主要介紹了如何取消pyecharts繪制地圖時(shí)默認(rèn)顯示小圓點(diǎn)標(biāo)識(shí),文章內(nèi)容介紹詳細(xì)具有一定的參考價(jià)值?需要的小伙伴可以參考一下2022-04-04
使用Python和百度語音識(shí)別生成視頻字幕的實(shí)現(xiàn)
這篇文章主要介紹了使用Python和百度語音識(shí)別生成視頻字幕,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
pygame實(shí)現(xiàn)方塊動(dòng)畫實(shí)例講解
在本篇文章里小編給大家整理的是一篇關(guān)于pygame實(shí)現(xiàn)方塊動(dòng)畫實(shí)例講解內(nèi)容,以后需要的朋友們可以學(xué)習(xí)參考下。2021-12-12
python3使用騰訊企業(yè)郵箱發(fā)送郵件的實(shí)例
今天小編就為大家分享一篇python3使用騰訊企業(yè)郵箱發(fā)送郵件的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-06-06
Python報(bào)錯(cuò):TypeError:?‘xxx‘?object?is?not?subscriptable解決
這篇文章主要給大家介紹了關(guān)于Python報(bào)錯(cuò):TypeError:?‘xxx‘?object?is?not?subscriptable的解決辦法,TypeError是Python中的一種錯(cuò)誤,表示操作或函數(shù)應(yīng)用于不合適類型的對象時(shí)發(fā)生,文中將解決辦法介紹的非常詳細(xì),需要的朋友可以參考下2024-08-08
Python使用shutil模塊實(shí)現(xiàn)文件拷貝
這篇文章主要介紹了Python使用shutil模塊實(shí)現(xiàn)文件拷貝,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07

