Merge pull request #246 from MikeTheWatchGuy/Dev-latest
New element! Frame - A frame with a label, Demo program from Frame, …
This commit is contained in:
commit
2ac081b3b6
|
@ -0,0 +1,69 @@
|
||||||
|
import time
|
||||||
|
import random
|
||||||
|
import PySimpleGUI as sg
|
||||||
|
|
||||||
|
|
||||||
|
STEP_SIZE=1
|
||||||
|
SAMPLES = 300
|
||||||
|
SAMPLE_MAX = 300
|
||||||
|
CANVAS_SIZE = (300,300)
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
global g_exit, g_response_time
|
||||||
|
|
||||||
|
with sg.FlexForm('Enter graph size') as form:
|
||||||
|
layout = [[sg.T('Enter width, height of graph')],
|
||||||
|
[sg.In(size=(6, 1)), sg.In(size=(6, 1))],
|
||||||
|
[sg.Ok(), sg.Cancel()]]
|
||||||
|
|
||||||
|
b,v = form.LayoutAndRead(layout)
|
||||||
|
if b is None or b == 'Cancel':
|
||||||
|
exit(69)
|
||||||
|
w, h = int(v[0]), int(v[1])
|
||||||
|
CANVAS_SIZE = (w,h)
|
||||||
|
|
||||||
|
# start ping measurement thread
|
||||||
|
|
||||||
|
sg.ChangeLookAndFeel('Black')
|
||||||
|
sg.SetOptions(element_padding=(0,0))
|
||||||
|
|
||||||
|
layout = [ [sg.Quit( button_color=('white','black'))],
|
||||||
|
[sg.Graph(CANVAS_SIZE, (0,0), (SAMPLES,SAMPLE_MAX),background_color='black', key='graph')],]
|
||||||
|
|
||||||
|
form = sg.FlexForm('Canvas test', grab_anywhere=True, background_color='black', no_titlebar=False, use_default_focus=False)
|
||||||
|
form.Layout(layout)
|
||||||
|
|
||||||
|
form.Finalize()
|
||||||
|
graph = form.FindElement('graph')
|
||||||
|
|
||||||
|
prev_response_time = None
|
||||||
|
i=0
|
||||||
|
prev_x, prev_y = 0, 0
|
||||||
|
graph_value = 250
|
||||||
|
while True:
|
||||||
|
# time.sleep(.2)
|
||||||
|
button, values = form.ReadNonBlocking()
|
||||||
|
if button == 'Quit' or values is None:
|
||||||
|
break
|
||||||
|
graph_offset = random.randint(-10, 10)
|
||||||
|
graph_value = graph_value + graph_offset
|
||||||
|
if graph_value > SAMPLE_MAX:
|
||||||
|
graph_value = SAMPLE_MAX
|
||||||
|
if graph_value < 0:
|
||||||
|
graph_value = 0
|
||||||
|
new_x, new_y = i, graph_value
|
||||||
|
prev_value = graph_value
|
||||||
|
if i >= SAMPLES:
|
||||||
|
graph.Move(-STEP_SIZE,0)
|
||||||
|
prev_x = prev_x - STEP_SIZE
|
||||||
|
graph.DrawLine((prev_x, prev_y), (new_x, new_y), color='white')
|
||||||
|
# form.FindElement('graph').DrawPoint((new_x, new_y), color='red')
|
||||||
|
prev_x, prev_y = new_x, new_y
|
||||||
|
i += STEP_SIZE if i < SAMPLES else 0
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
||||||
|
exit(69)
|
|
@ -3,6 +3,10 @@ from threading import Thread
|
||||||
import time
|
import time
|
||||||
import PySimpleGUI as sg
|
import PySimpleGUI as sg
|
||||||
|
|
||||||
|
|
||||||
|
STEP_SIZE=1
|
||||||
|
SAMPLES = 6000
|
||||||
|
|
||||||
# globale used to communicate with thread.. yea yea... it's working fine
|
# globale used to communicate with thread.. yea yea... it's working fine
|
||||||
g_exit = False
|
g_exit = False
|
||||||
g_response_time = None
|
g_response_time = None
|
||||||
|
@ -17,11 +21,14 @@ def main():
|
||||||
thread = Thread(target=ping_thread, args=(None,))
|
thread = Thread(target=ping_thread, args=(None,))
|
||||||
thread.start()
|
thread.start()
|
||||||
|
|
||||||
|
# sg.ChangeLookAndFeel('Black')
|
||||||
|
sg.SetOptions(element_padding=(0,0))
|
||||||
|
|
||||||
layout = [ [sg.T('Ping times to Google.com', font='Any 18')],
|
layout = [ [sg.T('Ping times to Google.com', font='Any 18')],
|
||||||
[sg.Graph((300,300), (0,0), (100,500),background_color='white', key='graph')],
|
[sg.Graph((6000,200), (0,0), (SAMPLES,500),background_color='black', key='graph')],
|
||||||
[sg.Quit()]]
|
[sg.Quit()]]
|
||||||
|
|
||||||
form = sg.FlexForm('Canvas test', grab_anywhere=True)
|
form = sg.FlexForm('Canvas test', grab_anywhere=True, background_color='black')
|
||||||
form.Layout(layout)
|
form.Layout(layout)
|
||||||
|
|
||||||
prev_response_time = None
|
prev_response_time = None
|
||||||
|
@ -33,19 +40,18 @@ def main():
|
||||||
button, values = form.ReadNonBlocking()
|
button, values = form.ReadNonBlocking()
|
||||||
if button == 'Quit' or values is None:
|
if button == 'Quit' or values is None:
|
||||||
break
|
break
|
||||||
|
graph = form.FindElement('graph')
|
||||||
if g_response_time is None or prev_response_time == g_response_time:
|
if g_response_time is None or prev_response_time == g_response_time:
|
||||||
continue
|
continue
|
||||||
new_x, new_y = i, g_response_time[0]
|
new_x, new_y = i, g_response_time[0]
|
||||||
prev_response_time = g_response_time
|
prev_response_time = g_response_time
|
||||||
form.FindElement('graph').DrawLine((prev_x, prev_y), (new_x, new_y), color='red')
|
if i >= SAMPLES:
|
||||||
|
graph.Move(-STEP_SIZE,0)
|
||||||
|
prev_x = prev_x - STEP_SIZE
|
||||||
|
graph.DrawLine((prev_x, prev_y), (new_x, new_y), color='white')
|
||||||
# form.FindElement('graph').DrawPoint((new_x, new_y), color='red')
|
# form.FindElement('graph').DrawPoint((new_x, new_y), color='red')
|
||||||
prev_x, prev_y = new_x, new_y
|
prev_x, prev_y = new_x, new_y
|
||||||
if i >= 100:
|
i += STEP_SIZE if i < SAMPLES else 0
|
||||||
i = 0
|
|
||||||
prev_x = prev_y = last_x = last_y = 0
|
|
||||||
form.FindElement('graph').Erase()
|
|
||||||
else: i += 4
|
|
||||||
|
|
||||||
# tell thread we're done. wait for thread to exit
|
# tell thread we're done. wait for thread to exit
|
||||||
g_exit = True
|
g_exit = True
|
||||||
|
|
|
@ -2,26 +2,35 @@ import PySimpleGUI as sg
|
||||||
|
|
||||||
def MachineLearningGUI():
|
def MachineLearningGUI():
|
||||||
sg.SetOptions(text_justification='right')
|
sg.SetOptions(text_justification='right')
|
||||||
form = sg.FlexForm('Machine Learning Front End', font=("Helvetica", 12)) # begin with a blank form
|
|
||||||
|
|
||||||
layout = [[sg.Text('Machine Learning Command Line Parameters', font=('Helvetica', 16))],
|
flags = [[sg.Checkbox('Normalize', size=(12, 1), default=True), sg.Checkbox('Verbose', size=(20, 1))],
|
||||||
[sg.Text('Passes', size=(15, 1)), sg.Spin(values=[i for i in range(1, 1000)], initial_value=20, size=(6, 1)),
|
[sg.Checkbox('Cluster', size=(12, 1)), sg.Checkbox('Flush Output', size=(20, 1), default=True)],
|
||||||
sg.Text('Steps', size=(18, 1)), sg.Spin(values=[i for i in range(1, 1000)], initial_value=20, size=(6, 1))],
|
[sg.Checkbox('Write Results', size=(12, 1)), sg.Checkbox('Keep Intermediate Data', size=(20, 1))],
|
||||||
[sg.Text('ooa', size=(15, 1)), sg.In(default_text='6', size=(10, 1)), sg.Text('nn', size=(15, 1)), sg.In(default_text='10', size=(10, 1))],
|
[sg.Checkbox('Normalize', size=(12, 1), default=True), sg.Checkbox('Verbose', size=(20, 1))],
|
||||||
[sg.Text('q', size=(15, 1)), sg.In(default_text='ff', size=(10, 1)), sg.Text('ngram', size=(15, 1)), sg.In(default_text='5', size=(10, 1))],
|
[sg.Checkbox('Cluster', size=(12, 1)), sg.Checkbox('Flush Output', size=(20, 1), default=True)],
|
||||||
[sg.Text('l', size=(15, 1)), sg.In(default_text='0.4', size=(10, 1)), sg.Text('Layers', size=(15, 1)), sg.Drop(values=('BatchNorm', 'other'),auto_size_text=True)],
|
[sg.Checkbox('Write Results', size=(12, 1)), sg.Checkbox('Keep Intermediate Data', size=(20, 1))],]
|
||||||
[sg.Text('_' * 100, size=(65, 1))],
|
|
||||||
[sg.Text('Flags', font=('Helvetica', 15), justification='left')],
|
loss_functions = [[sg.Radio('Cross-Entropy', 'loss', size=(12, 1)), sg.Radio('Logistic', 'loss', default=True, size=(12, 1))],
|
||||||
[sg.Checkbox('Normalize', size=(12, 1), default=True), sg.Checkbox('Verbose', size=(20, 1))],
|
[sg.Radio('Hinge', 'loss', size=(12, 1)), sg.Radio('Huber', 'loss', size=(12, 1))],
|
||||||
[sg.Checkbox('Cluster', size=(12, 1)), sg.Checkbox('Flush Output', size=(20, 1), default=True)],
|
[sg.Radio('Kullerback', 'loss', size=(12, 1)), sg.Radio('MAE(L1)', 'loss', size=(12, 1))],
|
||||||
[sg.Checkbox('Write Results', size=(12, 1)), sg.Checkbox('Keep Intermediate Data', size=(20, 1))],
|
[sg.Radio('MSE(L2)', 'loss', size=(12, 1)), sg.Radio('MB(L0)', 'loss', size=(12, 1))],]
|
||||||
[sg.Text('_' * 100, size=(65, 1))],
|
|
||||||
[sg.Text('Loss Functions', font=('Helvetica', 15), justification='left')],
|
command_line_parms = [[sg.Text('Passes', size=(8, 1)), sg.Spin(values=[i for i in range(1, 1000)], initial_value=20, size=(6, 1)),
|
||||||
[sg.Radio('Cross-Entropy', 'loss', size=(12, 1)), sg.Radio('Logistic', 'loss', default=True, size=(12, 1))],
|
sg.Text('Steps', size=(8, 1), pad=((7,3))), sg.Spin(values=[i for i in range(1, 1000)], initial_value=20, size=(6, 1))],
|
||||||
[sg.Radio('Hinge', 'loss', size=(12, 1)), sg.Radio('Huber', 'loss', size=(12, 1))],
|
[sg.Text('ooa', size=(8, 1)), sg.In(default_text='6', size=(8, 1)), sg.Text('nn', size=(8, 1)),
|
||||||
[sg.Radio('Kullerback', 'loss', size=(12, 1)), sg.Radio('MAE(L1)', 'loss', size=(12, 1))],
|
sg.In(default_text='10', size=(10, 1))],
|
||||||
[sg.Radio('MSE(L2)', 'loss', size=(12, 1)), sg.Radio('MB(L0)', 'loss', size=(12, 1))],
|
[sg.Text('q', size=(8, 1)), sg.In(default_text='ff', size=(8, 1)), sg.Text('ngram', size=(8, 1)),
|
||||||
|
sg.In(default_text='5', size=(10, 1))],
|
||||||
|
[sg.Text('l', size=(8, 1)), sg.In(default_text='0.4', size=(8, 1)), sg.Text('Layers', size=(8, 1)),
|
||||||
|
sg.Drop(values=('BatchNorm', 'other'), auto_size_text=True)],]
|
||||||
|
|
||||||
|
layout = [[sg.Frame('Command Line Parameteres', command_line_parms, text_color='green', font='Any 12')],
|
||||||
|
[sg.Frame('Flags', flags, font='Any 12', text_color='blue')],
|
||||||
|
[sg.Frame('Loss Functions', loss_functions, font='Any 12', text_color='red')],
|
||||||
[sg.Submit(), sg.Cancel()]]
|
[sg.Submit(), sg.Cancel()]]
|
||||||
|
|
||||||
|
|
||||||
|
form = sg.FlexForm('Machine Learning Front End', font=("Helvetica", 12))
|
||||||
button, values = form.LayoutAndRead(layout)
|
button, values = form.LayoutAndRead(layout)
|
||||||
del(form)
|
del(form)
|
||||||
sg.SetOptions(text_justification='left')
|
sg.SetOptions(text_justification='left')
|
||||||
|
@ -53,5 +62,5 @@ def CustomMeter():
|
||||||
form.CloseNonBlockingForm()
|
form.CloseNonBlockingForm()
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
CustomMeter()
|
# CustomMeter()
|
||||||
MachineLearningGUI()
|
MachineLearningGUI()
|
||||||
|
|
119
PySimpleGUI.py
119
PySimpleGUI.py
|
@ -12,6 +12,23 @@ import pickle
|
||||||
import calendar
|
import calendar
|
||||||
|
|
||||||
|
|
||||||
|
g_time_start = 0
|
||||||
|
g_time_end = 0
|
||||||
|
g_time_delta = 0
|
||||||
|
|
||||||
|
import time
|
||||||
|
def TimerStart():
|
||||||
|
global g_time_start
|
||||||
|
|
||||||
|
g_time_start = time.time()
|
||||||
|
|
||||||
|
def TimerStop():
|
||||||
|
global g_time_delta, g_time_end
|
||||||
|
|
||||||
|
g_time_end = time.time()
|
||||||
|
g_time_delta = g_time_end - g_time_start
|
||||||
|
print(g_time_delta)
|
||||||
|
|
||||||
# ----====----====----==== Constants the user CAN safely change ====----====----====----#
|
# ----====----====----==== Constants the user CAN safely change ====----====----====----#
|
||||||
DEFAULT_WINDOW_ICON = 'default_icon.ico'
|
DEFAULT_WINDOW_ICON = 'default_icon.ico'
|
||||||
DEFAULT_ELEMENT_SIZE = (45,1) # In CHARACTERS
|
DEFAULT_ELEMENT_SIZE = (45,1) # In CHARACTERS
|
||||||
|
@ -84,6 +101,7 @@ DEFAULT_METER_ORIENTATION = 'Horizontal'
|
||||||
DEFAULT_SLIDER_ORIENTATION = 'vertical'
|
DEFAULT_SLIDER_ORIENTATION = 'vertical'
|
||||||
DEFAULT_SLIDER_BORDER_WIDTH=1
|
DEFAULT_SLIDER_BORDER_WIDTH=1
|
||||||
DEFAULT_SLIDER_RELIEF = tk.FLAT
|
DEFAULT_SLIDER_RELIEF = tk.FLAT
|
||||||
|
DEFAULT_FRAME_RELIEF = tk.GROOVE
|
||||||
|
|
||||||
DEFAULT_LISTBOX_SELECT_MODE = tk.SINGLE
|
DEFAULT_LISTBOX_SELECT_MODE = tk.SINGLE
|
||||||
SELECT_MODE_MULTIPLE = tk.MULTIPLE
|
SELECT_MODE_MULTIPLE = tk.MULTIPLE
|
||||||
|
@ -223,6 +241,11 @@ class Element():
|
||||||
rc = self.FindReturnKeyBoundButton(element)
|
rc = self.FindReturnKeyBoundButton(element)
|
||||||
if rc is not None:
|
if rc is not None:
|
||||||
return rc
|
return rc
|
||||||
|
if element.Type == ELEM_TYPE_FRAME:
|
||||||
|
rc = self.FindReturnKeyBoundButton(element)
|
||||||
|
if rc is not None:
|
||||||
|
return rc
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def ReturnKeyHandler(self, event):
|
def ReturnKeyHandler(self, event):
|
||||||
|
@ -1180,7 +1203,6 @@ class Graph(Element):
|
||||||
zero_converted = self._convert_xy_to_canvas_xy(0,0)
|
zero_converted = self._convert_xy_to_canvas_xy(0,0)
|
||||||
shift_converted = self._convert_xy_to_canvas_xy(x_direction, y_direction)
|
shift_converted = self._convert_xy_to_canvas_xy(x_direction, y_direction)
|
||||||
shift_amount = (shift_converted[0]-zero_converted[0], shift_converted[1]-zero_converted[1])
|
shift_amount = (shift_converted[0]-zero_converted[0], shift_converted[1]-zero_converted[1])
|
||||||
print(shift_amount)
|
|
||||||
self._TKCanvas2.move('all', *shift_amount)
|
self._TKCanvas2.move('all', *shift_amount)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
@ -1195,13 +1217,50 @@ class Graph(Element):
|
||||||
# Frame #
|
# Frame #
|
||||||
# ---------------------------------------------------------------------- #
|
# ---------------------------------------------------------------------- #
|
||||||
class Frame(Element):
|
class Frame(Element):
|
||||||
def __init__(self, frame=None, background_color=None, scale=(None, None), size=(None, None), pad=None, key=None):
|
def __init__(self, title, layout, text_color=None, background_color=None, relief=DEFAULT_FRAME_RELIEF, size=(None, None), font=None, pad=None, key=None):
|
||||||
self.BackgroundColor = background_color if background_color is not None else DEFAULT_BACKGROUND_COLOR
|
|
||||||
self.TKFrame = frame
|
|
||||||
|
|
||||||
super().__init__(ELEM_TYPE_FRAME, background_color=background_color, scale=scale, size=size, pad=pad, key=key)
|
self.UseDictionary = False
|
||||||
|
self.ReturnValues = None
|
||||||
|
self.ReturnValuesList = []
|
||||||
|
self.ReturnValuesDictionary = {}
|
||||||
|
self.DictionaryKeyCounter = 0
|
||||||
|
self.ParentWindow = None
|
||||||
|
self.Rows = []
|
||||||
|
self.ParentForm = None
|
||||||
|
self.TKFrame = None
|
||||||
|
self.Title = title
|
||||||
|
self.Relief = relief
|
||||||
|
self.BackgroundColor = background_color if background_color is not None else DEFAULT_BACKGROUND_COLOR
|
||||||
|
|
||||||
|
self.Layout(layout)
|
||||||
|
|
||||||
|
super().__init__(ELEM_TYPE_FRAME, background_color=background_color, text_color=text_color, size=size, font=font, pad=pad, key=key)
|
||||||
return
|
return
|
||||||
|
|
||||||
|
def AddRow(self, *args):
|
||||||
|
''' Parms are a variable number of Elements '''
|
||||||
|
NumRows = len(self.Rows) # number of existing rows is our row number
|
||||||
|
CurrentRowNumber = NumRows # this row's number
|
||||||
|
CurrentRow = [] # start with a blank row and build up
|
||||||
|
# ------------------------- Add the elements to a row ------------------------- #
|
||||||
|
for i, element in enumerate(args): # Loop through list of elements and add them to the row
|
||||||
|
element.Position = (CurrentRowNumber, i)
|
||||||
|
CurrentRow.append(element)
|
||||||
|
if element.Key is not None:
|
||||||
|
self.UseDictionary = True
|
||||||
|
# ------------------------- Append the row to list of Rows ------------------------- #
|
||||||
|
self.Rows.append(CurrentRow)
|
||||||
|
|
||||||
|
def Layout(self, rows):
|
||||||
|
for row in rows:
|
||||||
|
self.AddRow(*row)
|
||||||
|
|
||||||
|
def __del__(self):
|
||||||
|
for row in self.Rows:
|
||||||
|
for element in row:
|
||||||
|
element.__del__()
|
||||||
|
|
||||||
|
|
||||||
def __del__(self):
|
def __del__(self):
|
||||||
super().__del__()
|
super().__del__()
|
||||||
|
|
||||||
|
@ -1264,7 +1323,7 @@ class Slider(Element):
|
||||||
|
|
||||||
|
|
||||||
# ---------------------------------------------------------------------- #
|
# ---------------------------------------------------------------------- #
|
||||||
# TkScrollableFrame (Used by Column (SOON) #
|
# TkScrollableFrame (Used by Column) #
|
||||||
# ---------------------------------------------------------------------- #
|
# ---------------------------------------------------------------------- #
|
||||||
class TkScrollableFrame(tk.Frame):
|
class TkScrollableFrame(tk.Frame):
|
||||||
def __init__(self, master, **kwargs):
|
def __init__(self, master, **kwargs):
|
||||||
|
@ -2132,9 +2191,18 @@ def BuildResultsForSubform(form, initialize_only, top_level_form):
|
||||||
BuildResultsForSubform(element, initialize_only, top_level_form)
|
BuildResultsForSubform(element, initialize_only, top_level_form)
|
||||||
for item in element.ReturnValuesList:
|
for item in element.ReturnValuesList:
|
||||||
AddToReturnList(top_level_form, item)
|
AddToReturnList(top_level_form, item)
|
||||||
# for key in element.ReturnValuesDictionary:
|
if element.UseDictionary:
|
||||||
# top_level_form.ReturnValuesDictionary[key] = element.ReturnValuesDictionary[key]
|
top_level_form.UseDictionary = True
|
||||||
# top_level_form.DictionaryKeyCounter += element.DictionaryKeyCounter
|
if element.ReturnValues[0] is not None: # if a button was clicked
|
||||||
|
button_pressed_text = element.ReturnValues[0]
|
||||||
|
|
||||||
|
if element.Type == ELEM_TYPE_FRAME:
|
||||||
|
element.DictionaryKeyCounter = top_level_form.DictionaryKeyCounter
|
||||||
|
element.ReturnValuesList = []
|
||||||
|
element.ReturnValuesDictionary = {}
|
||||||
|
BuildResultsForSubform(element, initialize_only, top_level_form)
|
||||||
|
for item in element.ReturnValuesList:
|
||||||
|
AddToReturnList(top_level_form, item)
|
||||||
if element.UseDictionary:
|
if element.UseDictionary:
|
||||||
top_level_form.UseDictionary = True
|
top_level_form.UseDictionary = True
|
||||||
if element.ReturnValues[0] is not None: # if a button was clicked
|
if element.ReturnValues[0] is not None: # if a button was clicked
|
||||||
|
@ -2200,7 +2268,7 @@ def BuildResultsForSubform(form, initialize_only, top_level_form):
|
||||||
# if an input type element, update the results
|
# if an input type element, update the results
|
||||||
if element.Type != ELEM_TYPE_BUTTON and element.Type != ELEM_TYPE_TEXT and element.Type != ELEM_TYPE_IMAGE and\
|
if element.Type != ELEM_TYPE_BUTTON and element.Type != ELEM_TYPE_TEXT and element.Type != ELEM_TYPE_IMAGE and\
|
||||||
element.Type != ELEM_TYPE_OUTPUT and element.Type != ELEM_TYPE_PROGRESS_BAR and \
|
element.Type != ELEM_TYPE_OUTPUT and element.Type != ELEM_TYPE_PROGRESS_BAR and \
|
||||||
element.Type!= ELEM_TYPE_COLUMN:
|
element.Type!= ELEM_TYPE_COLUMN and element.Type != ELEM_TYPE_FRAME:
|
||||||
AddToReturnList(form, value)
|
AddToReturnList(form, value)
|
||||||
AddToReturnDictionary(top_level_form, element, value)
|
AddToReturnDictionary(top_level_form, element, value)
|
||||||
elif (element.Type == ELEM_TYPE_BUTTON and element.BType == BUTTON_TYPE_CALENDAR_CHOOSER and element.Target == (None,None)) or \
|
elif (element.Type == ELEM_TYPE_BUTTON and element.BType == BUTTON_TYPE_CALENDAR_CHOOSER and element.Target == (None,None)) or \
|
||||||
|
@ -2240,6 +2308,13 @@ def FillSubformWithValues(form, values_dict):
|
||||||
value = values_dict[element.Key]
|
value = values_dict[element.Key]
|
||||||
except:
|
except:
|
||||||
continue
|
continue
|
||||||
|
if element.Type == ELEM_TYPE_FRAME:
|
||||||
|
FillSubformWithValues(element, values_dict)
|
||||||
|
try:
|
||||||
|
value = values_dict[element.Key]
|
||||||
|
except:
|
||||||
|
continue
|
||||||
|
|
||||||
if element.Type == ELEM_TYPE_INPUT_TEXT:
|
if element.Type == ELEM_TYPE_INPUT_TEXT:
|
||||||
element.Update(value)
|
element.Update(value)
|
||||||
elif element.Type == ELEM_TYPE_INPUT_CHECKBOX:
|
elif element.Type == ELEM_TYPE_INPUT_CHECKBOX:
|
||||||
|
@ -2268,6 +2343,10 @@ def _FindElementFromKeyInSubForm(form, key):
|
||||||
matching_elem = _FindElementFromKeyInSubForm(element, key)
|
matching_elem = _FindElementFromKeyInSubForm(element, key)
|
||||||
if matching_elem is not None:
|
if matching_elem is not None:
|
||||||
return matching_elem
|
return matching_elem
|
||||||
|
if element.Type == ELEM_TYPE_FRAME:
|
||||||
|
matching_elem = _FindElementFromKeyInSubForm(element, key)
|
||||||
|
if matching_elem is not None:
|
||||||
|
return matching_elem
|
||||||
if element.Key == key:
|
if element.Key == key:
|
||||||
return element
|
return element
|
||||||
|
|
||||||
|
@ -2366,6 +2445,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
|
||||||
col_frame.pack(side=tk.LEFT, padx=element.Pad[0], pady=element.Pad[1])
|
col_frame.pack(side=tk.LEFT, padx=element.Pad[0], pady=element.Pad[1])
|
||||||
if element.BackgroundColor != COLOR_SYSTEM_DEFAULT and element.BackgroundColor is not None:
|
if element.BackgroundColor != COLOR_SYSTEM_DEFAULT and element.BackgroundColor is not None:
|
||||||
col_frame.configure(background=element.BackgroundColor, highlightbackground=element.BackgroundColor, highlightcolor=element.BackgroundColor)
|
col_frame.configure(background=element.BackgroundColor, highlightbackground=element.BackgroundColor, highlightcolor=element.BackgroundColor)
|
||||||
|
|
||||||
# ------------------------- TEXT element ------------------------- #
|
# ------------------------- TEXT element ------------------------- #
|
||||||
elif element_type == ELEM_TYPE_TEXT:
|
elif element_type == ELEM_TYPE_TEXT:
|
||||||
# auto_size_text = element.AutoSizeText
|
# auto_size_text = element.AutoSizeText
|
||||||
|
@ -2728,12 +2808,16 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
|
||||||
toplevel_form.TKroot.configure(menu=element.TKMenu)
|
toplevel_form.TKroot.configure(menu=element.TKMenu)
|
||||||
# ------------------------- Frame element ------------------------- #
|
# ------------------------- Frame element ------------------------- #
|
||||||
elif element_type == ELEM_TYPE_FRAME:
|
elif element_type == ELEM_TYPE_FRAME:
|
||||||
width, height = element_size
|
labeled_frame = tk.LabelFrame(tk_row_frame, text=element.Title, relief=element.Relief)
|
||||||
if element.TKFrame is None:
|
PackFormIntoFrame(element, labeled_frame, toplevel_form)
|
||||||
element.TKFrame = tk.Frame(tk_row_frame, width=width, height=height, bd=border_depth)
|
labeled_frame.pack(side=tk.LEFT, padx=element.Pad[0], pady=element.Pad[1])
|
||||||
if element.BackgroundColor is not None and element.BackgroundColor != COLOR_SYSTEM_DEFAULT:
|
if element.BackgroundColor != COLOR_SYSTEM_DEFAULT and element.BackgroundColor is not None:
|
||||||
element.TKFrame.configure(background=element.BackgroundColor)
|
labeled_frame.configure(background=element.BackgroundColor, highlightbackground=element.BackgroundColor, highlightcolor=element.BackgroundColor)
|
||||||
element.TKFrame.pack(side=tk.LEFT, padx=element.Pad[0], pady=element.Pad[1])
|
if element.TextColor != COLOR_SYSTEM_DEFAULT and element.TextColor is not None:
|
||||||
|
labeled_frame.configure(foreground=element.TextColor)
|
||||||
|
if element.Font != None:
|
||||||
|
labeled_frame.configure(font=element.Font)
|
||||||
|
|
||||||
# ------------------------- SLIDER Box element ------------------------- #
|
# ------------------------- SLIDER Box element ------------------------- #
|
||||||
elif element_type == ELEM_TYPE_INPUT_SLIDER:
|
elif element_type == ELEM_TYPE_INPUT_SLIDER:
|
||||||
slider_length = element_size[0] * CharWidthInPixels()
|
slider_length = element_size[0] * CharWidthInPixels()
|
||||||
|
@ -2856,7 +2940,9 @@ def ConvertFlexToTK(MyFlexForm):
|
||||||
|
|
||||||
move_string = '+%i+%i'%(int(x),int(y))
|
move_string = '+%i+%i'%(int(x),int(y))
|
||||||
master.geometry(move_string)
|
master.geometry(move_string)
|
||||||
|
|
||||||
master.update_idletasks() # don't forget
|
master.update_idletasks() # don't forget
|
||||||
|
|
||||||
return
|
return
|
||||||
|
|
||||||
|
|
||||||
|
@ -2961,6 +3047,7 @@ def StartupTK(my_flex_form):
|
||||||
# root.protocol("WM_DELETE_WINDOW", MyFlexForm.DestroyedCallback())
|
# root.protocol("WM_DELETE_WINDOW", MyFlexForm.DestroyedCallback())
|
||||||
# root.bind('<Destroy>', MyFlexForm.DestroyedCallback())
|
# root.bind('<Destroy>', MyFlexForm.DestroyedCallback())
|
||||||
ConvertFlexToTK(my_flex_form)
|
ConvertFlexToTK(my_flex_form)
|
||||||
|
|
||||||
my_flex_form.SetIcon(my_flex_form.WindowIcon)
|
my_flex_form.SetIcon(my_flex_form.WindowIcon)
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
Loading…
Reference in New Issue