mirror of
https://github.com/TomSchimansky/CustomTkinter.git
synced 2023-08-10 21:13:13 +03:00
changed Readme.md
This commit is contained in:
parent
341f836f4e
commit
5ede252b2f
Binary file not shown.
Before Width: | Height: | Size: 12 MiB After Width: | Height: | Size: 20 MiB |
@ -19,17 +19,13 @@ class App(customtkinter.CTk):
|
|||||||
self.geometry(f"{App.WIDTH}x{App.HEIGHT}")
|
self.geometry(f"{App.WIDTH}x{App.HEIGHT}")
|
||||||
# self.minsize(App.WIDTH, App.HEIGHT)
|
# self.minsize(App.WIDTH, App.HEIGHT)
|
||||||
|
|
||||||
self.protocol("WM_DELETE_WINDOW", self.on_closing)
|
self.protocol("WM_DELETE_WINDOW", self.on_closing) # call .on_closing() when app gets closed
|
||||||
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 ============
|
# ============ create two frames ============
|
||||||
|
|
||||||
# configure grid layout (1x2)
|
# configure grid layout (2x1)
|
||||||
self.grid_columnconfigure(1, weight=1)
|
self.grid_columnconfigure(1, weight=1)
|
||||||
self.rowconfigure(0, weight=1)
|
self.grid_rowconfigure(0, weight=1)
|
||||||
|
|
||||||
self.frame_left = customtkinter.CTkFrame(master=self,
|
self.frame_left = customtkinter.CTkFrame(master=self,
|
||||||
width=180,
|
width=180,
|
||||||
@ -41,7 +37,7 @@ class App(customtkinter.CTk):
|
|||||||
|
|
||||||
# ============ frame_left ============
|
# ============ frame_left ============
|
||||||
|
|
||||||
# configure grid layout
|
# configure grid layout (1x11)
|
||||||
self.frame_left.grid_rowconfigure(0, minsize=10) # empty row with minsize as spacing
|
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(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(8, minsize=20) # empty row with minsize as spacing
|
||||||
@ -81,18 +77,17 @@ class App(customtkinter.CTk):
|
|||||||
# ============ frame_right ============
|
# ============ frame_right ============
|
||||||
|
|
||||||
# configure grid layout (3x7)
|
# configure grid layout (3x7)
|
||||||
for i in [0, 1, 2, 3]:
|
self.frame_right.rowconfigure((0, 1, 2, 3), weight=1)
|
||||||
self.frame_right.rowconfigure(i, weight=1)
|
|
||||||
self.frame_right.rowconfigure(7, weight=10)
|
self.frame_right.rowconfigure(7, weight=10)
|
||||||
self.frame_right.columnconfigure(0, weight=1)
|
self.frame_right.columnconfigure((0, 1), weight=1)
|
||||||
self.frame_right.columnconfigure(1, weight=1)
|
|
||||||
self.frame_right.columnconfigure(2, weight=0)
|
self.frame_right.columnconfigure(2, weight=0)
|
||||||
|
|
||||||
self.frame_info = customtkinter.CTkFrame(master=self.frame_right)
|
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")
|
self.frame_info.grid(row=0, column=0, columnspan=2, rowspan=4, pady=20, padx=20, sticky="nsew")
|
||||||
|
|
||||||
# ============ frame_right -> frame_info ============
|
# ============ frame_info ============
|
||||||
|
|
||||||
|
# configure grid layout (1x1)
|
||||||
self.frame_info.rowconfigure(0, weight=1)
|
self.frame_info.rowconfigure(0, weight=1)
|
||||||
self.frame_info.columnconfigure(0, weight=1)
|
self.frame_info.columnconfigure(0, weight=1)
|
||||||
|
|
||||||
@ -108,7 +103,8 @@ class App(customtkinter.CTk):
|
|||||||
self.progressbar = customtkinter.CTkProgressBar(master=self.frame_info)
|
self.progressbar = customtkinter.CTkProgressBar(master=self.frame_info)
|
||||||
self.progressbar.grid(row=1, column=0, sticky="ew", padx=15, pady=15)
|
self.progressbar.grid(row=1, column=0, sticky="ew", padx=15, pady=15)
|
||||||
|
|
||||||
# ============ frame_right <- ============
|
# ============ frame_right ============
|
||||||
|
|
||||||
self.radio_var = tkinter.IntVar(value=0)
|
self.radio_var = tkinter.IntVar(value=0)
|
||||||
|
|
||||||
self.label_radio_group = customtkinter.CTkLabel(master=self.frame_right,
|
self.label_radio_group = customtkinter.CTkLabel(master=self.frame_right,
|
||||||
|
@ -1,181 +0,0 @@
|
|||||||
import tkinter
|
|
||||||
import tkinter.messagebox
|
|
||||||
import customtkinter
|
|
||||||
import sys
|
|
||||||
|
|
||||||
# Set dark appearance mode:
|
|
||||||
customtkinter.set_appearance_mode("Dark") # Modes: "System" (standard), "Dark", "Light"
|
|
||||||
|
|
||||||
|
|
||||||
class App(customtkinter.CTk):
|
|
||||||
|
|
||||||
APP_NAME = "CustomTkinter complex example"
|
|
||||||
WIDTH = 700
|
|
||||||
HEIGHT = 500
|
|
||||||
|
|
||||||
MAIN_COLOR = "#5EA880"
|
|
||||||
MAIN_COLOR_DARK = "#2D5862"
|
|
||||||
MAIN_HOVER = "#458577"
|
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
|
||||||
super().__init__(*args, **kwargs)
|
|
||||||
|
|
||||||
self.title(App.APP_NAME)
|
|
||||||
self.geometry(str(App.WIDTH) + "x" + str(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 CTkFrames ============
|
|
||||||
|
|
||||||
self.frame_left = customtkinter.CTkFrame(master=self,
|
|
||||||
width=200,
|
|
||||||
height=App.HEIGHT-40,
|
|
||||||
corner_radius=5)
|
|
||||||
self.frame_left.place(relx=0.32, rely=0.5, anchor=tkinter.E)
|
|
||||||
|
|
||||||
self.frame_right = customtkinter.CTkFrame(master=self,
|
|
||||||
width=420,
|
|
||||||
height=App.HEIGHT-40,
|
|
||||||
corner_radius=5)
|
|
||||||
self.frame_right.place(relx=0.365, rely=0.5, anchor=tkinter.W)
|
|
||||||
|
|
||||||
# ============ frame_left ============
|
|
||||||
|
|
||||||
self.button_1 = customtkinter.CTkButton(master=self.frame_left,
|
|
||||||
border_color=App.MAIN_COLOR,
|
|
||||||
fg_color=None,
|
|
||||||
hover_color=App.MAIN_HOVER,
|
|
||||||
text="CTkButton",
|
|
||||||
command=self.button_event,
|
|
||||||
border_width=3,
|
|
||||||
corner_radius=6)
|
|
||||||
self.button_1.place(relx=0.5, y=50, anchor=tkinter.CENTER)
|
|
||||||
|
|
||||||
self.button_2 = customtkinter.CTkButton(master=self.frame_left,
|
|
||||||
border_color=App.MAIN_COLOR,
|
|
||||||
fg_color=None,
|
|
||||||
hover_color=App.MAIN_HOVER,
|
|
||||||
text="CTkButton",
|
|
||||||
command=self.button_event,
|
|
||||||
border_width=3,
|
|
||||||
corner_radius=6)
|
|
||||||
self.button_2.place(relx=0.5, y=100, anchor=tkinter.CENTER)
|
|
||||||
|
|
||||||
self.button_3 = customtkinter.CTkButton(master=self.frame_left,
|
|
||||||
border_color=App.MAIN_COLOR,
|
|
||||||
fg_color=None,
|
|
||||||
hover_color=App.MAIN_HOVER,
|
|
||||||
text="CTkButton",
|
|
||||||
command=self.button_event,
|
|
||||||
border_width=3,
|
|
||||||
corner_radius=6)
|
|
||||||
self.button_3.place(relx=0.5, y=150, anchor=tkinter.CENTER)
|
|
||||||
|
|
||||||
# ============ frame_right ============
|
|
||||||
|
|
||||||
self.frame_info = customtkinter.CTkFrame(master=self.frame_right,
|
|
||||||
width=380,
|
|
||||||
height=200,
|
|
||||||
corner_radius=5)
|
|
||||||
self.frame_info.place(relx=0.5, y=20, anchor=tkinter.N)
|
|
||||||
|
|
||||||
# ============ frame_right -> frame_info ============
|
|
||||||
|
|
||||||
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\n" +
|
|
||||||
"invidunt ut labore",
|
|
||||||
width=250,
|
|
||||||
height=100,
|
|
||||||
corner_radius=6,
|
|
||||||
fg_color=("white", "gray20"),
|
|
||||||
text_color=App.MAIN_COLOR,
|
|
||||||
justify=tkinter.LEFT)
|
|
||||||
self.label_info_1.place(relx=0.5, rely=0.15, anchor=tkinter.N)
|
|
||||||
|
|
||||||
self.progressbar = customtkinter.CTkProgressBar(master=self.frame_info,
|
|
||||||
progress_color=App.MAIN_COLOR,
|
|
||||||
width=250,
|
|
||||||
height=12)
|
|
||||||
self.progressbar.place(relx=0.5, rely=0.85, anchor=tkinter.S)
|
|
||||||
self.progressbar.set(0.65)
|
|
||||||
|
|
||||||
# ============ frame_right <- ============
|
|
||||||
|
|
||||||
self.slider_1 = customtkinter.CTkSlider(master=self.frame_right,
|
|
||||||
button_color=App.MAIN_COLOR,
|
|
||||||
button_hover_color=App.MAIN_HOVER,
|
|
||||||
width=160,
|
|
||||||
height=16,
|
|
||||||
number_of_steps=3,
|
|
||||||
border_width=5,
|
|
||||||
command=self.progressbar.set)
|
|
||||||
self.slider_1.place(x=20, rely=0.6, anchor=tkinter.W)
|
|
||||||
self.slider_1.set(0.3)
|
|
||||||
|
|
||||||
self.slider_2 = customtkinter.CTkSlider(master=self.frame_right,
|
|
||||||
button_color=App.MAIN_COLOR,
|
|
||||||
button_hover_color=App.MAIN_HOVER,
|
|
||||||
width=160,
|
|
||||||
height=16,
|
|
||||||
border_width=5,
|
|
||||||
command=self.progressbar.set)
|
|
||||||
self.slider_2.place(x=20, rely=0.7, anchor=tkinter.W)
|
|
||||||
self.slider_2.set(0.7)
|
|
||||||
|
|
||||||
self.label_info_2 = customtkinter.CTkLabel(master=self.frame_right,
|
|
||||||
text="CTkLabel: Lorem ipsum",
|
|
||||||
fg_color=None,
|
|
||||||
width=180,
|
|
||||||
height=20,
|
|
||||||
justify=tkinter.CENTER)
|
|
||||||
self.label_info_2.place(x=310, rely=0.6, anchor=tkinter.CENTER)
|
|
||||||
|
|
||||||
self.button_4 = customtkinter.CTkButton(master=self.frame_right,
|
|
||||||
border_color=App.MAIN_COLOR,
|
|
||||||
fg_color=None,
|
|
||||||
hover_color=App.MAIN_HOVER,
|
|
||||||
height=28,
|
|
||||||
text="CTkButton",
|
|
||||||
command=self.button_event,
|
|
||||||
border_width=3,
|
|
||||||
corner_radius=6)
|
|
||||||
self.button_4.place(x=310, rely=0.7, anchor=tkinter.CENTER)
|
|
||||||
|
|
||||||
self.entry = customtkinter.CTkEntry(master=self.frame_right,
|
|
||||||
width=120,
|
|
||||||
height=28,
|
|
||||||
corner_radius=6)
|
|
||||||
self.entry.place(relx=0.33, rely=0.92, anchor=tkinter.CENTER)
|
|
||||||
self.entry.insert(0, "CTkEntry")
|
|
||||||
|
|
||||||
self.button_5 = customtkinter.CTkButton(master=self.frame_right,
|
|
||||||
border_color=App.MAIN_COLOR,
|
|
||||||
fg_color=None,
|
|
||||||
hover_color=App.MAIN_HOVER,
|
|
||||||
height=28,
|
|
||||||
text="CTkButton",
|
|
||||||
command=self.button_event,
|
|
||||||
border_width=3,
|
|
||||||
corner_radius=6)
|
|
||||||
self.button_5.place(relx=0.66, rely=0.92, anchor=tkinter.CENTER)
|
|
||||||
|
|
||||||
def button_event(self):
|
|
||||||
print("Button pressed")
|
|
||||||
|
|
||||||
def on_closing(self, event=0):
|
|
||||||
self.destroy()
|
|
||||||
|
|
||||||
def start(self):
|
|
||||||
self.mainloop()
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
|
||||||
app = App()
|
|
||||||
app.start()
|
|
Loading…
Reference in New Issue
Block a user