mirror of
https://github.com/TomSchimansky/CustomTkinter.git
synced 2023-08-10 21:13:13 +03:00
finished image example
This commit is contained in:
parent
0d8a79d783
commit
f3d90821ce
@ -94,8 +94,6 @@ class CTkFrame(CTkBaseClass):
|
|||||||
def _draw(self, no_color_updates=False):
|
def _draw(self, no_color_updates=False):
|
||||||
super()._draw(no_color_updates)
|
super()._draw(no_color_updates)
|
||||||
|
|
||||||
print("frame draw", no_color_updates)
|
|
||||||
|
|
||||||
if not self._canvas.winfo_exists():
|
if not self._canvas.winfo_exists():
|
||||||
return
|
return
|
||||||
|
|
||||||
|
@ -16,6 +16,9 @@ class App(customtkinter.CTk):
|
|||||||
|
|
||||||
# load images with light and dark mode image
|
# load images with light and dark mode image
|
||||||
image_path = os.path.join(os.path.dirname(os.path.realpath(__file__)), "test_images")
|
image_path = os.path.join(os.path.dirname(os.path.realpath(__file__)), "test_images")
|
||||||
|
self.logo_image = customtkinter.CTkImage(Image.open(os.path.join(image_path, "CustomTkinter_logo_single.png")), size=(26, 26))
|
||||||
|
self.large_test_image = customtkinter.CTkImage(Image.open(os.path.join(image_path, "large_test_image.png")), size=(500, 150))
|
||||||
|
self.image_icon_image = customtkinter.CTkImage(Image.open(os.path.join(image_path, "image_icon_light.png")), size=(20, 20))
|
||||||
self.home_image = customtkinter.CTkImage(light_image=Image.open(os.path.join(image_path, "home_dark.png")),
|
self.home_image = customtkinter.CTkImage(light_image=Image.open(os.path.join(image_path, "home_dark.png")),
|
||||||
dark_image=Image.open(os.path.join(image_path, "home_light.png")), size=(20, 20))
|
dark_image=Image.open(os.path.join(image_path, "home_light.png")), size=(20, 20))
|
||||||
self.chat_image = customtkinter.CTkImage(light_image=Image.open(os.path.join(image_path, "chat_dark.png")),
|
self.chat_image = customtkinter.CTkImage(light_image=Image.open(os.path.join(image_path, "chat_dark.png")),
|
||||||
@ -28,22 +31,24 @@ class App(customtkinter.CTk):
|
|||||||
self.navigation_frame.grid(row=0, column=0, sticky="nsew")
|
self.navigation_frame.grid(row=0, column=0, sticky="nsew")
|
||||||
self.navigation_frame.grid_rowconfigure(4, weight=1)
|
self.navigation_frame.grid_rowconfigure(4, weight=1)
|
||||||
|
|
||||||
self.navigation_frame_label = customtkinter.CTkLabel(self.navigation_frame, text="Image Example",
|
self.navigation_frame_label = customtkinter.CTkLabel(self.navigation_frame, text=" Image Example", image=self.logo_image,
|
||||||
font=customtkinter.CTkFont(size=18, weight="bold"))
|
compound="left", font=customtkinter.CTkFont(size=15, weight="bold"))
|
||||||
self.navigation_frame_label.grid(row=0, column=0, padx=20, pady=20)
|
self.navigation_frame_label.grid(row=0, column=0, padx=20, pady=20)
|
||||||
|
|
||||||
self.home_button = customtkinter.CTkButton(self.navigation_frame, corner_radius=0, height=40, border_spacing=10, text="Home",
|
self.home_button = customtkinter.CTkButton(self.navigation_frame, corner_radius=0, height=40, border_spacing=10, text="Home",
|
||||||
fg_color="transparent", text_color=("gray10", "gray90"), hover_color=("gray70", "gray30"),
|
fg_color="transparent", text_color=("gray10", "gray90"), hover_color=("gray70", "gray30"),
|
||||||
image=self.home_image, anchor="w", command=self.home_button_event)
|
image=self.home_image, anchor="w", command=self.home_button_event)
|
||||||
self.home_button.grid(row=1, column=0, sticky="ew")
|
self.home_button.grid(row=1, column=0, sticky="ew")
|
||||||
self.chat_button = customtkinter.CTkButton(self.navigation_frame, corner_radius=0, height=40, border_spacing=10, text="New Chat",
|
|
||||||
|
self.frame_2_button = customtkinter.CTkButton(self.navigation_frame, corner_radius=0, height=40, border_spacing=10, text="Frame 2",
|
||||||
fg_color="transparent", text_color=("gray10", "gray90"), hover_color=("gray70", "gray30"),
|
fg_color="transparent", text_color=("gray10", "gray90"), hover_color=("gray70", "gray30"),
|
||||||
image=self.chat_image, anchor="w", command=self.chat_button_event)
|
image=self.chat_image, anchor="w", command=self.frame_2_button_event)
|
||||||
self.chat_button.grid(row=2, column=0, sticky="ew")
|
self.frame_2_button.grid(row=2, column=0, sticky="ew")
|
||||||
self.add_user_button = customtkinter.CTkButton(self.navigation_frame, corner_radius=0, height=40, border_spacing=10, text="Add User",
|
|
||||||
|
self.frame_3_button = customtkinter.CTkButton(self.navigation_frame, corner_radius=0, height=40, border_spacing=10, text="Frame 3",
|
||||||
fg_color="transparent", text_color=("gray10", "gray90"), hover_color=("gray70", "gray30"),
|
fg_color="transparent", text_color=("gray10", "gray90"), hover_color=("gray70", "gray30"),
|
||||||
image=self.add_user_image, anchor="w", command=self.add_user_button_event)
|
image=self.add_user_image, anchor="w", command=self.frame_3_button_event)
|
||||||
self.add_user_button.grid(row=3, column=0, sticky="ew")
|
self.frame_3_button.grid(row=3, column=0, sticky="ew")
|
||||||
|
|
||||||
self.appearance_mode_menu = customtkinter.CTkOptionMenu(self.navigation_frame, values=["Light", "Dark", "System"],
|
self.appearance_mode_menu = customtkinter.CTkOptionMenu(self.navigation_frame, values=["Light", "Dark", "System"],
|
||||||
command=self.change_appearance_mode_event)
|
command=self.change_appearance_mode_event)
|
||||||
@ -51,12 +56,25 @@ class App(customtkinter.CTk):
|
|||||||
|
|
||||||
# create home frame
|
# create home frame
|
||||||
self.home_frame = customtkinter.CTkFrame(self, corner_radius=0, fg_color="transparent")
|
self.home_frame = customtkinter.CTkFrame(self, corner_radius=0, fg_color="transparent")
|
||||||
|
self.home_frame.grid_columnconfigure(0, weight=1)
|
||||||
|
|
||||||
# create chat frame
|
self.home_frame_large_image_label = customtkinter.CTkLabel(self.home_frame, text="", image=self.large_test_image)
|
||||||
self.chat_frame = customtkinter.CTkFrame(self, corner_radius=0, fg_color="transparent")
|
self.home_frame_large_image_label.grid(row=0, column=0, padx=20, pady=10)
|
||||||
|
|
||||||
# create add user frame
|
self.home_frame_button_1 = customtkinter.CTkButton(self.home_frame, text="", image=self.image_icon_image)
|
||||||
self.add_user_frame = customtkinter.CTkFrame(self, corner_radius=0, fg_color="transparent")
|
self.home_frame_button_1.grid(row=1, column=0, padx=20, pady=10)
|
||||||
|
self.home_frame_button_2 = customtkinter.CTkButton(self.home_frame, text="CTkButton", image=self.image_icon_image, compound="right")
|
||||||
|
self.home_frame_button_2.grid(row=2, column=0, padx=20, pady=10)
|
||||||
|
self.home_frame_button_3 = customtkinter.CTkButton(self.home_frame, text="CTkButton", image=self.image_icon_image, compound="top")
|
||||||
|
self.home_frame_button_3.grid(row=3, column=0, padx=20, pady=10)
|
||||||
|
self.home_frame_button_4 = customtkinter.CTkButton(self.home_frame, text="CTkButton", image=self.image_icon_image, compound="top", anchor="w")
|
||||||
|
self.home_frame_button_4.grid(row=4, column=0, padx=20, pady=10)
|
||||||
|
|
||||||
|
# create second frame
|
||||||
|
self.second_frame = customtkinter.CTkFrame(self, corner_radius=0, fg_color="transparent")
|
||||||
|
|
||||||
|
# create third frame
|
||||||
|
self.third_frame = customtkinter.CTkFrame(self, corner_radius=0, fg_color="transparent")
|
||||||
|
|
||||||
# select default frame
|
# select default frame
|
||||||
self.select_frame_by_name("home")
|
self.select_frame_by_name("home")
|
||||||
@ -64,31 +82,31 @@ class App(customtkinter.CTk):
|
|||||||
def select_frame_by_name(self, name):
|
def select_frame_by_name(self, name):
|
||||||
# set button color for selected button
|
# set button color for selected button
|
||||||
self.home_button.configure(fg_color=("gray75", "gray25") if name == "home" else "transparent")
|
self.home_button.configure(fg_color=("gray75", "gray25") if name == "home" else "transparent")
|
||||||
self.chat_button.configure(fg_color=("gray75", "gray25") if name == "chat" else "transparent")
|
self.frame_2_button.configure(fg_color=("gray75", "gray25") if name == "frame_2" else "transparent")
|
||||||
self.add_user_button.configure(fg_color=("gray75", "gray25") if name == "add_user" else "transparent")
|
self.frame_3_button.configure(fg_color=("gray75", "gray25") if name == "frame_3" else "transparent")
|
||||||
|
|
||||||
# show selected frame
|
# show selected frame
|
||||||
if name == "home":
|
if name == "home":
|
||||||
self.home_frame.grid(row=0, column=1, sticky="nsew")
|
self.home_frame.grid(row=0, column=1, sticky="nsew")
|
||||||
else:
|
else:
|
||||||
self.home_frame.grid_forget()
|
self.home_frame.grid_forget()
|
||||||
if name == "home":
|
if name == "frame_2":
|
||||||
self.home_frame.grid(row=0, column=1, sticky="nsew")
|
self.second_frame.grid(row=0, column=1, sticky="nsew")
|
||||||
else:
|
else:
|
||||||
self.home_frame.grid_forget()
|
self.second_frame.grid_forget()
|
||||||
if name == "home":
|
if name == "frame_3":
|
||||||
self.home_frame.grid(row=0, column=1, sticky="nsew")
|
self.third_frame.grid(row=0, column=1, sticky="nsew")
|
||||||
else:
|
else:
|
||||||
self.home_frame.grid_forget()
|
self.third_frame.grid_forget()
|
||||||
|
|
||||||
def home_button_event(self):
|
def home_button_event(self):
|
||||||
self.select_frame_by_name("home")
|
self.select_frame_by_name("home")
|
||||||
|
|
||||||
def chat_button_event(self):
|
def frame_2_button_event(self):
|
||||||
self.select_frame_by_name("chat")
|
self.select_frame_by_name("frame_2")
|
||||||
|
|
||||||
def add_user_button_event(self):
|
def frame_3_button_event(self):
|
||||||
self.select_frame_by_name("add_user")
|
self.select_frame_by_name("frame_3")
|
||||||
|
|
||||||
def change_appearance_mode_event(self, new_appearance_mode):
|
def change_appearance_mode_event(self, new_appearance_mode):
|
||||||
customtkinter.set_appearance_mode(new_appearance_mode)
|
customtkinter.set_appearance_mode(new_appearance_mode)
|
||||||
|
BIN
examples/test_images/CustomTkinter_logo_single.png
Normal file
BIN
examples/test_images/CustomTkinter_logo_single.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 198 KiB |
BIN
examples/test_images/image_icon_light.png
Normal file
BIN
examples/test_images/image_icon_light.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 5.9 KiB |
BIN
examples/test_images/large_test_image.png
Normal file
BIN
examples/test_images/large_test_image.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.3 MiB |
Loading…
x
Reference in New Issue
Block a user