Font sizer - fixed exit detection. Change Submits for Slider - don't setup unless change_submits flag is set
This commit is contained in:
parent
c4364a2109
commit
421e96e800
|
@ -8,7 +8,7 @@ form = sg.FlexForm("Font size selector")
|
||||||
|
|
||||||
fontSize = 12
|
fontSize = 12
|
||||||
sampleText = sg.Text("Aa", size=(2, 1), font="Helvetica " + str(fontSize))
|
sampleText = sg.Text("Aa", size=(2, 1), font="Helvetica " + str(fontSize))
|
||||||
slider = sg.Slider(range=(6,50), orientation='h', size=(10,20), change_submits=True, key='slider')
|
slider = sg.Slider(range=(6,50), orientation='h', size=(10,20), change_submits=False, key='slider')
|
||||||
spin = sg.Spin([sz for sz in range(4,72)], font=('Helvetica 20'), initial_value=fontSize, change_submits=True, key='spin')
|
spin = sg.Spin([sz for sz in range(4,72)], font=('Helvetica 20'), initial_value=fontSize, change_submits=True, key='spin')
|
||||||
layout = [
|
layout = [
|
||||||
[sampleText, spin, slider],
|
[sampleText, spin, slider],
|
||||||
|
@ -19,7 +19,7 @@ sz = fontSize
|
||||||
form.Layout(layout)
|
form.Layout(layout)
|
||||||
while True:
|
while True:
|
||||||
button, values= form.Read()
|
button, values= form.Read()
|
||||||
if button is None:
|
if button in (None, 'OK', 'Cancel'):
|
||||||
break
|
break
|
||||||
sz_spin = int(values['spin'])
|
sz_spin = int(values['spin'])
|
||||||
sz_slider = int(values['slider'])
|
sz_slider = int(values['slider'])
|
||||||
|
|
|
@ -937,6 +937,37 @@ class Slider(Element):
|
||||||
super().__del__()
|
super().__del__()
|
||||||
|
|
||||||
|
|
||||||
|
# ---------------------------------------------------------------------- #
|
||||||
|
# TkScrollableFrame (Used by Column (SOON) #
|
||||||
|
# ---------------------------------------------------------------------- #
|
||||||
|
# TODO NOT YET WORKING! DO NOT USE. Will be used to make scrollable columns
|
||||||
|
class TkScrollableFrame(tk.Frame):
|
||||||
|
def __init__(self, master, **kwargs):
|
||||||
|
tk.Frame.__init__(self, master, **kwargs)
|
||||||
|
|
||||||
|
# create a canvas object and a vertical scrollbar for scrolling it
|
||||||
|
self.vscrollbar = tk.Scrollbar(self, orient=tk.VERTICAL)
|
||||||
|
self.vscrollbar.pack(side='right', fill="y", expand="false")
|
||||||
|
self.canvas = tk.Canvas(self, yscrollcommand=self.vscrollbar.set)
|
||||||
|
self.canvas.pack(side="left")
|
||||||
|
self.vscrollbar.config(command=self.canvas.yview)
|
||||||
|
|
||||||
|
# reset the view
|
||||||
|
self.canvas.xview_moveto(0)
|
||||||
|
self.canvas.yview_moveto(0)
|
||||||
|
|
||||||
|
# create a frame inside the canvas which will be scrolled with it
|
||||||
|
# self.interior = tk.Frame(self.canvas, **kwargs)
|
||||||
|
# self.canvas.create_window(0, 0, window=self.interior, anchor="nw")
|
||||||
|
|
||||||
|
# self.bind('<Configure>', self.set_scrollregion)
|
||||||
|
|
||||||
|
|
||||||
|
def set_scrollregion(self, event=None):
|
||||||
|
""" Set the scroll region on the canvas"""
|
||||||
|
self.canvas.configure(scrollregion=self.canvas.bbox('all'))
|
||||||
|
|
||||||
|
|
||||||
# ---------------------------------------------------------------------- #
|
# ---------------------------------------------------------------------- #
|
||||||
# Column #
|
# Column #
|
||||||
# ---------------------------------------------------------------------- #
|
# ---------------------------------------------------------------------- #
|
||||||
|
@ -1576,6 +1607,7 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
|
||||||
# ------------------------- COLUMN element ------------------------- #
|
# ------------------------- COLUMN element ------------------------- #
|
||||||
if element_type == ELEM_TYPE_COLUMN:
|
if element_type == ELEM_TYPE_COLUMN:
|
||||||
col_frame = tk.Frame(tk_row_frame)
|
col_frame = tk.Frame(tk_row_frame)
|
||||||
|
# col_frame = TkScrollableFrame(tk_row_frame) # do not use yet! not working
|
||||||
PackFormIntoFrame(element, col_frame, toplevel_form)
|
PackFormIntoFrame(element, col_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:
|
||||||
|
@ -1886,10 +1918,10 @@ def PackFormIntoFrame(form, containing_frame, toplevel_form):
|
||||||
else:
|
else:
|
||||||
range_from = element.Range[0]
|
range_from = element.Range[0]
|
||||||
range_to = element.Range[1]
|
range_to = element.Range[1]
|
||||||
|
if element.ChangeSubmits:
|
||||||
tkscale = tk.Scale(tk_row_frame, orient=element.Orientation, variable=element.TKIntVar, from_=range_from, to_=range_to, resolution = element.Resolution, length=slider_length, width=slider_width , bd=element.BorderWidth, relief=element.Relief, font=font, command=element.SliderChangedHandler)
|
tkscale = tk.Scale(tk_row_frame, orient=element.Orientation, variable=element.TKIntVar, from_=range_from, to_=range_to, resolution = element.Resolution, length=slider_length, width=slider_width , bd=element.BorderWidth, relief=element.Relief, font=font, command=element.SliderChangedHandler)
|
||||||
# if element.ChangeSubmits:
|
else:
|
||||||
# element.tkscale.bind('<Change>', element.SliderChangedHandler)
|
tkscale = tk.Scale(tk_row_frame, orient=element.Orientation, variable=element.TKIntVar, from_=range_from, to_=range_to, resolution = element.Resolution, length=slider_length, width=slider_width , bd=element.BorderWidth, relief=element.Relief, font=font)
|
||||||
# tktext_label.configure(anchor=tk.NW, image=photo)
|
|
||||||
tkscale.config(highlightthickness=0)
|
tkscale.config(highlightthickness=0)
|
||||||
if element.BackgroundColor is not None and element.BackgroundColor != COLOR_SYSTEM_DEFAULT:
|
if element.BackgroundColor is not None and element.BackgroundColor != COLOR_SYSTEM_DEFAULT:
|
||||||
tkscale.configure(background=element.BackgroundColor)
|
tkscale.configure(background=element.BackgroundColor)
|
||||||
|
|
Loading…
Reference in New Issue