Merge pull request #1346 from PySimpleGUI/Dev-latest

Dev latest
This commit is contained in:
MikeTheWatchGuy 2019-04-25 17:29:36 -04:00 committed by GitHub
commit 9389982c8a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 11 deletions

View File

@ -1,5 +1,5 @@
# import PySimpleGUIWeb as sg import PySimpleGUIWeb as sg
import PySimpleGUI as sg # import PySimpleGUI as sg
import pymunk import pymunk
import random import random
import socket import socket

View File

@ -364,6 +364,7 @@ class Element():
# ------------------------- REMI CHANGED CALLBACK ----------------------- # ------------------------- REMI CHANGED CALLBACK -----------------------
# called when a widget has changed and the element has events enabled # called when a widget has changed and the element has events enabled
def ChangedCallback(self, widget:remi.Widget, *args): def ChangedCallback(self, widget:remi.Widget, *args):
print(f'Callback {args}')
self.ParentForm.LastButtonClicked = self.Key if self.Key is not None else '' self.ParentForm.LastButtonClicked = self.Key if self.Key is not None else ''
self.ParentForm.MessageQueue.put(self.ParentForm.LastButtonClicked) self.ParentForm.MessageQueue.put(self.ParentForm.LastButtonClicked)
@ -1810,8 +1811,8 @@ class Graph(Element):
print('Call Window.Finalize() prior to this operation') print('Call Window.Finalize() prior to this operation')
return None return None
rpoint = remi.gui.SvgRectangle(converted_top_left[0], converted_top_left[1], bottom_right[0]-top_left[0], top_left[1]-bottom_right[1]) rpoint = remi.gui.SvgRectangle(converted_top_left[0], converted_top_left[1], bottom_right[0]-top_left[0], bottom_right[1]-top_left[1])
rpoint.set_stroke(color=line_color) rpoint.set_stroke(width=1, color=line_color)
rpoint.set_fill(fill_color) rpoint.set_fill(fill_color)
self.SvgGroup.append([rpoint,]) self.SvgGroup.append([rpoint,])
return rpoint return rpoint
@ -1846,16 +1847,25 @@ class Graph(Element):
print('Call Window.Finalize() prior to this operation') print('Call Window.Finalize() prior to this operation')
return None return None
rpoint = remi.gui.SvgImage(image_source, converted_point[0], converted_point[0], size[0], size[1]) rpoint = remi.gui.SvgImage('', converted_point[0], converted_point[0], size[0], size[1])
if type(image_source) is bytes or len(image_source) > 200: if type(image_source) is bytes or len(image_source) > 200:
rpoint.set_image("data:image/svg+xml;base64,%s"%image_source) rpoint.set_image("data:image/svg;base64,%s"%image_source)
# img_string = "data:image/svg+xml;base64,%s"%image_source
else: else:
mimetype, encoding = mimetypes.guess_type(image_source)
with open(image_source, 'rb') as f: with open(image_source, 'rb') as f:
data = f.read() data = f.read()
print(data) # rpoint.set_image("data:%s;base64,%s" % (mimetype, base64.b64encode(data)))
rpoint.set_image("data:image/svg+xml;base64,%s"% base64.b64encode(data)) b64 = base64.b64encode(data)
b64_str = b64.decode("utf-8")
image_string = "data:image/svg;base64,%s"%b64_str
rpoint.set_image(image_string)
# rpoint.set_image("data:image/svg;base64,%s"% base64.b64encode(data))
# rpoint.set_image(image_source) # rpoint.set_image(image_source)
# img_string = "data:image/svg+xml;base64,%s"% base64.b64encode(data)
self.SvgGroup.append([rpoint,]) self.SvgGroup.append([rpoint,])
# rpoint.set_image(image_source)
# self.SvgGroup.redraw() # self.SvgGroup.redraw()
# image_widget.attributes['x'] = converted_point[0] # image_widget.attributes['x'] = converted_point[0]
# image_widget.attributes['y'] = converted_point[1] # image_widget.attributes['y'] = converted_point[1]
@ -1891,8 +1901,8 @@ class Graph(Element):
print('*** WARNING - The Graph element has not been finalized and cannot be drawn upon ***') print('*** WARNING - The Graph element has not been finalized and cannot be drawn upon ***')
print('Call Window.Finalize() prior to this operation') print('Call Window.Finalize() prior to this operation')
return None return None
cur_x = float(self.SvgGroup.attributes['x']) cur_x = float(self.SvgGroup.attributes['cx'])
cur_y = float(self.SvgGroup.attributes['y']) cur_y = float(self.SvgGroup.attributes['cy'])
self.SvgGroup.set_position(cur_x - x_direction,cur_y - y_direction) self.SvgGroup.set_position(cur_x - x_direction,cur_y - y_direction)
self.SvgGroup.redraw() self.SvgGroup.redraw()
@ -1920,6 +1930,8 @@ class Graph(Element):
# figure.empty() # figure.empty()
cur_x = float(figure.attributes['x']) cur_x = float(figure.attributes['x'])
cur_y = float(figure.attributes['y']) cur_y = float(figure.attributes['y'])
print(f'cur_x cur_y = {cur_x}, {cur_y}')
figure.set_position(cur_x - x_direction,cur_y - y_direction) figure.set_position(cur_x - x_direction,cur_y - y_direction)
figure.redraw() figure.redraw()