MCPcopy
hub / github.com/TomSchimansky/CustomTkinter

github.com/TomSchimansky/CustomTkinter @v6.0.0 sqlite

repository ↗ · DeepWiki ↗ · release v6.0.0 ↗
748 symbols 2,896 edges 86 files 145 documented · 19%
README
<img src="https://github.com/TomSchimansky/CustomTkinter/raw/v6.0.0/documentation_images/CustomTkinter_logo_light.png">

PyPI PyPI - Downloads Downloads last 6 month PyPI - License Minimum Python Version


Current Developers Contact
Tom Schimansky contact@customtkinter.tomschimansky.com
Federico Spada www.linkedin.com/in/federicospada13

Paypal donation button


Official website: https://customtkinter.tomschimansky.com/

CustomTkinter is a python UI-library based on Tkinter, which provides new, modern and fully customizable widgets. They are created and used like normal Tkinter widgets and can also be used in combination with normal Tkinter elements. The widgets and the window colors either adapt to the system appearance or the manually set mode ('light', 'dark'), and all CustomTkinter widgets and windows support HighDPI scaling (Windows, macOS). With CustomTkinter you'll get a consistent and modern look across all desktop platforms (Windows, macOS, Linux).

| complex_example.py on Windows 11 with dark mode and 'blue' theme

| complex_example.py on macOS in light mode and standard 'blue' theme

Installation

Install the module with pip:

pip3 install customtkinter

Update existing installation: pip3 install customtkinter --upgrade\ (update as often as possible because this library is under active development)

Documentation

The official documentation can be found here:

➡️ https://customtkinter.tomschimansky.com/documentation.

Example Program

To test customtkinter you can try this simple example with only a single button:

import customtkinter

customtkinter.set_appearance_mode("System")  # Modes: system (default), light, dark
customtkinter.set_default_color_theme("blue")  # Themes: blue (default), dark-blue, green

app = customtkinter.CTk()  # create CTk window like you do with the Tk window
app.geometry("400x240")

def button_function():
    print("button pressed")

# Use CTkButton instead of tkinter Button
button = customtkinter.CTkButton(master=app, text="CTkButton", command=button_function)
button.place(relx=0.5, rely=0.5, anchor=customtkinter.CENTER)

app.mainloop()

which results in the following window on macOS:

In the examples folder, you can find more example programs and in the Documentation you can find further information on the appearance mode, scaling, themes and all widgets.

More Examples and Showcase

You can run the following code to show a simple App that displays all available widgets:

import customtkinter as ctk
ctk.run_showroom()

Appearance mode change and scaling change

CustomTkinter can adapt to the Windows 10/11 light or dark mode:

https://user-images.githubusercontent.com/66446067/204672968-6584f360-4c52-434f-9c16-25761341368b.mp4

| complex_example.py on Windows 11 with system appearance mode change and standard 'blue' theme

On macOS you either need python3.10 or higher or the anaconda python version to get a dark window header (Tcl/Tk >= 8.6.9 required):

https://user-images.githubusercontent.com/66446067/204673854-b6cbcfda-d9a1-4425-92a3-5b57d7f2fd6b.mp4

| complex_example.py on macOS with system appearance mode change, user-scaling change and standard 'blue' theme

Button with images

It's possible to put an image on a CTkButton. You just have to pass a PhotoImage object to the CTkButton with the image argument. If you want no text at all you have to set text="" or you specify how to position the text and image at once with the compound option:

| image_example.py on Windows 11

Scrollable Frames

Scrollable frames are possible in vertical or horizontal orientation and can be combined with any other widgets. | scrollable_frame_example.py on Windows 11

Integration of TkinterMapView widget

In the following example I used a TkinterMapView which integrates well with a CustomTkinter program. It's a tile based map widget which displays OpenStreetMap or other tile based maps:

https://user-images.githubusercontent.com/66446067/204675835-1584a8da-5acc-4993-b4a9-e70f06fa14b0.mp4

| examples/map_with_customtkinter.py from TkinterMapView repository on Windows 11

You can find the TkinterMapView library and example program here: https://github.com/TomSchimansky/TkinterMapView

Core symbols most depended-on inside this repo

_apply_appearance_mode
called by 290
customtkinter/windows/widgets/appearance_mode/appearance_mode_base_class.py
_apply_widget_scaling
called by 262
customtkinter/windows/widgets/scaling/scaling_base_class.py
pack
called by 232
customtkinter/windows/widgets/ctk_scrollable_frame.py
grid
called by 197
customtkinter/windows/widgets/ctk_scrollable_frame.py
_check_color_type
called by 159
customtkinter/windows/widgets/appearance_mode/appearance_mode_base_class.py
coords
called by 142
customtkinter/windows/widgets/core_rendering/ctk_canvas.py
itemconfig
called by 99
customtkinter/windows/widgets/core_rendering/ctk_canvas.py
configure
called by 97
customtkinter/windows/ctk_tk.py

Shape

Method 661
Class 47
Function 40

Languages

Python100%

Modules by API surface

customtkinter/windows/widgets/ctk_textbox.py65 symbols
customtkinter/windows/widgets/ctk_entry.py36 symbols
customtkinter/windows/ctk_tk.py27 symbols
customtkinter/windows/widgets/ctk_tabview.py26 symbols
customtkinter/windows/widgets/ctk_scrollable_frame.py26 symbols
customtkinter/windows/widgets/core_widget_classes/ctk_base_class.py26 symbols
customtkinter/windows/ctk_toplevel.py26 symbols
customtkinter/windows/widgets/ctk_optionmenu.py25 symbols
customtkinter/windows/widgets/ctk_switch.py24 symbols
customtkinter/windows/widgets/ctk_slider.py24 symbols
customtkinter/windows/widgets/ctk_segmented_button.py24 symbols
customtkinter/windows/widgets/ctk_combobox.py24 symbols

Dependencies from manifests, versioned

darkdetect0.7.0 · 1×
typing-extensions4.4.0 · 1×

For agents

$ claude mcp add CustomTkinter \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact