2018-09-27 20:24:09 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
import sys
|
2018-09-28 18:57:37 +00:00
|
|
|
if sys.version_info[0] >= 3:
|
2018-09-27 20:24:09 +00:00
|
|
|
import PySimpleGUI as sg
|
2018-09-28 18:57:37 +00:00
|
|
|
else:
|
|
|
|
import PySimpleGUI27 as sg
|
2018-09-06 20:54:56 +00:00
|
|
|
import cv2 as cv
|
|
|
|
from PIL import Image
|
|
|
|
import tempfile
|
|
|
|
import os
|
2018-09-24 22:01:00 +00:00
|
|
|
from sys import exit as exit
|
2018-09-06 20:54:56 +00:00
|
|
|
|
|
|
|
"""
|
|
|
|
Demo program to open and play a file using OpenCV
|
|
|
|
Unsure how to get the frames coming from OpenCV into the right format, so saving each frame to
|
|
|
|
a temp file. Clearly... clearly... this is not the optimal solution and one is being searched for now.
|
|
|
|
|
|
|
|
Until then enjoy it working somewhat slowly.
|
|
|
|
"""
|
|
|
|
|
2018-09-06 22:02:37 +00:00
|
|
|
|
2018-09-06 20:54:56 +00:00
|
|
|
def main():
|
2018-09-24 22:01:00 +00:00
|
|
|
# filename = 'C:/Python/MIDIVideo/PlainVideos/- 08-30 Ted Talk/TED Talk Short - Video+.mp4'
|
|
|
|
filename = sg.PopupGetFile('Filename to play')
|
2018-09-06 20:54:56 +00:00
|
|
|
if filename is None:
|
|
|
|
exit(69)
|
|
|
|
vidFile = cv.VideoCapture(filename)
|
|
|
|
# ---===--- Get some Stats --- #
|
|
|
|
num_frames = vidFile.get(cv.CAP_PROP_FRAME_COUNT)
|
|
|
|
fps = vidFile.get(cv.CAP_PROP_FPS)
|
|
|
|
|
|
|
|
sg.ChangeLookAndFeel('Dark')
|
|
|
|
|
2018-09-24 22:01:00 +00:00
|
|
|
# define the window layout
|
2018-09-06 22:02:37 +00:00
|
|
|
layout = [[sg.Text('OpenCV Demo', size=(15, 1),pad=((510,0),3), justification='center', font='Helvetica 20')],
|
2018-09-06 20:54:56 +00:00
|
|
|
[sg.Image(filename='', key='image')],
|
2018-09-06 22:02:37 +00:00
|
|
|
[sg.Slider(range=(0, num_frames), size=(115, 10), orientation='h', key='slider')],
|
2018-09-24 22:01:00 +00:00
|
|
|
[sg.ReadButton('Exit', size=(10, 2), pad=((600, 0), 3), font='Helvetica 14')]]
|
2018-09-06 20:54:56 +00:00
|
|
|
|
2018-09-24 22:01:00 +00:00
|
|
|
# create the window and show it without the plot
|
|
|
|
window = sg.Window('Demo Application - OpenCV Integration', no_titlebar=False, location=(0,0))
|
|
|
|
window.Layout(layout)
|
|
|
|
window.ReadNonBlocking()
|
2018-09-06 20:54:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
# ---===--- LOOP through video file by frame --- #
|
|
|
|
i = 0
|
|
|
|
temp_filename = next(tempfile._get_candidate_names()) + '.png'
|
|
|
|
while vidFile.isOpened():
|
2018-09-24 22:01:00 +00:00
|
|
|
button, values = window.ReadNonBlocking()
|
2018-09-06 20:54:56 +00:00
|
|
|
if button is 'Exit' or values is None:
|
|
|
|
os.remove(temp_filename)
|
|
|
|
exit(69)
|
|
|
|
ret, frame = vidFile.read()
|
|
|
|
if not ret: # if out of data stop looping
|
|
|
|
break
|
|
|
|
|
2018-09-24 22:01:00 +00:00
|
|
|
window.FindElement('slider').Update(i)
|
2018-09-06 20:54:56 +00:00
|
|
|
i += 1
|
|
|
|
|
|
|
|
with open(temp_filename, 'wb') as f:
|
|
|
|
Image.fromarray(frame).save(temp_filename, 'PNG') # save the PIL image as file
|
2018-09-24 22:01:00 +00:00
|
|
|
window.FindElement('image').Update(filename=temp_filename)
|
2018-09-06 20:54:56 +00:00
|
|
|
|
|
|
|
|
|
|
|
main()
|