基于Python3 + OpenCV3.3.1的远程监控程序


一、环境配置

OpenCV是一个基于(开源)发行的跨平台计算机视觉库,利用OpenCV能够实现视频图像的捕获。

关于python3中OpenCV和Numpy的配置:

1. 安装python后一般会自带有pip程序,利用pip install [库名称] 就能够进行下载,但是由于Numpy和OpenCV在pip库没有匹配的版本,所以使用pip直接安装会报错。

2. 我们利用wheel进行下载,首先利用pip install wheel 下载wheel,这样就可以下载whl文件了。

3. 进入 https://www.lfd.uci.edu/~gohlke/pythonlibs/ 下载相应的OpenCV和Numpy的whl文件,利用pip install [下载的文件名(包含后缀名)]就可以安装OpenCV和Numpy了。

二、程序编写

服务器分析:

1. 先通过在服务器端利用OpenCV捕获到视频的每一帧图片

2. 将这些图片进行压缩成JPEG格式,这样能减小图片大小,便于传输

3. 按照提前协商好的分辨率和帧数进行打包编码传输

4. 利用服务器端打开端口8880,此时客户端连接后,便可以在客户端中捕获到服务器端的视频。

  1. #服务器端
  2.  
  3. import socket
  4. import threading
  5. import struct
  6. import time
  7. import cv2
  8. import numpy
  9.  
  10. class Carame_Accept_Object:
  11. def __init__(self,S_addr_port=("",8880)):
  12. self.resolution=(640,480) #分辨率
  13. self.img_fps=15 #每秒传输多少帧数
  14. self.addr_port=S_addr_port
  15. self.Set_Socket(self.addr_port)
  16.  
  17. #设置套接字
  18. def Set_Socket(self,S_addr_port):
  19. self.server=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
  20. self.server.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1) #端口可复用
  21. self.server.bind(S_addr_port)
  22. self.server.listen(5)
  23. #print("the process work in the port:%d" % S_addr_port[1])
  24.  
  25. def check_option(object,client):
  26. #按格式解码,确定帧数和分辨率
  27. info=struct.unpack('lhh',client.recv(8))
  28. if info[0]>888:
  29. object.img_fps=int(info[0])-888 #获取帧数
  30. object.resolution=list(object.resolution)
  31. # 获取分辨率
  32. object.resolution[0]=info[1]
  33. object.resolution[1]=info[2]
  34. object.resolution = tuple(object.resolution)
  35. return 1
  36. else:
  37. return 0
  38.  
  39. def RT_Image(object,client,D_addr):
  40. if(check_option(object,client)==0):
  41. return
  42. camera=cv2.VideoCapture(0) #从摄像头中获取视频
  43. img_param=[int(cv2.IMWRITE_JPEG_QUALITY),object.img_fps] #设置传送图像格式、帧数
  44. while(1):
  45. time.sleep(0.1) #推迟线程运行0.1s
  46. _,object.img=camera.read() #读取视频每一帧
  47.  
  48. object.img=cv2.resize(object.img,object.resolution) #按要求调整图像大小(resolution必须为元组)
  49. _,img_encode=cv2.imencode('.jpg',object.img,img_param) #按格式生成图片
  50. img_code=numpy.array(img_encode) #转换成矩阵
  51. object.img_data=img_code.tostring() #生成相应的字符串
  52. try:
  53. #按照相应的格式进行打包发送图片
  54. client.send(struct.pack("lhh",len(object.img_data),object.resolution[0],object.resolution[1])+object.img_data)
  55. except:
  56. camera.release() #释放资源
  57. return
  58.  
  59. if __name__ == '__main__':
  60. camera=Carame_Accept_Object()
  61. while(1):
  62. client,D_addr=camera.server.accept()
  63. clientThread=threading.Thread(None,target=RT_Image,args=(camera,client,D_addr,))
  64. clientThread.start()

客户端分析:

1. 客户端连接端口后,首先发送需要协商的分辨率和帧数,以致能够使传输“协议”一致

2. 客户端使用线程,对图片进行收集

