Merge pull request #3109 from PySimpleGUI/Dev-latest
Added cprint, Multiline added write_only parameter, changed Graph.dra…
This commit is contained in:
commit
8218ed2698
|
@ -1,6 +1,6 @@
|
||||||
#usr/bin/python3
|
#usr/bin/python3
|
||||||
|
|
||||||
version = __version__ = "0.39.0.3 Unreleased\n , VSeparator added (spelling error), added default key for one_line_progress_meter, auto-add keys to tables & trees"
|
version = __version__ = "0.39.0.4 Unreleased\n , VSeparator added (spelling error), added default key for one_line_progress_meter, auto-add keys to tables & trees, Graph.draw_image now uses image_data property instead of calling set_image"
|
||||||
|
|
||||||
port = 'PySimpleGUIWeb'
|
port = 'PySimpleGUIWeb'
|
||||||
|
|
||||||
|
@ -877,7 +877,7 @@ class Spin(Element):
|
||||||
class Multiline(Element):
|
class Multiline(Element):
|
||||||
def __init__(self, default_text='', enter_submits=False, disabled=False, autoscroll=False, size=(None, None),
|
def __init__(self, default_text='', enter_submits=False, disabled=False, autoscroll=False, size=(None, None),
|
||||||
auto_size_text=None, background_color=None, text_color=None, change_submits=False, enable_events=False, do_not_clear=True,
|
auto_size_text=None, background_color=None, text_color=None, change_submits=False, enable_events=False, do_not_clear=True,
|
||||||
key=None, focus=False, font=None, pad=None, tooltip=None, visible=True, size_px=(None,None)):
|
key=None, write_only=False, focus=False, font=None, pad=None, tooltip=None, visible=True, size_px=(None,None)):
|
||||||
'''
|
'''
|
||||||
Multiline Element
|
Multiline Element
|
||||||
:param default_text:
|
:param default_text:
|
||||||
|
@ -904,6 +904,7 @@ class Multiline(Element):
|
||||||
self.Autoscroll = autoscroll
|
self.Autoscroll = autoscroll
|
||||||
self.Disabled = disabled
|
self.Disabled = disabled
|
||||||
self.ChangeSubmits = change_submits or enable_events
|
self.ChangeSubmits = change_submits or enable_events
|
||||||
|
self.WriteOnly = write_only
|
||||||
if size[0] is not None and size[0] < 100:
|
if size[0] is not None and size[0] < 100:
|
||||||
size = size[0]*DEFAULT_PIXELS_TO_CHARS_SCALING[0], size[1]*DEFAULT_PIXELS_TO_CHARS_SCALING[1]
|
size = size[0]*DEFAULT_PIXELS_TO_CHARS_SCALING[0], size[1]*DEFAULT_PIXELS_TO_CHARS_SCALING[1]
|
||||||
self.Widget = None # type: remi.gui.TextInput
|
self.Widget = None # type: remi.gui.TextInput
|
||||||
|
@ -952,6 +953,9 @@ class Multiline(Element):
|
||||||
|
|
||||||
update = Update
|
update = Update
|
||||||
|
|
||||||
|
ML = Multiline
|
||||||
|
MLine = Multiline
|
||||||
|
|
||||||
|
|
||||||
# ---------------------------------------------------------------------- #
|
# ---------------------------------------------------------------------- #
|
||||||
# Multiline Output #
|
# Multiline Output #
|
||||||
|
@ -1742,7 +1746,8 @@ class Graph(Element):
|
||||||
rpoint = remi.gui.SvgImage('', 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;base64,%s"%image_source)
|
# rpoint.set_image("data:image/svg;base64,%s"%image_source)
|
||||||
|
rpoint.image_data = "data:image/svg;base64,%s"%image_source
|
||||||
else:
|
else:
|
||||||
mimetype, encoding = mimetypes.guess_type(image_source)
|
mimetype, encoding = mimetypes.guess_type(image_source)
|
||||||
with open(image_source, 'rb') as f:
|
with open(image_source, 'rb') as f:
|
||||||
|
@ -1750,7 +1755,8 @@ class Graph(Element):
|
||||||
b64 = base64.b64encode(data)
|
b64 = base64.b64encode(data)
|
||||||
b64_str = b64.decode("utf-8")
|
b64_str = b64.decode("utf-8")
|
||||||
image_string = "data:image/svg;base64,%s"%b64_str
|
image_string = "data:image/svg;base64,%s"%b64_str
|
||||||
rpoint.set_image(image_string)
|
# rpoint.set_image(image_string)
|
||||||
|
rpoint.image_data = image_string
|
||||||
self.SvgGroup.append([rpoint,])
|
self.SvgGroup.append([rpoint,])
|
||||||
rpoint.redraw()
|
rpoint.redraw()
|
||||||
self.SvgGroup.redraw()
|
self.SvgGroup.redraw()
|
||||||
|
@ -3934,6 +3940,8 @@ def BuildResultsForSubform(form, initialize_only, top_level_form):
|
||||||
value = element.Widget.get_value()
|
value = element.Widget.get_value()
|
||||||
elif element.Type == ELEM_TYPE_INPUT_MULTILINE:
|
elif element.Type == ELEM_TYPE_INPUT_MULTILINE:
|
||||||
element = element # type: Multiline
|
element = element # type: Multiline
|
||||||
|
if element.WriteOnly:
|
||||||
|
continue
|
||||||
value = element.Widget.get_value()
|
value = element.Widget.get_value()
|
||||||
elif element.Type == ELEM_TYPE_TAB_GROUP:
|
elif element.Type == ELEM_TYPE_TAB_GROUP:
|
||||||
try:
|
try:
|
||||||
|
@ -5694,6 +5702,133 @@ def EasyPrintClose():
|
||||||
_easy_print_data = None
|
_easy_print_data = None
|
||||||
|
|
||||||
|
|
||||||
|
# d8b 888
|
||||||
|
# Y8P 888
|
||||||
|
# 888
|
||||||
|
# .d8888b 88888b. 888d888 888 88888b. 888888
|
||||||
|
# d88P" 888 "88b 888P" 888 888 "88b 888
|
||||||
|
# 888 888 888 888 888 888 888 888
|
||||||
|
# Y88b. 888 d88P 888 888 888 888 Y88b.
|
||||||
|
# "Y8888P 88888P" 888 888 888 888 "Y888
|
||||||
|
# 888
|
||||||
|
# 888
|
||||||
|
# 888
|
||||||
|
|
||||||
|
|
||||||
|
CPRINT_DESTINATION_WINDOW = None
|
||||||
|
CPRINT_DESTINATION_MULTILINE_ELMENT_KEY = None
|
||||||
|
|
||||||
|
def cprint_set_output_destination(window, multiline_key):
|
||||||
|
"""
|
||||||
|
Sets up the color print (cprint) output destination
|
||||||
|
:param window: The window that the cprint call will route the output to
|
||||||
|
:type window: (Window)
|
||||||
|
:param multiline_key: Key for the Multiline Element where output will be sent
|
||||||
|
:type multiline_key: (Any)
|
||||||
|
:return: None
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
|
|
||||||
|
global CPRINT_DESTINATION_WINDOW, CPRINT_DESTINATION_MULTILINE_ELMENT_KEY
|
||||||
|
|
||||||
|
CPRINT_DESTINATION_WINDOW = window
|
||||||
|
CPRINT_DESTINATION_MULTILINE_ELMENT_KEY = multiline_key
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# def cprint(*args, **kwargs):
|
||||||
|
def cprint(*args, end=None, sep=' ', text_color=None, t=None, background_color=None, b=None, colors=None, c=None, window=None, key=None):
|
||||||
|
"""
|
||||||
|
Color print to a multiline element in a window of your choice.
|
||||||
|
Must have EITHER called cprint_set_output_destination prior to making this call so that the
|
||||||
|
window and element key can be saved and used here to route the output, OR used the window
|
||||||
|
and key parameters to the cprint function to specicy these items.
|
||||||
|
|
||||||
|
args is a variable number of things you want to print.
|
||||||
|
|
||||||
|
end - The end char to use just like print uses
|
||||||
|
sep - The separation character like print uses
|
||||||
|
text_color - The color of the text
|
||||||
|
key - overrides the previously defined Multiline key
|
||||||
|
window - overrides the previously defined window to output to
|
||||||
|
background_color - The color of the background
|
||||||
|
colors -(str, str) or str. A combined text/background color definition in a single parameter
|
||||||
|
|
||||||
|
There are also "aliases" for text_color, background_color and colors (t, b, c)
|
||||||
|
t - An alias for color of the text (makes for shorter calls)
|
||||||
|
b - An alias for the background_color parameter
|
||||||
|
c - Tuple[str, str] - "shorthand" way of specifying color. (foreground, backgrouned)
|
||||||
|
c - str - can also be a string of the format "foreground on background" ("white on red")
|
||||||
|
|
||||||
|
With the aliases it's possible to write the same print but in more compact ways:
|
||||||
|
cprint('This will print white text on red background', c=('white', 'red'))
|
||||||
|
cprint('This will print white text on red background', c='white on red')
|
||||||
|
cprint('This will print white text on red background', text_color='white', background_color='red')
|
||||||
|
cprint('This will print white text on red background', t='white', b='red')
|
||||||
|
|
||||||
|
:param *args: stuff to output
|
||||||
|
:type *args: (Any)
|
||||||
|
:param text_color: Color of the text
|
||||||
|
:type text_color: (str)
|
||||||
|
:param background_color: The background color of the line
|
||||||
|
:type background_color: (str)
|
||||||
|
:param colors: Either a tuple or a string that has both the text and background colors
|
||||||
|
:type colors: (str) or Tuple[str, str]
|
||||||
|
:param t: Color of the text
|
||||||
|
:type t: (str)
|
||||||
|
:param b: The background color of the line
|
||||||
|
:type b: (str)
|
||||||
|
:param c: Either a tuple or a string that has both the text and background colors
|
||||||
|
:type c: (str) or Tuple[str, str]
|
||||||
|
:param end: end character
|
||||||
|
:type end: (str)
|
||||||
|
:param sep: separator character
|
||||||
|
:type sep: (str)
|
||||||
|
:param key: key of multiline to output to (if you want to override the one previously set)
|
||||||
|
:type key: (Any)
|
||||||
|
:param window: Window containing the multiline to output to (if you want to override the one previously set)
|
||||||
|
:type window: (Window)
|
||||||
|
:return: None
|
||||||
|
:rtype: None
|
||||||
|
"""
|
||||||
|
|
||||||
|
destination_key = CPRINT_DESTINATION_MULTILINE_ELMENT_KEY if key is None else key
|
||||||
|
destination_window = window or CPRINT_DESTINATION_WINDOW
|
||||||
|
|
||||||
|
if (destination_window is None and window is None) or (destination_key is None and key is None):
|
||||||
|
print('** Warning ** Attempting to perform a cprint without a valid window & key',
|
||||||
|
'Will instead print on Console',
|
||||||
|
'You can specify window and key in this cprint call, or set ahead of time using cprint_set_output_destination')
|
||||||
|
print(*args)
|
||||||
|
return
|
||||||
|
|
||||||
|
kw_text_color = text_color or t
|
||||||
|
kw_background_color = background_color or b
|
||||||
|
dual_color = colors or c
|
||||||
|
try:
|
||||||
|
if isinstance(dual_color, tuple):
|
||||||
|
kw_text_color = dual_color[0]
|
||||||
|
kw_background_color = dual_color[1]
|
||||||
|
elif isinstance(dual_color, str):
|
||||||
|
kw_text_color = dual_color.split(' on ')[0]
|
||||||
|
kw_background_color = dual_color.split(' on ')[1]
|
||||||
|
except Exception as e:
|
||||||
|
print('* cprint warning * you messed up with color formatting', e)
|
||||||
|
|
||||||
|
mline = destination_window.find_element(destination_key, silent_on_error=True) # type: Multiline
|
||||||
|
try:
|
||||||
|
# mline = destination_window[destination_key] # type: Multiline
|
||||||
|
if end is None:
|
||||||
|
mline.print(*args, text_color=kw_text_color, background_color=kw_background_color, end='', sep=sep)
|
||||||
|
mline.print('')
|
||||||
|
else:
|
||||||
|
mline.print(*args,text_color=kw_text_color, background_color=kw_background_color, end=end, sep=sep)
|
||||||
|
except Exception as e:
|
||||||
|
print('** cprint error trying to print to the multiline. Printing to console instead **', e)
|
||||||
|
print(*args, end=end, sep=sep)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# ------------------------------------------------------------------------------------------------ #
|
# ------------------------------------------------------------------------------------------------ #
|
||||||
# A print-like call that can be used to output to a multiline element as if it's an Output element #
|
# A print-like call that can be used to output to a multiline element as if it's an Output element #
|
||||||
# ------------------------------------------------------------------------------------------------ #
|
# ------------------------------------------------------------------------------------------------ #
|
||||||
|
|
Loading…
Reference in New Issue