You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
98 lines
2.9 KiB
98 lines
2.9 KiB
#Pavol Debnar
|
|
#Thesis 2022/23
|
|
|
|
#for use of this script, TCP_IP address must be changed and the folders in writeString and fileString
|
|
import socket
|
|
import cv2
|
|
import numpy as np
|
|
import os
|
|
|
|
|
|
def variance_of_laplacian(image):
|
|
return cv2.Laplacian(image, cv2.CV_64F).var()
|
|
|
|
|
|
|
|
os.environ["OPENCV_FFMPEG_CAPTURE_OPTIONS"]="rtsp_transport;tcp"
|
|
|
|
gstreamerstr = "tcpclientsrc host=192.168.1.110 port=5000 ! jpegdec ! videoconvert ! appsink"
|
|
|
|
def recvall(sock, count):
|
|
buf = b''
|
|
while count:
|
|
newbuf = sock.recv(count)
|
|
if not newbuf: return None
|
|
buf += newbuf
|
|
count -= len(newbuf)
|
|
return buf
|
|
|
|
TCP_IP = '192.168.1.2' #this address needs to be BBX-mini
|
|
TCP_PORT = 5001
|
|
|
|
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
|
s.bind(( TCP_IP, TCP_PORT))
|
|
s.listen(True)
|
|
conn, addr = s.accept()
|
|
|
|
|
|
#if not capture.isOpened() : print("CANNOT OPEN STREAM")
|
|
#capture = cv2.VideoCapture("vid.mp4")
|
|
keypressNo = 1
|
|
while(True):
|
|
capture = cv2.VideoCapture(gstreamerstr,cv2.CAP_GSTREAMER)
|
|
ret, frame = capture.read()
|
|
if not ret:
|
|
print('fail')
|
|
break
|
|
|
|
frame = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
|
|
variance = variance_of_laplacian(frame)
|
|
|
|
cv2.putText(frame, "{}: {:.2f}".format("Variance:", variance), (10, 30),
|
|
cv2.FONT_HERSHEY_SIMPLEX, 0.8, (0, 0, 255), 3)
|
|
cv2.imshow('frame',frame)
|
|
#cv2.waitKey(0)
|
|
|
|
if cv2.waitKey(70) == ord('v'):
|
|
conn.send("n".encode())
|
|
|
|
length = conn.recv(3)
|
|
stringData = recvall(conn, int(length))
|
|
stringData=stringData.decode()
|
|
print(stringData)
|
|
|
|
frames=[]
|
|
maxVarIdx = 0
|
|
maxVar = 0
|
|
for i in range(30):
|
|
ret, frame = capture.read()
|
|
frame = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY)
|
|
frames.append(frame)
|
|
var = variance_of_laplacian(frame)
|
|
if var > maxVar:
|
|
maxVar = var
|
|
maxVarIdx = i
|
|
|
|
conn.send("n".encode())
|
|
length = conn.recv(3)
|
|
stringData = recvall(conn, int(length))
|
|
stringData=stringData.decode()
|
|
print(stringData)
|
|
|
|
cv2.waitKey(40)
|
|
#test to see if the image with the highest variance gets picked
|
|
#cv2.putText(frame, "{}: {:.2f}".format("Variance:", var), (10, 30), cv2.FONT_HERSHEY_SIMPLEX, 0.8, (0, 0, 255), 3)
|
|
#writeString="imgtest"+str(keypressNo)+"-"+str(i)+".jpg"
|
|
#cv2.imwrite(writeString, frames[i])
|
|
writeString="/home/palko/Documents/Documents/Diplomka/src/online/img"+str(keypressNo)+".png"
|
|
fileString = "/home/palko/Documents/Documents/Diplomka/src/online/img" + str(keypressNo) + ".json"
|
|
myfile = open(fileString, "w")
|
|
a=myfile.write(stringData)
|
|
myfile.close()
|
|
cv2.imwrite(writeString, frames[maxVarIdx])
|
|
keypressNo=keypressNo+1
|
|
|
|
|
|
capture.release()
|
|
cv2.destroyAllWindows()
|