From 18ce3337e67d83c01e683d0fbf6fcd98706b1808 Mon Sep 17 00:00:00 2001 From: PySimpleGUI Date: Mon, 7 Oct 2019 18:08:06 -0400 Subject: [PATCH] Fix for flickering image in OpenCV demos!!!! --- PySimpleGUIWeb/PySimpleGUIWeb.py | 72 ++++++++++++++++---------------- 1 file changed, 37 insertions(+), 35 deletions(-) diff --git a/PySimpleGUIWeb/PySimpleGUIWeb.py b/PySimpleGUIWeb/PySimpleGUIWeb.py index 09ba3617..c13d90ed 100644 --- a/PySimpleGUIWeb/PySimpleGUIWeb.py +++ b/PySimpleGUIWeb/PySimpleGUIWeb.py @@ -1443,39 +1443,39 @@ class Image(Element): +# class SuperImageOld(remi.gui.Image): +# def __init__(self, file_path_name=None, **kwargs): +# image = file_path_name +# super(SuperImage, self).__init__(image, **kwargs) +# +# self.imagedata = None +# self.mimetype = None +# self.encoding = None +# if image is None: +# return +# self.load(image) +# +# def load(self, file_path_name): +# if type(file_path_name) is bytes or len(file_path_name) > 200: +# try: +# self.imagedata = base64.b64decode(file_path_name, validate=True) +# except binascii.Error: +# self.imagedata = file_path_name +# else: +# self.mimetype, self.encoding = mimetypes.guess_type(file_path_name) +# with open(file_path_name, 'rb') as f: +# self.imagedata = f.read() +# self.refresh() +# +# def refresh(self): +# i = int(time.time() * 1e6) +# self.attributes['src'] = "/%s/get_image_data?update_index=%d" % (id(self), i) +# +# def get_image_data(self, update_index): +# headers = {'Content-type': self.mimetype if self.mimetype else 'application/octet-stream'} +# return [self.imagedata, headers] + class SuperImage(remi.gui.Image): - def __init__(self, file_path_name=None, **kwargs): - image = file_path_name - super(SuperImage, self).__init__(image, **kwargs) - - self.imagedata = None - self.mimetype = None - self.encoding = None - if image is None: - return - self.load(image) - - def load(self, file_path_name): - if type(file_path_name) is bytes or len(file_path_name) > 200: - try: - self.imagedata = base64.b64decode(file_path_name, validate=True) - except binascii.Error: - self.imagedata = file_path_name - else: - self.mimetype, self.encoding = mimetypes.guess_type(file_path_name) - with open(file_path_name, 'rb') as f: - self.imagedata = f.read() - self.refresh() - - def refresh(self): - i = int(time.time() * 1e6) - self.attributes['src'] = "/%s/get_image_data?update_index=%d" % (id(self), i) - - def get_image_data(self, update_index): - headers = {'Content-type': self.mimetype if self.mimetype else 'application/octet-stream'} - return [self.imagedata, headers] - -class SuperImagenew(remi.gui.Image): def __init__(self, file_path_name=None, **kwargs): """ This new app_instance variable is causing lots of problems. I do not know the value of the App @@ -1496,7 +1496,9 @@ class SuperImagenew(remi.gui.Image): def load(self, file_path_name): if type(file_path_name) is bytes or len(file_path_name) > 200: - self.imagedata = base64.b64decode(file_path_name) + # print("image data") + self.mimetype = 'image/png' + self.imagedata = file_path_name #base64.b64decode(file_path_name) else: self.mimetype, self.encoding = mimetypes.guess_type(file_path_name) with open(file_path_name, 'rb') as f: @@ -1504,6 +1506,7 @@ class SuperImagenew(remi.gui.Image): self.refresh() def refresh(self): + # print("refresh") i = int(time.time() * 1e6) # self.app_instance.execute_javascript(""" if Window.App is not None: @@ -1521,11 +1524,10 @@ class SuperImagenew(remi.gui.Image): """ % {'id': id(self), 'frame_index':i}) def get_image_data(self, update_index): + # print("get image data") headers = {'Content-type': self.mimetype if self.mimetype else 'application/octet-stream'} return [self.imagedata, headers] - - # ---------------------------------------------------------------------- # # Graph # # ---------------------------------------------------------------------- #