106 lines
4.0 KiB
Python
106 lines
4.0 KiB
Python
import PySimpleGUI as sg
|
|
|
|
"""
|
|
Demo - User Settings
|
|
|
|
Use the "user_settings" API calls to make a "settings window"
|
|
|
|
This demo is very basic. The user_settings functions are used directly without a lookup table
|
|
or some other mechanism to map between PySimpleGUI keys and user settings keys.
|
|
|
|
Two windows are shown. One is a super-simple "save previously entered filename"
|
|
The other is a larger "settings window" where multiple settings are saved/loaded
|
|
|
|
Copyright 2020 PySimpleGUI.org
|
|
"""
|
|
|
|
SETTINGS_PATH = '.'
|
|
|
|
|
|
def make_window():
|
|
"""
|
|
Creates a new window. The default values for some elements are pulled directly from the
|
|
"User Settings" without the use of temp variables.
|
|
|
|
Some get_entry calls don't have a default value, such as theme, because there was an initial call
|
|
that would have set the default value if the setting wasn't present. Could still put the default
|
|
value if you wanted but it would be 2 places to change if you wanted a different default value.
|
|
|
|
Use of a lookup table to map between element keys and user settings could be aded. This demo
|
|
is intentionally done without one to show how to use the settings APIs in the most basic,
|
|
straightforward way.
|
|
|
|
If your application allows changing the theme, then a make_window function is good to have
|
|
so that you can close and re-create a window easily.
|
|
|
|
:return: (sg.Window) The window that was created
|
|
"""
|
|
|
|
sg.theme(sg.user_settings_get_entry('theme', 'DarkBlue2')) # set the theme
|
|
|
|
layout = [[sg.Text('Settings Window')],
|
|
[sg.Input(sg.user_settings_get_entry('input', ''), k='-IN-')],
|
|
[sg.Listbox(sg.theme_list(), default_values=[sg.user_settings_get_entry('theme')], size=(15, 10), k='-LISTBOX-')],
|
|
[sg.CB('Option 1', sg.user_settings_get_entry('option1', True), k='-CB1-')],
|
|
[sg.CB('Option 2', sg.user_settings_get_entry('option2', False), k='-CB2-')],
|
|
[sg.T('Settings file = ' + sg.user_settings_filename())],
|
|
[sg.Button('Save'), sg.Button('Exit without saving', k='Exit')]]
|
|
|
|
return sg.Window('A Settings Window', layout)
|
|
|
|
|
|
def settings_window():
|
|
"""
|
|
Create and interact with a "settings window". You can a similar pair of functions to your
|
|
code to add a "settings" feature.
|
|
"""
|
|
|
|
window = make_window()
|
|
current_theme = sg.theme()
|
|
|
|
while True:
|
|
event, values = window.read()
|
|
if event in (sg.WINDOW_CLOSED, 'Exit'):
|
|
break
|
|
if event == 'Save':
|
|
# Save some of the values as user settings
|
|
sg.user_settings_set_entry('input', values['-IN-'])
|
|
sg.user_settings_set_entry('theme', values['-LISTBOX-'][0])
|
|
sg.user_settings_set_entry('option1', values['-CB1-'])
|
|
sg.user_settings_set_entry('option2', values['-CB2-'])
|
|
|
|
# if the theme was changed, restart the window
|
|
if values['-LISTBOX-'][0] != current_theme:
|
|
current_theme = values['-LISTBOX-'][0]
|
|
window.close()
|
|
window = make_window()
|
|
|
|
|
|
def save_previous_filename_demo():
|
|
"""
|
|
Saving the previously selected filename....
|
|
A 2-line demo of one of the likely most popular use of user settings
|
|
* Get the previously entered filename
|
|
* Use previous as default for Input
|
|
* When a new filename is chosen, write the filename to user settings
|
|
"""
|
|
|
|
prior_filename = sg.user_settings_get_entry('filename', '')
|
|
|
|
layout = [[sg.Text('Enter a filename:')],
|
|
[sg.Input(prior_filename, key='-IN-'), sg.FileBrowse()],
|
|
[sg.B('OK')]]
|
|
|
|
event, values = sg.Window('Filename Example', layout).read(close=True)
|
|
|
|
# If user clicked OK, then save the filename for next time
|
|
if event == 'OK':
|
|
sg.user_settings_set_entry('filename', values['-IN-'])
|
|
|
|
|
|
if __name__ == '__main__':
|
|
sg.user_settings_filename(path=SETTINGS_PATH) # Set the location for the settings file
|
|
# Run a couple of demo windows
|
|
save_previous_filename_demo()
|
|
settings_window()
|