From 96f1496b43416230af1b0458c9fcf058ae446c7a Mon Sep 17 00:00:00 2001 From: PySimpleGUI Date: Wed, 27 Oct 2021 16:49:56 -0400 Subject: [PATCH] New Dashboard Demo that uses Frames instead of Columns --- DemoPrograms/Demo_Frame_Based_Dashboard.py | 85 ++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 DemoPrograms/Demo_Frame_Based_Dashboard.py diff --git a/DemoPrograms/Demo_Frame_Based_Dashboard.py b/DemoPrograms/Demo_Frame_Based_Dashboard.py new file mode 100644 index 00000000..7786f1c7 --- /dev/null +++ b/DemoPrograms/Demo_Frame_Based_Dashboard.py @@ -0,0 +1,85 @@ +import PySimpleGUI as sg + +""" + Demo - Resizable Dashboard using Frames + + This Demo Program looks similar to the one based on the Column Element. + This version has a big difference in how it was implemented and the fact that it can be resized. + + It's a good example of how PySimpleGUI evolves, continuously. When the original Column-based demo + was written, none of these techniques such as expansion, were easily programmed. + + Dashboard using blocks of information. + + Copyright 2021 PySimpleGUI.org +""" + + +theme_dict = {'BACKGROUND': '#2B475D', + 'TEXT': '#FFFFFF', + 'INPUT': '#F2EFE8', + 'TEXT_INPUT': '#000000', + 'SCROLL': '#F2EFE8', + 'BUTTON': ('#000000', '#C2D4D8'), + 'PROGRESS': ('#FFFFFF', '#C7D5E0'), + 'BORDER': 0,'SLIDER_DEPTH': 0, 'PROGRESS_DEPTH': 0} + +sg.theme_add_new('Dashboard', theme_dict) +sg.theme('Dashboard') + +BORDER_COLOR = '#C7D5E0' +DARK_HEADER_COLOR = '#1B2838' +BPAD_TOP = ((20,20), (20, 10)) +BPAD_LEFT = ((20,10), (0, 0)) +BPAD_LEFT_INSIDE = (0, (10, 0)) +BPAD_RIGHT = ((10,20), (10, 0)) + +top_banner = [ + [sg.Text('Dashboard', font='Any 20', background_color=DARK_HEADER_COLOR, enable_events=True, grab=False), sg.Push(background_color=DARK_HEADER_COLOR), + sg.Text('Wednesday 27 Oct 2021', font='Any 20', background_color=DARK_HEADER_COLOR)], + ] + +top = [[sg.Push(), sg.Text('Weather Could Go Here', font='Any 20'), sg.Push()], + [sg.T('This Frame has a relief while the others do not')], + [sg.T('This window is resizable (see that sizegrip in the bottom right?)')]] + +block_3 = [[sg.Text('Block 3', font='Any 20')], + [sg.Input(), sg.Text('Some Text')], + [sg.T('This frame has element_justification="c"')], + [sg.Button('Go'), sg.Button('Exit')] ] + + +block_2 = [[sg.Text('Block 2', font='Any 20')], + [sg.T('This is some random text')], + [sg.Image(data=sg.DEFAULT_BASE64_ICON, enable_events=True)] ] + +block_4 = [[sg.Text('Block 4', font='Any 20')], + [sg.T('You can move the window by grabbing this block (and the top banner)')], + [sg.T('This block is a Column Element')], + [sg.T('The others are all frames')], + [sg.T('The Frame Element, with a border_width=0\n and no title is just like a Column')], + [sg.T('Frames that have a fixed size \n handle element_justification better than Columns')]] + + +layout = [ + [sg.Frame('', top_banner, pad=(0,0), background_color=DARK_HEADER_COLOR, expand_x=True, border_width=0, grab=True)], + [sg.Frame('', top, size=(920, 100), pad=BPAD_TOP, expand_x=True, relief=sg.RELIEF_GROOVE, border_width=3)], + [sg.Frame('', [[sg.Frame('', block_2, size=(450,150), pad=BPAD_LEFT_INSIDE, border_width=0, expand_x=True, expand_y=True, )], + [sg.Frame('', block_3, size=(450,150), pad=BPAD_LEFT_INSIDE, border_width=0, expand_x=True, expand_y=True, element_justification='c')]], + pad=BPAD_LEFT, background_color=BORDER_COLOR, border_width=0, expand_x=True, expand_y=True), + sg.Column(block_4, size=(450, 320), pad=BPAD_RIGHT, expand_x=True, expand_y=True, grab=True),],[sg.Sizegrip(background_color=BORDER_COLOR)]] + +window = sg.Window('Dashboard PySimpleGUI-Style', layout, margins=(0,0), background_color=BORDER_COLOR, no_titlebar=True, resizable=True, right_click_menu=sg.MENU_RIGHT_CLICK_EDITME_VER_LOC_EXIT) + +while True: # Event Loop + event, values = window.read() + print(event, values) + if event == sg.WIN_CLOSED or event == 'Exit': + break + elif event == 'Edit Me': + sg.execute_editor(__file__) + elif event == 'Version': + sg.popup_scrolled(sg.get_versions(), keep_on_top=True) + elif event == 'File Location': + sg.popup_scrolled('This Python file is:', __file__) +window.close()