3. 对收到的每一张图片进行解码,并利用OpenCV播放出来,即可实现C/S两端实时视频传输。

  1. #客户端
  2.  
  3. import socket
  4. import cv2
  5. import threading
  6. import struct
  7. import numpy
  8.  
  9. class Camera_Connect_Object:
  10. def __init__(self,D_addr_port=["",8880]):
  11. self.resolution=[640,480]
  12. self.addr_port=D_addr_port
  13. self.src=888+15 #双方确定传输帧数,(888)为校验值
  14. self.interval=0 #图片播放时间间隔
  15. self.img_fps=15 #每秒传输多少帧数
  16.  
  17. def Set_socket(self):
  18. self.client=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
  19. self.client.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)
  20.  
  21. def Socket_Connect(self):
  22. self.Set_socket()
  23. self.client.connect(self.addr_port)
  24. print("IP is %s:%d" % (self.addr_port[0],self.addr_port[1]))
  25.  
  26. def RT_Image(self):
  27. #按照格式打包发送帧数和分辨率
  28. self.name=self.addr_port[0]+" Camera"
  29. self.client.send(struct.pack("lhh", self.src, self.resolution[0], self.resolution[1]))
  30. while(1):
  31. info=struct.unpack("lhh",self.client.recv(8))
  32. buf_size=info[0] #获取读的图片总长度
  33. if buf_size:
  34. try:
  35. self.buf=b"" #代表bytes类型
  36. temp_buf=self.buf
  37. while(buf_size): #读取每一张图片的长度
  38. temp_buf=self.client.recv(buf_size)
  39. buf_size-=len(temp_buf)
  40. self.buf+=temp_buf #获取图片
  41. data = numpy.fromstring(self.buf, dtype='uint8') #按uint8转换为图像矩阵
  42. self.image = cv2.imdecode(data, 1) #图像解码
  43. cv2.imshow(self.name, self.image) #展示图片
  44. except:
  45. pass;
  46. finally:
  47. if(cv2.waitKey(10)==27): #每10ms刷新一次图片,按‘ESC’(27)退出
  48. self.client.close()
  49. cv2.destroyAllWindows()
  50. break
  51.  
  52. def Get_Data(self,interval):
  53. showThread=threading.Thread(target=self.RT_Image)
  54. showThread.start()
  55.  
  56. if __name__ == '__main__':
  57. camera=Camera_Connect_Object()
  58. camera.addr_port[0]=input("Please input IP:")
  59. camera.addr_port=tuple(camera.addr_port)
  60. camera.Socket_Connect()
  61. camera.Get_Data(camera.interval)

三、文件生成

完成程序的编写以后,希望能把Python脚本转为为能够脱离Python平台的可执行程序,利用pyinstaller可达成目的。

1. 利用 pip install pyinstaller 下载pyinstaller组件,若下载不成功,请参照环境配置方法进行下载

2. 下载成功后,在源程序目录处打开cmd窗口,利用pyinstaller -F -w -i (xxx.ico) (yyy.py) 生成指定图标的exe文件

3. 在生成的目录下,能在 dist 文件夹中找到相应的运行程序

注:pyinstaller指令请参照 https://pyinstaller.readthedocs.io/en/stable/usage.html

参考文章:

基于Socket和OpenCV的实时视频传输(On Windows):https://www.2cto.com/kf/201608/537950.html

基于python和opencv的视频传输程序(一):http://www.jianshu.com/p/4aed39710676

教程 | 深度学习 + OpenCV,Python 实现实时视频目标检测:http://www.myzaker.com/article/59c358c91bc8e07a1400002f/


