mirror of
https://github.com/TomSchimansky/CustomTkinter.git
synced 2023-08-10 21:13:13 +03:00
212 lines
10 KiB
Python
212 lines
10 KiB
Python
import tkinter
|
|
import tkinter.messagebox
|
|
import customtkinter
|
|
import sys
|
|
|
|
customtkinter.set_appearance_mode("System") # Modes: "System" (standard), "Dark", "Light"
|
|
customtkinter.set_default_color_theme("blue") # Themes: "blue" (standard), "green", "dark-blue"
|
|
|
|
|
|
class App(customtkinter.CTk):
|
|
|
|
WIDTH = 780
|
|
HEIGHT = 520
|
|
|
|
def __init__(self):
|
|
super().__init__()
|
|
|
|
self.title("CustomTkinter complex example")
|
|
self.geometry(f"{App.WIDTH}x{App.HEIGHT}")
|
|
# self.minsize(App.WIDTH, App.HEIGHT)
|
|
|
|
self.protocol("WM_DELETE_WINDOW", self.on_closing)
|
|
if sys.platform == "darwin":
|
|
self.bind("<Command-q>", self.on_closing)
|
|
self.bind("<Command-w>", self.on_closing)
|
|
self.createcommand('tk::mac::Quit', self.on_closing)
|
|
|
|
# ============ create two frames ============
|
|
|
|
# configure grid layout (1x2)
|
|
self.grid_columnconfigure(1, weight=1)
|
|
self.rowconfigure(0, weight=1)
|
|
|
|
self.frame_left = customtkinter.CTkFrame(master=self,
|
|
width=180,
|
|
corner_radius=0)
|
|
self.frame_left.grid(row=0, column=0, sticky="nswe")
|
|
|
|
self.frame_right = customtkinter.CTkFrame(master=self)
|
|
self.frame_right.grid(row=0, column=1, sticky="nswe", padx=20, pady=20)
|
|
|
|
# ============ frame_left ============
|
|
|
|
# configure grid layout
|
|
self.frame_left.grid_rowconfigure(0, minsize=10) # empty row with minsize as spacing
|
|
self.frame_left.grid_rowconfigure(5, weight=1) # empty row as spacing
|
|
self.frame_left.grid_rowconfigure(8, minsize=20) # empty row with minsize as spacing
|
|
self.frame_left.grid_rowconfigure(11, minsize=10) # empty row with minsize as spacing
|
|
|
|
self.label_1 = customtkinter.CTkLabel(master=self.frame_left,
|
|
text="CustomTkinter",
|
|
text_font=("Roboto Medium", -16)) # font name and size in px
|
|
self.label_1.grid(row=1, column=0, pady=10, padx=10)
|
|
|
|
self.button_1 = customtkinter.CTkButton(master=self.frame_left,
|
|
text="CTkButton 1",
|
|
fg_color=("gray75", "gray30"), # <- custom tuple-color
|
|
command=self.button_event)
|
|
self.button_1.grid(row=2, column=0, pady=10, padx=20)
|
|
|
|
self.button_2 = customtkinter.CTkButton(master=self.frame_left,
|
|
text="CTkButton 2",
|
|
fg_color=("gray75", "gray30"), # <- custom tuple-color
|
|
command=self.button_event)
|
|
self.button_2.grid(row=3, column=0, pady=10, padx=20)
|
|
|
|
self.button_3 = customtkinter.CTkButton(master=self.frame_left,
|
|
text="CTkButton 3",
|
|
fg_color=("gray75", "gray30"), # <- custom tuple-color
|
|
command=self.button_event)
|
|
self.button_3.grid(row=4, column=0, pady=10, padx=20)
|
|
|
|
self.switch_1 = customtkinter.CTkSwitch(master=self.frame_left)
|
|
self.switch_1.grid(row=9, column=0, pady=10, padx=20, sticky="w")
|
|
|
|
self.switch_2 = customtkinter.CTkSwitch(master=self.frame_left,
|
|
text="Dark Mode",
|
|
command=self.change_mode)
|
|
self.switch_2.grid(row=10, column=0, pady=10, padx=20, sticky="w")
|
|
|
|
# ============ frame_right ============
|
|
|
|
# configure grid layout (3x7)
|
|
for i in [0, 1, 2, 3]:
|
|
self.frame_right.rowconfigure(i, weight=1)
|
|
self.frame_right.rowconfigure(7, weight=10)
|
|
self.frame_right.columnconfigure(0, weight=1)
|
|
self.frame_right.columnconfigure(1, weight=1)
|
|
self.frame_right.columnconfigure(2, weight=0)
|
|
|
|
self.frame_info = customtkinter.CTkFrame(master=self.frame_right)
|
|
self.frame_info.grid(row=0, column=0, columnspan=2, rowspan=4, pady=20, padx=20, sticky="nsew")
|
|
|
|
# ============ frame_right -> frame_info ============
|
|
|
|
self.frame_info.rowconfigure(0, weight=1)
|
|
self.frame_info.columnconfigure(0, weight=1)
|
|
|
|
self.label_info_1 = customtkinter.CTkLabel(master=self.frame_info,
|
|
text="CTkLabel: Lorem ipsum dolor sit,\n" +
|
|
"amet consetetur sadipscing elitr,\n" +
|
|
"sed diam nonumy eirmod tempor" ,
|
|
height=100,
|
|
fg_color=("white", "gray38"), # <- custom tuple-color
|
|
justify=tkinter.LEFT)
|
|
self.label_info_1.grid(column=0, row=0, sticky="nwe", padx=15, pady=15)
|
|
|
|
self.progressbar = customtkinter.CTkProgressBar(master=self.frame_info)
|
|
self.progressbar.grid(row=1, column=0, sticky="ew", padx=15, pady=15)
|
|
|
|
# ============ frame_right <- ============
|
|
self.radio_var = tkinter.IntVar(value=0)
|
|
|
|
self.label_radio_group = customtkinter.CTkLabel(master=self.frame_right,
|
|
text="CTkRadioButton Group:")
|
|
self.label_radio_group.grid(row=0, column=2, columnspan=1, pady=20, padx=10, sticky="")
|
|
|
|
self.radio_button_1 = customtkinter.CTkRadioButton(master=self.frame_right,
|
|
variable=self.radio_var,
|
|
value=0)
|
|
self.radio_button_1.grid(row=1, column=2, pady=10, padx=20, sticky="n")
|
|
|
|
self.radio_button_2 = customtkinter.CTkRadioButton(master=self.frame_right,
|
|
variable=self.radio_var,
|
|
value=1)
|
|
self.radio_button_2.grid(row=2, column=2, pady=10, padx=20, sticky="n")
|
|
|
|
self.radio_button_3 = customtkinter.CTkRadioButton(master=self.frame_right,
|
|
variable=self.radio_var,
|
|
value=2)
|
|
self.radio_button_3.grid(row=3, column=2, pady=10, padx=20, sticky="n")
|
|
|
|
self.slider_1 = customtkinter.CTkSlider(master=self.frame_right,
|
|
from_=0,
|
|
to=1,
|
|
number_of_steps=3,
|
|
command=self.progressbar.set)
|
|
self.slider_1.grid(row=4, column=0, columnspan=2, pady=10, padx=20, sticky="we")
|
|
|
|
self.slider_2 = customtkinter.CTkSlider(master=self.frame_right,
|
|
command=self.progressbar.set)
|
|
self.slider_2.grid(row=5, column=0, columnspan=2, pady=10, padx=20, sticky="we")
|
|
|
|
self.slider_button_1 = customtkinter.CTkButton(master=self.frame_right,
|
|
height=25,
|
|
text="CTkButton",
|
|
command=self.button_event)
|
|
self.slider_button_1.grid(row=4, column=2, columnspan=1, pady=10, padx=20, sticky="we")
|
|
|
|
self.slider_button_2 = customtkinter.CTkButton(master=self.frame_right,
|
|
height=25,
|
|
text="CTkButton",
|
|
command=self.button_event)
|
|
self.slider_button_2.grid(row=5, column=2, columnspan=1, pady=10, padx=20, sticky="we")
|
|
|
|
self.checkbox_button_1 = customtkinter.CTkButton(master=self.frame_right,
|
|
height=25,
|
|
text="CTkButton",
|
|
border_width=3, # <- custom border_width
|
|
fg_color=None, # <- no fg_color
|
|
command=self.button_event)
|
|
self.checkbox_button_1.grid(row=6, column=2, columnspan=1, pady=10, padx=20, sticky="we")
|
|
|
|
self.check_box_1 = customtkinter.CTkCheckBox(master=self.frame_right,
|
|
text="CTkCheckBox")
|
|
self.check_box_1.grid(row=6, column=0, pady=10, padx=20, sticky="w")
|
|
|
|
self.check_box_2 = customtkinter.CTkCheckBox(master=self.frame_right,
|
|
text="CTkCheckBox")
|
|
self.check_box_2.grid(row=6, column=1, pady=10, padx=20, sticky="w")
|
|
|
|
self.entry = customtkinter.CTkEntry(master=self.frame_right,
|
|
width=120,
|
|
placeholder_text="CTkEntry")
|
|
self.entry.grid(row=8, column=0, columnspan=2, pady=20, padx=20, sticky="we")
|
|
|
|
self.button_5 = customtkinter.CTkButton(master=self.frame_right,
|
|
text="CTkButton",
|
|
command=self.button_event)
|
|
self.button_5.grid(row=8, column=2, columnspan=1, pady=20, padx=20, sticky="we")
|
|
|
|
# set default values
|
|
self.radio_button_1.select()
|
|
#self.switch_2.select()
|
|
self.slider_1.set(0.2)
|
|
self.slider_2.set(0.7)
|
|
self.progressbar.set(0.5)
|
|
self.slider_button_1.configure(state=tkinter.DISABLED, text="Disabled Button")
|
|
self.radio_button_3.configure(state=tkinter.DISABLED)
|
|
self.check_box_1.configure(state=tkinter.DISABLED, text="CheckBox disabled")
|
|
self.check_box_2.select()
|
|
|
|
def button_event(self):
|
|
print("Button pressed")
|
|
|
|
def change_mode(self):
|
|
if self.switch_2.get() == 1:
|
|
customtkinter.set_appearance_mode("dark")
|
|
else:
|
|
customtkinter.set_appearance_mode("light")
|
|
|
|
def on_closing(self, event=0):
|
|
self.destroy()
|
|
|
|
def start(self):
|
|
self.mainloop()
|
|
|
|
|
|
if __name__ == "__main__":
|
|
app = App()
|
|
app.start()
|