Merge pull request #3314 from PySimpleGUI/Dev-latest

New Custom Titlebar showing multiple color combinations
This commit is contained in:
PySimpleGUI 2020-08-20 07:42:12 -04:00 committed by GitHub
commit e0af9ffe58
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 161 additions and 10 deletions

View File

@ -15,18 +15,19 @@ import PySimpleGUI as sg
# If not running 4.28.0.4+ that has the DarkGrey8 theme, then uncomment to get it added. # If not running 4.28.0.4+ that has the DarkGrey8 theme, then uncomment to get it added.
# DarkGrey8 = {'BACKGROUND': '#19232D', DarkGrey8 = {'BACKGROUND': '#19232D',
# 'TEXT': '#ffffff', 'TEXT': '#ffffff',
# 'INPUT': '#32414B', 'INPUT': '#32414B',
# 'TEXT_INPUT': '#ffffff', 'TEXT_INPUT': '#ffffff',
# 'SCROLL': '#505F69', 'SCROLL': '#505F69',
# 'BUTTON': ('#ffffff', '#32414B'), 'BUTTON': ('#ffffff', '#32414B'),
# 'PROGRESS': ('#505F69', '#32414B'), 'PROGRESS': ('#505F69', '#32414B'),
# 'BORDER': 1, 'SLIDER_DEPTH': 0, 'PROGRESS_DEPTH': 0, 'BORDER': 1, 'SLIDER_DEPTH': 0, 'PROGRESS_DEPTH': 0,
# } }
# sg.theme_add_new('DarkGrey8', DarkGrey8) sg.theme_add_new('DarkGrey8', DarkGrey8)
sg.theme('DarkGrey8')
def dummy_minimized_window(title): def dummy_minimized_window(title):
""" """

View File

@ -0,0 +1,150 @@
import PySimpleGUI as sg
"""
Demo Titlebar Multiple Combintions - how to make a custom titlebar with different color options
Demo showing how to remove the titlebar and replace with your own
Unlike previous demos that lacked a titlebar, this one provides a way for you
to "minimize" your window that does not have a titlebar. This is done by faking
the window using a hidden window that is minimized.
Use the "theme" calls to experiment with the color combinations to get to the colors you like. With themes, there
are pairs of colors that usually match well. You're shown each of these combinations to help you decide which you
like the best. These color combinations are shown to you one by one as you click the "next" button:
['1 - Button Colors', sg.theme_button_color()[0], sg.theme_button_color()[1]],
['2 - Reversed Button Colors', sg.theme_button_color()[1], sg.theme_button_color()[0]],
['3 - Input Colors', sg.theme_input_text_color(), sg.theme_input_background_color()],
['4 - Reversed Input Colors', sg.theme_input_background_color(), sg.theme_input_text_color()],
['5 - Reversed background & Text', sg.theme_background_color(), sg.theme_text_color()],
['6 - Button Background & Slider', sg.theme_button_color()[1], sg.theme_slider_color()],
['7 - Slider & Button Text', sg.theme_slider_color(), sg.theme_button_color()[0]],
Copyright 2020 PySimpleGUI.org
"""
def dummy_minimized_window(title):
"""
Creates an invisible window that is minimized to the taskbar
As soon as something happens to the window, it is closed and the function
returns.
The FocusIn event is set so that if the user restores the window from the taskbar, then the read
wille return, the window will be closed, and the function will return
"""
layout = [[sg.T('This is your window with a customized titlebar... you just cannot see it')]]
window = sg.Window(title, layout, finalize=True, alpha_channel=0)
window.minimize()
window.bind('<FocusIn>', '-FOCUS-')
window.read(close=True)
def title_bar(title, text_color, background_color):
"""
Creates a "row" that can be added to a layout. This row looks like a titlebar
:param title: The "title" to show in the titlebar
:type title: str
:param text_color: Text color for titlebar
:type text_color: str
:param background_color: Background color for titlebar
:type background_color: str
:return: A list of elements (i.e. a "row" for a layout)
:rtype: List[sg.Element]
"""
bc = background_color
tc = text_color
font = 'Helvetica 12'
return [sg.Col([[sg.T(title, text_color=tc, background_color=bc, font=font)]], pad=(0, 0), background_color=bc),
sg.Col([[sg.T('_', text_color=tc, background_color=bc, enable_events=True, font=font, key='-MINIMIZE-'),
sg.Text('', text_color=tc, background_color=bc, font=font, enable_events=True, key='Exit')]], element_justification='r', key='-C-',
pad=(0, 0), background_color=bc)]
def create_window(title, bar_text_color, bar_background_color):
"""
Creates a window using the title and colors provided to make the titlebar
:return: A window with a custom titlebar using specificied colors
:rtype: sg.Window
"""
layout = [
title_bar(title, bar_text_color, bar_background_color),
[sg.T('This is normal window text. The above is the fake "titlebar"')],
[sg.T('Input something:')],
[sg.Input('Color of input text', key='-IN-'), sg.Text(size=(12, 1), key='-OUT-')],
[sg.Button('Go'), sg.Button('Next'), sg.B('New Theme'), sg.Button('Exit')]]
window = sg.Window(title, layout, resizable=True, no_titlebar=True, grab_anywhere=True, keep_on_top=True, margins=(0, 0), finalize=True)
window['-C-'].expand(True, False, False) # expand the titlebar's rightmost column so that it resizes correctly
return window
def choose_theme():
layout = [[sg.Text('Look and Feel Browser')],
[sg.Text('Click a look and feel color to see demo window')],
[sg.Listbox(values=sg.theme_list(),
size=(20, 20), key='-LIST-', enable_events=True)],
[sg.Button('Choose')]]
window = sg.Window('Look and Feel Browser', layout)
while True: # Event Loop
event, values = window.read()
if event in (sg.WIN_CLOSED, 'Choose'):
break
window.close()
if event is None:
theme = sg.theme()
else:
theme = values['-LIST-'][0]
sg.theme(theme)
color_pairs = [['1 - Button Colors', sg.theme_button_color()[0], sg.theme_button_color()[1]],
['2 - Reversed Button Colors', sg.theme_button_color()[1], sg.theme_button_color()[0]],
['3 - Input Colors', sg.theme_input_text_color(), sg.theme_input_background_color()],
['4 - Reversed Input Colors', sg.theme_input_background_color(), sg.theme_input_text_color()],
['5 - Reversed background & Text', sg.theme_background_color(), sg.theme_text_color()],
['6 - Button Background & Slider', sg.theme_button_color()[1], sg.theme_slider_color()],
['7 - Slider & Button Text', sg.theme_slider_color(), sg.theme_button_color()[0]], ]
return theme, color_pairs
def main():
theme, color_pairs = choose_theme()
index = 0
window = create_window(f'{color_pairs[index][0]} - {theme}', color_pairs[index][1], color_pairs[index][2])
while True: # Event Loop
event, values = window.read()
print(event, values)
if event == sg.WIN_CLOSED or event.startswith('Exit'):
break
if event == '-MINIMIZE-':
window.hide()
dummy_minimized_window(window.Title)
window.un_hide()
elif event == 'Go':
window['-OUT-'].update(values['-IN-'])
elif event == 'Next':
window.close()
index = (index + 1) % len(color_pairs)
window = create_window(f'{color_pairs[index][0]} - {theme}', color_pairs[index][1], color_pairs[index][2])
elif event == 'New Theme':
window.close()
theme, color_pairs = choose_theme()
index = 0
window = create_window(f'{color_pairs[index][0]} - {theme}', color_pairs[index][1], color_pairs[index][2])
window.close()
if __name__ == '__main__':
main()