基于Python3 + OpenCV3.3.1的远程监控程序的更多相关文章

  1. Sublime Text 2 (for OS X )配置成可以运行基于python3解释器的 .py文件

    Mac自带的python 其version是python 2.7 官网下的Sublime Text 2部署好了以后默认也是 为了使ST2 可以在command+B时可以运行基于python3的.py, ...

  2. 利用java实现一个简单的远程监控程序

    一般的远程监控软件都是用c或者c++等语言开发的,而使用java如何来实现相同的功能呢. 首先我们先介绍一下一个简单的远程监控程序的实现原理. 功能一,远程屏幕监视 (1) 必须要有监控端与被监控端, ...

  3. 基于IAP和Keil MDK的远程升级设计

    写在前面:三个周之前,我突然想写一个远程升级的程序.那个时候我只是大概知道IAP的意思是在应用编程,但怎么编,我还一无所知.我给自己定下一个个阶段目标,从最基础的代码一点点写起,解决一个又一个的问题. ...

  4. 基于ssh反向代理实现的远程协助

    本文描述了怎么通过ssh反向代理实现远程协助,并提供了相关代码. 可满足web开启远程协助功能后,维护人员能够通过ssh和http登录客户机器(包括在nat环境下) web开启该功能后,ssh才能登录 ...

  5. [转载] 基于Dubbo的Hessian协议实现远程调用

    转载自http://shiyanjun.cn/archives/349.html Dubbo基于Hessian实现了自己Hessian协议,可以直接通过配置的Dubbo内置的其他协议,在服务消费方进行 ...

  6. 基于Python3的漏洞检测工具 ( Python3 插件式框架 )

    目录 Python3 漏洞检测工具 -- lance screenshot requirements 关键代码 usage documents Any advice or sugggestions P ...

  7. 使用Dockerfile文件制作centos6.8基础镜像,基于centos基础镜像的ssh远程登录镜像,jdk1.8镜像,tomcat镜像,elasticsearch镜像等等

    一.首先制作一个centos6.8的裸机镜像 创建一个干净的目录: [root@docker centos6.]# ls c68-docker.tar.xz Dockerfile Dockerfile ...

  8. 基于Dubbo的Hessian协议实现远程调用

    Dubbo基于Hessian实现了自己Hessian协议,可以直接通过配置的Dubbo内置的其他协议,在服务消费方进行远程调用,也就是说,服务调用方需要使用Java语言来基于Dubbo调用提供方服务, ...

  9. 乐鑫esp8266基于freeRtos实现私有服务器本地远程OTA升级

    目录 一.前言: 二.回顾下OTA的流程: 三.lwip网络框架的知识的使用: 四.如何处理服务器返回的数据? 五.扇区的擦除和烧写? 六.如何调用? 七.好好享用吧! 八.下载: 九.工程截图: 代 ...

随机推荐

  1. 杭电oj 1000

    今天开始和一个认识的学弟刷题. 学弟是个大牛,我还是个菜鸟.嘿嘿. 杭电第一题我就wrong了好几次. #include <iostream> using namespace std; i ...

  2. csdn下载频道 循环登录的解决方法

    一直循环登录,明明登录成功,跳转页面后还是无法下载,还是要登录,一直循环. 解决方法是修改密码.看来asp果然是垃圾啊.

  3. HashMap源码-使用说明部分

    /* * Implementation notes. * 使用说明 * * This map usually acts as a binned (bucketed) hash table, but * ...

  4. Delphi~通过程序窗体句柄获取程序路径

    http://www.cnblogs.com/Jesses/articles/1636323.html 引用PsAPI var  h:HWND;  pid: Cardinal;  pHandle: T ...

  5. WebService authentication

    http://blog.csdn.net/largestone_187/article/details/5734632 通过SoapHeader对用户口令进行验证,只有授权的用户才可以使用接口.确保了 ...

  6. Android修改状态栏颜色全方位教程

    关键字:状态栏着色 透明状态栏 沉浸式 白底黑字 Github Demo:https://github.com/imflyn/Eyes 参考文章: Android-transulcent-status ...

  7. 针对WebLogic Server 12.1.3版本打补丁

    先去下载补丁文件,在链接 https://support.oracle.com/epmos/faces/DocumentDisplay?_afrLoop=179118524484876&id= ...

  8. 各种Lisp系语言大检阅

    主要特色: CommonLISP : lisp系集大成者, 工业化强度的大型语言. 拥有理论上最高的表达力, 非常复杂, 学习难度极大. 喜欢的人捧到天上, 觉得它是一切语言的终点, 不喜欢的人恶心死 ...

  9. linux服务器网络配置

    一.配置linux服务器的网络 手动修改配置网卡文件 先检查网卡是否正常 lspci |grep Ether 与网卡相关的TCP/IP网络配置文件位置 /etc/sysconfig/network-s ...

  10. virtualbox虚拟机ubuntu操作系统,设置网络互通、访问,能访问虚拟机swoole的http服务

    网络互通 1.设置virtualbox网络连接模式为桥接网卡模式 2.重启虚拟机查看虚拟机IP ifconfig 3.开启window的telnet程序 控制面板->程序->启用或关闭wi ...