python實(shí)現(xiàn)opencv+scoket網(wǎng)絡(luò)實(shí)時(shí)圖傳
本文實(shí)例為大家分享了python實(shí)現(xiàn)opencv+scoket網(wǎng)絡(luò)實(shí)時(shí)圖傳的具體代碼,供大家參考,具體內(nèi)容如下
服務(wù)器分析:
1. 先通過(guò)在服務(wù)器端利用OpenCV捕獲到視頻的每一幀圖片
2. 將這些圖片進(jìn)行壓縮成JPEG格式,這樣能減小圖片大小,便于傳輸
3. 按照提前協(xié)商好的分辨率和幀數(shù)進(jìn)行打包編碼傳輸
4. 利用服務(wù)器端打開端口8880,此時(shí)客戶端連接后,便可以在客戶端中捕獲到服務(wù)器端的視頻。
#服務(wù)端 import socket import threading import struct import time import cv2 import numpy class Carame_Accept_Object: def __init__(self,S_addr_port=("",8880)): self.resolution=(640,480) #分辨率 self.img_fps=15 #每秒傳輸多少幀數(shù) self.addr_port=S_addr_port self.Set_Socket(self.addr_port) #設(shè)置套接字 def Set_Socket(self,S_addr_port): self.server=socket.socket(socket.AF_INET,socket.SOCK_STREAM) self.server.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1) #端口可復(fù)用 self.server.bind(S_addr_port) self.server.listen(5) #print("the process work in the port:%d" % S_addr_port[1]) def check_option(object,client): #按格式解碼,確定幀數(shù)和分辨率 info=struct.unpack('lhh',client.recv(8)) if info[0]>888: object.img_fps=int(info[0])-888 #獲取幀數(shù) object.resolution=list(object.resolution) # 獲取分辨率 object.resolution[0]=info[1] object.resolution[1]=info[2] object.resolution = tuple(object.resolution) return 1 else: return 0 def RT_Image(object,client,D_addr): if(check_option(object,client)==0): return camera=cv2.VideoCapture(0) #從攝像頭中獲取視頻 img_param=[int(cv2.IMWRITE_JPEG_QUALITY),object.img_fps] #設(shè)置傳送圖像格式、幀數(shù) while(1): time.sleep(0.1) #推遲線程運(yùn)行0.1s _,object.img=camera.read() #讀取視頻每一幀 object.img=cv2.resize(object.img,object.resolution) #按要求調(diào)整圖像大小(resolution必須為元組) _,img_encode=cv2.imencode('.jpg',object.img,img_param) #按格式生成圖片 img_code=numpy.array(img_encode) #轉(zhuǎn)換成矩陣 object.img_data=img_code.tostring() #生成相應(yīng)的字符串 try: #按照相應(yīng)的格式進(jìn)行打包發(fā)送圖片 client.send(struct.pack("lhh",len(object.img_data),object.resolution[0],object.resolution[1])+object.img_data) except: camera.release() #釋放資源 return if __name__ == '__main__': camera=Carame_Accept_Object() while(1): client,D_addr=camera.server.accept() clientThread=threading.Thread(None,target=RT_Image,args=(camera,client,D_addr,)) clientThread.start()
客戶端分析:
1. 客戶端連接端口后,首先發(fā)送需要協(xié)商的分辨率和幀數(shù),以致能夠使傳輸“協(xié)議”一致
2. 客戶端使用線程,對(duì)圖片進(jìn)行收集
3. 對(duì)收到的每一張圖片進(jìn)行解碼,并利用OpenCV播放出來(lái),即可實(shí)現(xiàn)C/S兩端實(shí)時(shí)視頻傳輸。
#客戶端 import socket import cv2 import threading import struct import numpy class Camera_Connect_Object: def __init__(self,D_addr_port=["",8880]): self.resolution=[640,480] self.addr_port=D_addr_port self.src=888+15 #雙方確定傳輸幀數(shù),(888)為校驗(yàn)值 self.interval=0 #圖片播放時(shí)間間隔 self.img_fps=15 #每秒傳輸多少幀數(shù) def Set_socket(self): self.client=socket.socket(socket.AF_INET,socket.SOCK_STREAM) self.client.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1) def Socket_Connect(self): self.Set_socket() self.client.connect(self.addr_port) print("IP is %s:%d" % (self.addr_port[0],self.addr_port[1])) def RT_Image(self): #按照格式打包發(fā)送幀數(shù)和分辨率 self.name=self.addr_port[0]+" Camera" self.client.send(struct.pack("lhh", self.src, self.resolution[0], self.resolution[1])) while(1): info=struct.unpack("lhh",self.client.recv(8)) buf_size=info[0] #獲取讀的圖片總長(zhǎng)度 if buf_size: try: self.buf=b"" #代表bytes類型 temp_buf=self.buf while(buf_size): #讀取每一張圖片的長(zhǎng)度 temp_buf=self.client.recv(buf_size) buf_size-=len(temp_buf) self.buf+=temp_buf #獲取圖片 data = numpy.fromstring(self.buf, dtype='uint8') #按uint8轉(zhuǎn)換為圖像矩陣 self.image = cv2.imdecode(data, 1) #圖像解碼 cv2.imshow(self.name, self.image) #展示圖片 except: pass; finally: if(cv2.waitKey(10)==27): #每10ms刷新一次圖片,按‘ESC'(27)退出 self.client.close() cv2.destroyAllWindows() break def Get_Data(self,interval): showThread=threading.Thread(target=self.RT_Image) showThread.start() if __name__ == '__main__': camera=Camera_Connect_Object() camera.addr_port[0]="服務(wù)端的ip" camera.addr_port=tuple(camera.addr_port) camera.Socket_Connect() camera.Get_Data(camera.interval
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- python+opencv實(shí)現(xiàn)移動(dòng)偵測(cè)(幀差法)
- python opencv 檢測(cè)移動(dòng)物體并截圖保存實(shí)例
- win10下opencv-python特定版本手動(dòng)安裝與pip自動(dòng)安裝教程
- Python+OpenCV實(shí)現(xiàn)圖像的全景拼接
- python+opencv3生成一個(gè)自定義純色圖教程
- python opencv圓、橢圓與任意多邊形的繪制實(shí)例詳解
- python通過(guò)opencv實(shí)現(xiàn)圖片裁剪原理解析
- Python opencv相機(jī)標(biāo)定實(shí)現(xiàn)原理及步驟詳解
相關(guān)文章
python3獲取視頻文件播放時(shí)長(zhǎng)的三種方法
這篇文章主要介紹了python3獲取視頻文件播放時(shí)長(zhǎng)的三種方法,VideoFileClip,CV2以及FFmpeg這三種方法,文章通過(guò)代碼示例給大家講解的非常詳細(xì),需要的朋友可以參考下2024-04-04Python制作腳本幫女朋友搶購(gòu)清空購(gòu)物車
這篇文章主要介紹了Python制作的搶購(gòu)清空購(gòu)物車的腳本,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08pycharm2021激活碼使用教程(永久激活親測(cè)可用)
pycharm2021激活碼是一個(gè)可以輕松幫助用戶免費(fèi)激活pycharm2021.1軟件的文件,雖然說(shuō)pycharm現(xiàn)在只是推出了2021.1的EAP版,但是如果你想先率先體驗(yàn)一波,那么就可以利用小編提供的這個(gè)激活碼來(lái)進(jìn)行使用啦,并這個(gè)激活碼是永久有效的2021-03-03關(guān)于Python Error標(biāo)準(zhǔn)異常的總結(jié)
這篇文章主要介紹了關(guān)于Python Error標(biāo)準(zhǔn)異常的總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Python3.x+pycharm+Anaconda中縮小打包的.exe體積的問題
這篇文章主要介紹了Python3.x+pycharm+Anaconda中縮小打包的.exe體積的問題,本文通過(guò)圖文實(shí)例相結(jié)合給大家分享解決方案,需要的朋友可以參考下2021-08-08如何在Windows環(huán)境下安裝PyMySQL(已安裝Anaconda)
這篇文章主要介紹了如何在Windows環(huán)境下安裝PyMySQL問題(已安裝Anaconda),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08在pycharm中無(wú)法import所安裝的庫(kù)解決方案
這篇文章主要介紹了在pycharm中無(wú)法import所安裝的庫(kù)解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-05-05Python實(shí)現(xiàn)圖算法、堆操作和并查集代碼實(shí)例
這篇文章主要介紹了Python實(shí)現(xiàn)圖算法、堆操作和并查集代碼實(shí)例,圖算法、堆操作和并查集是計(jì)算機(jī)科學(xué)中常用的數(shù)據(jù)結(jié)構(gòu)和算法,它們?cè)诮鉀Q各種實(shí)際問題中具有重要的應(yīng)用價(jià)值,需要的朋友可以參考下2023-08-08