使用nodejs和python构建一个远程监控系统1(1)

‘’’

if not os.path.exists(filePath):

os.mkdir(filePath)

@staticmethod

def countCenter(box):

‘’’

计算一个矩形的中心

‘’’

return (int(abs(box[0][0] - box[1][0])*0.5) + box[0][0],int(abs(box[0][1] - box[1][1])*0.5) +box[0][1])

@staticmethod

def countBox(center):

‘’’

根据两个点计算出,x,y,c,r

‘’’

return (center[0][0],center[0][1],center[1][0]-center[0][0],center[1][1]-center[0][1])

@staticmethod

def getImageFileName():

return time.strftime(“%Y_%m_%d_%H_%M_%S”, time.localtime())+‘.png’

#构造日志

logger = logging.getLogger(LOG_NAME)

formatter = logging.Formatter(LOG_FORMATTER)

IOUtil.mkdir(LOG_DIR);

file_handler = logging.FileHandler(LOG_DIR + LOG_FILE,encoding=‘utf-8’)

file_handler.setFormatter(formatter)

console_handler = logging.StreamHandler(sys.stdout)

console_handler.setFormatter(formatter)

logger.addHandler(file_handler)

logger.addHandler(console_handler)

logger.setLevel(logging.INFO)

这部分需要注意的是提供了一个方法用于将图像在rgb-bgr颜色模式之间转换,因为opencv使用的图像模式为bgr,而我们习惯的颜色模式是rgb

2.配置文件

#照片保存文件夹

SCREENSHOT_DIR = “screenshots/”

#视频保存文件夹

VIDEO_DIR = “videos/”

#预警图片文件夹

WARN_DIR = “warn/”

#日志文件夹

LOG_DIR = “log/”

#日志文件

LOG_FILE = “camera.log”

#图像发送IP

IMAGE_IP = “127.0.0.1”

#图像发送端口

IMAGE_PORT = 9999

#日志输出格式

LOG_FORMATTER = “%(asctime)s %(levelname)-8s: %(message)s”

#日志输出名称

LOG_NAME = ‘cameraLogger’

#是否打开本地窗口

IS_WINDOW_ON = True

3.视频采集类(负责采集摄像头信息,拍照,录制视频等等)

#encoding=utf-8

import cv2

import numpy

import socket

import json

import threading

import os

import time

import copy

from settings import *

from threading import Thread

from utils import IOUtil,logger

‘’’

管理者模块,负责控制信息获取,命令获取

‘’’

class CameraManager(object):

#相机管理类,负责控制信息获取

def init(self,capture):

‘’’

:param capture: 摄像头对象

:param windowManager: 钩子类,窗口管理,按键

‘’’

#从配置文件中读取截图目录和录像目录创建文件夹

self.screenshot_dir = SCREENSHOT_DIR

self.video_dir = VIDEO_DIR

self._capture = capture

#当前画面

self._frame = None

#录像编码

self._videoEncoding = None

#视频写入工具

self._videoWriter = None

#是否开启显示

self._isShow = False

#是否工作

self._isWorking = True

#fps

self._fps = 0

#是否正在写入视频

self._videoFilename = None

IOUtil.mkdir(self.screenshot_dir)

IOUtil.mkdir(self.video_dir)

logger.info(“视频采集器初始化完毕!”)

def getFrame(self):

#返回当前的帧

return copy.copy(self._frame)

def getFps(self):

#获得当前fps

return self._fps

def isWritingVideo(self):

#是否正在写入视频

return self._videoFilename is not None

def start(self):

#开始工作

logger.info(“开启视频采集”)

frameThread = Thread(target = self._update,args=())

frameThread.start()

return self

def stop(self):

#停止工作

self._isWorking = False

self._videoFilename = None

logger.info(“关闭视频采集”)

def _update(self):

#更新摄像头画面

logger.info(“视频采集线程启动…”)

while self._isWorking:

startTime = time.time()

if self._capture is not None:

_,self._frame = self._capture.read()

try:

self._fps = 1/(time.time() - startTime)

except:

self._fps = 30

logger.info(“视频采集线程关闭…”)

def getImageFileName(self,filename=None,imageformat=“.png”):

#获得图片文件名

if not filename:

filename = time.strftime(“%Y_%m_%d_%H_%M_%S”, time.localtime())

filename += imageformat

return os.path.join(self.screenshot_dir,filename)

def writeImage(self):

#写入图片文件

logger.info(“开始写入一张图片”)

imageFileName = self.getImageFileName()

try:

cv2.imwrite(imageFileName,self._frame)

except Exception as e:

logger.error(“写入图片失败:”+str(e))

logger.info(“写入图片成功”+imageFileName)

def getVideoFileName(self,filename=None,videoformat=“.avi”):

#获得视频文件名

if not filename:

filename = time.strftime(“%Y_%m_%d_%H_%M_%S”, time.localtime())

filename += videoformat

return os.path.join(self.video_dir,filename)

def startWritingVideo(self,filename=None,encoding=cv2.VideoWriter_fourcc(“I”,“4”,“2”,“0”),videoformat=“.avi”):

#初始化写入视频文件

logger.info(“开启视频录制”)

self._videoFilename = self.getVideoFileName()

self._videoEncoding = encoding

Thread(target = self._writingVideo,args=()).start()

def stopWritingVideo(self):

#关闭视频写入

self._videoFilename = None

self._videoWriter = None

self._videoEncoding = None

def _writingVideo(self):

#写入视频文件

logger.info(“视频采集线程启动,目标文件为:”+self._videoFilename)

if self._videoWriter is None:

size = (int(self._capture.get(cv2.CAP_PROP_FRAME_WIDTH)),int(self._capture.get(cv2.CAP_PROP_FRAME_HEIGHT)))

self._videoWriter = cv2.VideoWriter(self._videoFilename,self._videoEncoding,self._fps,size)

while self._videoFilename is not None:

self._videoWriter.write(self._frame)

logger.info(“写入视频完毕,文件名为:”+self._videoFilename)

def isWorking(self):

#工作控制

return self._isWorking

if name == “main”:

video = cv2.VideoCapture(0)

camera = CameraManager(video)

camera.start()

while True:

frame = camera.getFrame()

if frame is not None:

cv2.imshow(“test”,frame)

k = cv2.waitKey(1) & 0xff

if k == 27:

camera.stop()

break

elif k == 9:

#tab键开启录像

if not camera.isWritingVideo():

camera.startWritingVideo()
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:前端)


后记


总结一下这三次面试下来我的经验是:

  1. 一定不要死记硬背,要理解原理,否则面试官一深入就会露馅!

  2. 代码能力一定要注重,尤其是很多原理性的代码(之前两次让我写过Node中间件,Promise.all,双向绑定原理,被虐的怀疑人生)!

  3. 尽量从面试官的问题中表现自己知识的深度与广度,让面试官发现你的闪光点!

  4. 多刷面经!

我把所有遇到的面试题都做了一个整理,并且阅读了很多大牛的博客之后写了解析,免费分享给大家,算是一个感恩回馈吧,有需要的朋友【点击我】免费获取。祝大家早日拿到自己心怡的工作!

篇幅有限,仅展示部分内容



广度,让面试官发现你的闪光点!

  1. 多刷面经!

我把所有遇到的面试题都做了一个整理,并且阅读了很多大牛的博客之后写了解析,免费分享给大家,算是一个感恩回馈吧,有需要的朋友【点击我】免费获取。祝大家早日拿到自己心怡的工作!

篇幅有限,仅展示部分内容



  • 11
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值