PySimpleGUI/DemoPrograms/Demo_OpenCV.py

80 lines
2.7 KiB
Python
Raw Normal View History

2018-09-27 20:24:09 +00:00
#!/usr/bin/env python
import PySimpleGUI as sg
2018-09-06 20:54:56 +00:00
from PIL import Image
import cv2 as cv
import io
2018-09-06 20:54:56 +00:00
"""
Demo program to open and play a file using OpenCV
It's main purpose is to show you:
1. How to get a frame at a time from a video file using OpenCV
2. How to display an image in a PySimpleGUI Window
2018-09-06 20:54:56 +00:00
For added fun, you can reposition the video using the slider.
2018-09-06 20:54:56 +00:00
"""
2018-09-06 20:54:56 +00:00
def main():
# ---===--- Get the filename --- #
filename = sg.popup_get_file('Filename to play')
2018-09-06 20:54:56 +00:00
if filename is None:
return
2018-09-06 20:54:56 +00:00
vidFile = cv.VideoCapture(filename)
# ---===--- Get some Stats --- #
num_frames = vidFile.get(cv.CAP_PROP_FRAME_COUNT)
fps = vidFile.get(cv.CAP_PROP_FPS)
2019-12-24 23:52:47 +00:00
sg.theme('Black')
2018-09-06 20:54:56 +00:00
# ---===--- define the window layout --- #
layout = [[sg.Text('OpenCV Demo', size=(15, 1), font='Helvetica 20')],
[sg.Image(filename='', key='-image-')],
[sg.Slider(range=(0, num_frames),
size=(60, 10), orientation='h', key='-slider-')],
[sg.Button('Exit', size=(7, 1), pad=((600, 0), 3), font='Helvetica 14')]]
2018-09-06 20:54:56 +00:00
# create the window and show it without the plot
2020-05-15 02:45:21 +00:00
window = sg.Window('Demo Application - OpenCV Integration', layout, no_titlebar=False, location=(0, 0))
2018-09-06 20:54:56 +00:00
# locate the elements we'll be updating. Does the search only 1 time
image_elem = window['-image-']
slider_elem = window['-slider-']
2018-09-06 20:54:56 +00:00
# ---===--- LOOP through video file by frame --- #
cur_frame = 0
2018-09-06 20:54:56 +00:00
while vidFile.isOpened():
event, values = window.read(timeout=0)
if event in ('Exit', None):
break
2018-09-06 20:54:56 +00:00
ret, frame = vidFile.read()
if not ret: # if out of data stop looping
break
# if someone moved the slider manually, the jump to that frame
if int(values['-slider-']) != cur_frame-1:
cur_frame = int(values['-slider-'])
vidFile.set(cv.CAP_PROP_POS_FRAMES, cur_frame)
slider_elem.update(cur_frame)
cur_frame += 1
2018-09-06 20:54:56 +00:00
imgbytes = cv.imencode('.png', frame)[1].tobytes() # ditto
image_elem.update(data=imgbytes)
#############
# | | #
# | | #
# |_| #
# __ __ #
# \ \ / / #
# \ V / #
# \_/ #
""" #############
# This was another way updates were being done, but seems slower than the above
img = Image.fromarray(frame) # create PIL image from frame
bio = io.BytesIO() # a binary memory resident stream
img.save(bio, format= 'PNG') # save image as png to it
imgbytes = bio.getvalue() # this can be used by OpenCV hopefully
image_elem.update(data=imgbytes)
"""
2018-09-06 20:54:56 +00:00
main()