Various fixes

This commit is contained in:
MikeTheWatchGuy 2018-09-07 23:23:45 -04:00
parent ceb09ae62c
commit a968100ab8
4 changed files with 33 additions and 24 deletions

View File

@ -274,7 +274,7 @@ def RealtimeButtons():
import PySimpleGUI as sg import PySimpleGUI as sg
# Make a form, but don't use context manager # Make a form, but don't use context manager
form = sg.FlexForm('Robotics Remote Control', auto_size_text=True) form = sg.FlexForm('Robotics Remote Control', auto_size_text=True, grab_anywhere=False)
form_rows = [[sg.Text('Robotics Remote Control')], form_rows = [[sg.Text('Robotics Remote Control')],
[sg.T(' ' * 10), sg.RealtimeButton('Forward')], [sg.T(' ' * 10), sg.RealtimeButton('Forward')],
@ -431,10 +431,9 @@ def ScriptLauncher():
def ExecuteCommandSubprocess(command, *args): def ExecuteCommandSubprocess(command, *args):
try: try:
# expanded_args = [] expanded_args = []
# for a in args: for a in args:
# expanded_args += a expanded_args += a
expanded_args = [*args]
sp = subprocess.Popen([command,expanded_args], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) sp = subprocess.Popen([command,expanded_args], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
out, err = sp.communicate() out, err = sp.communicate()
if out: if out:
@ -757,8 +756,8 @@ fig_dict = {'Simple Data Entry':SimpleDataEntry, 'Simple Entry Return Data as Di
listbox_values = [key for key in fig_dict.keys()] listbox_values = [key for key in fig_dict.keys()]
while True: while True:
sg.ChangeLookAndFeel('Dark') # sg.ChangeLookAndFeel('Dark')
sg.SetOptions(element_padding=(0,0)) # sg.SetOptions(element_padding=(0,0))
col_listbox = [[sg.Listbox(values=listbox_values, size=(max(len(x) for x in listbox_values),len(listbox_values)), change_submits=True, key='func')], col_listbox = [[sg.Listbox(values=listbox_values, size=(max(len(x) for x in listbox_values),len(listbox_values)), change_submits=True, key='func')],
[sg.SimpleButton('Run', pad=((30,0),0)), sg.Exit(button_color=('white', 'firebrick4'))]] [sg.SimpleButton('Run', pad=((30,0),0)), sg.Exit(button_color=('white', 'firebrick4'))]]

View File

@ -97,9 +97,9 @@ def StatusOutputExample_context_manager():
form.CloseNonBlockingForm() form.CloseNonBlockingForm()
def main(): def main():
StatusOutputExample()
RemoteControlExample() RemoteControlExample()
StatusOutputExample() StatusOutputExample()
StatusOutputExample()
sg.MsgBox('End of non-blocking demonstration') sg.MsgBox('End of non-blocking demonstration')
# StatusOutputExample_context_manager() # StatusOutputExample_context_manager()

View File

@ -8,19 +8,22 @@ import PySimpleGUI as sg
def RemoteControlExample(): def RemoteControlExample():
# Make a form, but don't use context manager # Make a form, but don't use context manager
sg.SetOptions(element_padding=(0,0))
back ='#eeeeee' back ='#eeeeee'
image_forward = 'ButtonGraphics/RobotForward.png' image_forward = 'ButtonGraphics/RobotForward.png'
image_backward = 'ButtonGraphics/RobotBack.png' image_backward = 'ButtonGraphics/RobotBack.png'
image_left = 'ButtonGraphics/RobotLeft.png' image_left = 'ButtonGraphics/RobotLeft.png'
image_right = 'ButtonGraphics/RobotRight.png' image_right = 'ButtonGraphics/RobotRight.png'
sg.SetOptions(border_width=0, button_color=('black', back), background_color=back, element_background_color=back, text_element_background_color=back) sg.SetOptions(border_width=0, button_color=('black', back), background_color=back, element_background_color=back, text_element_background_color=back)
form = sg.FlexForm('Robotics Remote Control', auto_size_text=True, grab_anywhere=False) form = sg.FlexForm('Robotics Remote Control', auto_size_text=True, grab_anywhere=False)
status_display_elem = sg.T('', justification='center', size=(19,1))
form_rows = [[sg.Text('Robotics Remote Control')], form_rows = [[sg.Text('Robotics Remote Control')],
[status_display_elem], [sg.T('', justification='center', size=(19,1), key='status')],
[sg.T(' '*6), sg.RealtimeButton('Forward', image_filename=image_forward)], [ sg.RealtimeButton('Forward', image_filename=image_forward, pad=((50,0),0))],
[ sg.RealtimeButton('Left', image_filename=image_left), sg.T(' '), sg.RealtimeButton('Right', image_filename=image_right)], [ sg.RealtimeButton('Left', image_filename=image_left), sg.RealtimeButton('Right', image_filename=image_right, pad=((50,0), 0))],
[sg.T(' '*6), sg.RealtimeButton('Reverse', image_filename=image_backward)], [ sg.RealtimeButton('Reverse', image_filename=image_backward, pad=((50,0),0))],
[sg.T('')], [sg.T('')],
[sg.Quit(button_color=('black', 'orange'))] [sg.Quit(button_color=('black', 'orange'))]
] ]
@ -37,9 +40,9 @@ def RemoteControlExample():
# This is the code that reads and updates your window # This is the code that reads and updates your window
button, values = form.ReadNonBlocking() button, values = form.ReadNonBlocking()
if button is not None: if button is not None:
status_display_elem.Update(button) form.FindElement('status').Update(button)
else: else:
status_display_elem.Update('') form.FindElement('status').Update('')
# if user clicked quit button OR closed the form using the X, then break out of loop # if user clicked quit button OR closed the form using the X, then break out of loop
if button == 'Quit' or values is None: if button == 'Quit' or values is None:
break break
@ -50,9 +53,9 @@ def RemoteControlExample():
def RemoteControlExample_NoGraphics(): def RemoteControlExample_NoGraphics():
# Make a form, but don't use context manager # Make a form, but don't use context manager
form = sg.FlexForm('Robotics Remote Control', auto_size_text=True, grab_anywhere=False) form = sg.FlexForm('Robotics Remote Control', auto_size_text=True, grab_anywhere=False)
status_display_elem = sg.T('', justification='center', size=(19,1))
form_rows = [[sg.Text('Robotics Remote Control', justification='center')], form_rows = [[sg.Text('Robotics Remote Control', justification='center')],
[status_display_elem], [sg.T('', justification='center', size=(19,1), key='status')],
[sg.T(' '*8), sg.RealtimeButton('Forward')], [sg.T(' '*8), sg.RealtimeButton('Forward')],
[ sg.RealtimeButton('Left'), sg.T(' '), sg.RealtimeButton('Right')], [ sg.RealtimeButton('Left'), sg.T(' '), sg.RealtimeButton('Right')],
[sg.T(' '*8), sg.RealtimeButton('Reverse')], [sg.T(' '*8), sg.RealtimeButton('Reverse')],
@ -72,9 +75,9 @@ def RemoteControlExample_NoGraphics():
# This is the code that reads and updates your window # This is the code that reads and updates your window
button, values = form.ReadNonBlocking() button, values = form.ReadNonBlocking()
if button is not None: if button is not None:
status_display_elem.Update(button) form.FindElement('status').Update(button)
else: else:
status_display_elem.Update('') form.FindElement('status').Update('')
# if user clicked quit button OR closed the form using the X, then break out of loop # if user clicked quit button OR closed the form using the X, then break out of loop
if button == 'Quit' or values is None: if button == 'Quit' or values is None:
break break
@ -89,7 +92,7 @@ def main():
RemoteControlExample_NoGraphics() RemoteControlExample_NoGraphics()
# Uncomment to get the fancy graphics version. Be sure and download the button images! # Uncomment to get the fancy graphics version. Be sure and download the button images!
RemoteControlExample() RemoteControlExample()
sg.MsgBox('End of non-blocking demonstration') # sg.Popup('End of non-blocking demonstration')
if __name__ == '__main__': if __name__ == '__main__':

View File

@ -3,12 +3,16 @@ import glob
import ntpath import ntpath
import subprocess import subprocess
LOCATION_OF_YOUR_SCRIPTS = 'C:/Python/PycharmProjects/GooeyGUI/' LOCATION_OF_YOUR_SCRIPTS = ''
# Execute the command. Will not see the output from the command until it completes. # Execute the command. Will not see the output from the command until it completes.
def execute_command_blocking(command, *args): def execute_command_blocking(command, *args):
expanded_args = []
for a in args:
expanded_args.append(a)
# expanded_args += a
try: try:
sp = subprocess.Popen([command,*args], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) sp = subprocess.Popen([command,expanded_args], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
out, err = sp.communicate() out, err = sp.communicate()
if out: if out:
print(out.decode("utf-8")) print(out.decode("utf-8"))
@ -20,8 +24,11 @@ def execute_command_blocking(command, *args):
# Executes command and immediately returns. Will not see anything the script outputs # Executes command and immediately returns. Will not see anything the script outputs
def execute_command_nonblocking(command, *args): def execute_command_nonblocking(command, *args):
expanded_args = []
for a in args:
expanded_args += a
try: try:
sp = subprocess.Popen([command,*args], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE) sp = subprocess.Popen([command,expanded_args], shell=True, stdout=subprocess.PIPE, stderr=subprocess.PIPE)
except: pass except: pass
def Launcher2(): def Launcher2():