From 54049efa7c3a0967e2a471cf3b903476e4afa46b Mon Sep 17 00:00:00 2001 From: MikeTheWatchGuy Date: Tue, 18 Sep 2018 01:01:13 -0400 Subject: [PATCH] Frame Element - parameter to set the location Title should be shown, Fixed keypad demo. It had been overwritten! --- Demo_Keypad.py | 87 +++++++++++++++++++++----------------------------- PySimpleGUI.py | 22 ++++++++++--- 2 files changed, 55 insertions(+), 54 deletions(-) diff --git a/Demo_Keypad.py b/Demo_Keypad.py index fe036363..501e9d4b 100644 --- a/Demo_Keypad.py +++ b/Demo_Keypad.py @@ -1,56 +1,43 @@ -from tkinter import * -from random import randint -import PySimpleGUI as g -from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg, FigureCanvasAgg -from matplotlib.figure import Figure -import matplotlib.backends.tkagg as tkagg -import tkinter as Tk +import PySimpleGUI as sg + +# g.SetOptions(button_color=g.COLOR_SYSTEM_DEFAULT) # because some people like gray buttons + +# Demonstrates a number of PySimpleGUI features including: +# Default element size +# auto_size_buttons +# ReadFormButton +# Dictionary return values +# Update of elements in form (Text, Input) +# do_not_clear of Input elements -def main(): - fig = Figure() +# create the 2 Elements we want to control outside the form - ax = fig.add_subplot(111) - ax.set_xlabel("X axis") - ax.set_ylabel("Y axis") - ax.grid() +layout = [[sg.Text('Enter Your Passcode')], + [sg.Input(size=(10, 1), do_not_clear=True, key='input')], + [sg.ReadFormButton('1'), sg.ReadFormButton('2'), sg.ReadFormButton('3')], + [sg.ReadFormButton('4'), sg.ReadFormButton('5'), sg.ReadFormButton('6')], + [sg.ReadFormButton('7'), sg.ReadFormButton('8'), sg.ReadFormButton('9')], + [sg.ReadFormButton('Submit'), sg.ReadFormButton('0'), sg.ReadFormButton('Clear')], + [sg.Text('', size=(15, 1), font=('Helvetica', 18), text_color='red', key='out')], + ] - layout = [[g.Text('Animated Matplotlib', size=(40, 1), justification='center', font='Helvetica 20')], - [g.Canvas(size=(640, 480), key='canvas')], - [g.ReadFormButton('Exit', size=(10, 2), pad=((280, 0), 3), font='Helvetica 14')]] +form = sg.FlexForm('Keypad', default_button_element_size=(5, 2), auto_size_buttons=False, grab_anywhere=False) +form.Layout(layout) - # create the form and show it without the plot - form = g.FlexForm('Demo Application - Embedding Matplotlib In PySimpleGUI') - form.Layout(layout) - form.ReadNonBlocking() +# Loop forever reading the form's values, updating the Input field +keys_entered = '' +while True: + button, values = form.Read() # read the form + if button is None: # if the X button clicked, just exit + break + if button is 'Clear': # clear keys if clear button + keys_entered = '' + elif button in '1234567890': + keys_entered = values['input'] # get what's been entered so far + keys_entered += button # add the new digit + elif button is 'Submit': + keys_entered = values['input'] + form.FindElement('out').Update(keys_entered) # output the final string - canvas_elem = form.FindElement('canvas') - - graph = FigureCanvasTkAgg(fig, master=canvas_elem.TKCanvas) - canvas = canvas_elem.TKCanvas - - dpts = [randint(0, 10) for x in range(10000)] - for i in range(len(dpts)): - button, values = form.ReadNonBlocking() - if button is 'Exit' or values is None: - exit(69) - - ax.cla() - ax.grid() - - ax.plot(range(20), dpts[i:i + 20], color='purple') - graph.draw() - figure_x, figure_y, figure_w, figure_h = fig.bbox.bounds - figure_w, figure_h = int(figure_w), int(figure_h) - photo = Tk.PhotoImage(master=canvas, width=figure_w, height=figure_h) - - canvas.create_image(640 / 2, 480 / 2, image=photo) - - figure_canvas_agg = FigureCanvasAgg(fig) - figure_canvas_agg.draw() - - tkagg.blit(photo, figure_canvas_agg.get_renderer()._renderer, colormode=2) - # time.sleep(.1) - -if __name__ == '__main__': - main() \ No newline at end of file + form.FindElement('input').Update(keys_entered) # change the form to reflect current key string \ No newline at end of file diff --git a/PySimpleGUI.py b/PySimpleGUI.py index f9d26aa8..219601e8 100644 --- a/PySimpleGUI.py +++ b/PySimpleGUI.py @@ -118,6 +118,14 @@ TABLE_SELECT_MODE_BROWSE = tk.BROWSE TABLE_SELECT_MODE_EXTENDED = tk.EXTENDED DEFAULT_TABLE_SECECT_MODE = TABLE_SELECT_MODE_EXTENDED +TITLE_LOCATION_TOP = tk.N +TITLE_LOCATION_BOTTOM = tk.S +TITLE_LOCATION_LEFT = tk.W +TITLE_LOCATION_RIGHT = tk.E +TITLE_LOCATION_TOP_LEFT = tk.NW +TITLE_LOCATION_TOP_RIGHT = tk.NE +TITLE_LOCATION_BOTTOM_LEFT = tk.SW +TITLE_LOCATION_BOTTOM_RIGHT = tk.SE # DEFAULT_METER_ORIENTATION = 'Vertical' @@ -1217,7 +1225,7 @@ class Graph(Element): # Frame # # ---------------------------------------------------------------------- # class Frame(Element): - def __init__(self, title, layout, text_color=None, background_color=None, relief=DEFAULT_FRAME_RELIEF, size=(None, None), font=None, pad=None, key=None): + def __init__(self, title, layout, title_color=None, background_color=None, title_location=None , relief=DEFAULT_FRAME_RELIEF, size=(None, None), font=None, pad=None, border_width=None, key=None): self.UseDictionary = False self.ReturnValues = None @@ -1230,11 +1238,13 @@ class Frame(Element): self.TKFrame = None self.Title = title self.Relief = relief + self.TitleLocation = title_location + self.BorderWidth = border_width 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) + super().__init__(ELEM_TYPE_FRAME, background_color=background_color, text_color=title_color, size=size, font=font, pad=pad, key=key) return def AddRow(self, *args): @@ -2815,8 +2825,12 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form): labeled_frame.configure(background=element.BackgroundColor, highlightbackground=element.BackgroundColor, highlightcolor=element.BackgroundColor) 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) + if font is not None: + labeled_frame.configure(font=font) + if element.TitleLocation is not None: + labeled_frame.configure(labelanchor=element.TitleLocation) + if element.BorderWidth is not None: + labeled_frame.configure(borderwidth=element.BorderWidth) # ------------------------- SLIDER Box element ------------------------- # elif element_type == ELEM_TYPE_INPUT_SLIDER: