forked from magicbear/OscilloVideo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoscilloscope.py
124 lines (100 loc) · 3.28 KB
/
oscilloscope.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
import soundcard as sc
import numpy as np
import cv2
import threading
import time
import math
terminate_program = 0
class AudioOutputThread(threading.Thread):
def __init__(self):
"""
初始化
"""
threading.Thread.__init__(self)
self.data = None
def run(self):
t1 = time.time()
# speakers = sc.all_speakers()
default_speaker = sc.default_speaker()
while terminate_program == 0:
if self.data is None:
time.sleep(0.01)
continue
nd = self.data
self.data = None
print(time.time()-t1, nd.shape)
try:
# speakers[2].play(nd, samplerate=96000)
default_speaker.play(nd, samplerate=96000)
except:
pass
at = AudioOutputThread()
at.start()
data = np.zeros((100000,2), np.float32)
p = 0
cv2.namedWindow("test")
cv2.namedWindow("test2")
cv2.resizeWindow("test", 640, 480)
cv2.resizeWindow("test", 640, 480)
cv2.moveWindow("test",1280,280)
cv2.moveWindow("test2",1280,600)
cv2.waitKey(500)
cap = cv2.VideoCapture("test.mp4")
n = 0
fps = 30
video_fps = 30
pframe_samples = math.floor(96000 / fps)
t = time.time()
while cap.isOpened():
res, img = cap.read()
n = n + 1
pts = n / video_fps
pass_time = (time.time() - t)
if pts < pass_time:
continue
img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# img = cv2.resize(img, (int(0.6 * img.shape[1]),int(0.6 * img.shape[0])))
edges = cv2.Canny(img,100,200)
ret,thresh = cv2.threshold(edges, 128, 255, cv2.THRESH_BINARY | cv2.THRESH_OTSU)
# contours, hierarchy = cv2.findContours(thresh, cv2.RETR_EXTERNAL , cv2.CHAIN_APPROX_TC89_L1)
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_EXTERNAL , cv2.CHAIN_APPROX_NONE)
condatas = np.array([], dtype=np.int32)
dsize = 0
for i in range(0, len(contours)):
if contours[i].shape[0] < 3:
continue
dsize += contours[i].shape[0]
condatas=np.append(condatas, contours[i][:,0,:])
condatas = condatas.reshape((-1,2))
voldatas = condatas.astype(np.float32)
wh = np.max(img.shape)
voldatas[:,0] *= 1 / wh * 1.2
voldatas[:,0] -= 0.6
voldatas[:,1] /= wh / -1.2
voldatas[:,1] += 0.6
last_p = p
osc_image = np.zeros((img.shape[0], img.shape[1], 1), np.uint8)
if dsize > 0:
point_size = math.floor(pframe_samples / dsize)
for i in range(0, pframe_samples):
p = int(i / pframe_samples * dsize)
px = voldatas[p, 0]
py = voldatas[p, 1]
osc_image[condatas[p,1],condatas[p,0],0] = 255
data[last_p+i,0] = px
data[last_p+i,1] = py
else:
data[last_p:last_p+pframe_samples,:] = 0
p = last_p+pframe_samples
if p >= pframe_samples * 2:
at.data = np.copy(data[0:p,:])
p = 0
cv2.putText(osc_image, "%d / %d" % (pframe_samples, dsize), (40, 25), cv2.FONT_HERSHEY_SIMPLEX, 1, 255, 1, cv2.LINE_AA)
cv2.imshow("test", thresh)
cv2.imshow("test2", osc_image)
# print("pts => ",pts, (time.time() - t))
# time.sleep(pts - pass_time)
if pts > pass_time:
if int((pts - pass_time)*1000) > 0:
cv2.waitKey(int((pts - pass_time)*1000))
terminate_program = 1