Skip to content

ZikPin/CTkDataVisualizingWidgets

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 

Repository files navigation

CTkDataVisualizingWidgets

Custom data visualizing widgets like calendar, graph and chart.

CTkCalendar

A calendar widget consists of two parts title_bar and calendar frame. You can customize virtually everything in the widget. There is also an option to define the current day, if you define today_fg_color

Basic view on the left and with little customization on the right:

image

To use just init the class and pass the parent (the only required argument). The parameters starting with title_bar are responsible for widgets inside the title bar and the ones starting with the calendar are responsible for the frame where the calendar is displayed

Creating the customized widget on the preview:

from CTkDataVisualizingWidgets import *
import customtkinter as ctk

window = ctk.CTk()
window.title("Calendar Widget")
ctk.set_appearance_mode("dark")

# init calendar
calendar_widget = CTkCalendar(window, width=300, height=210, border_width=3, border_color="white",
                              fg_color="#020317", title_bar_border_width=3, title_bar_border_color="white",
                              title_bar_fg_color="#020F43", calendar_fg_color="#020F43", corner_radius=30,
                              title_bar_corner_radius=10, calendar_corner_radius=10, calendar_border_color="white",
                              calendar_border_width=3, calendar_label_pad=5,
                              today_fg_color="white", today_text_color="black")
calendar_widget.pack(side="left", padx=20)

window.mainloop()

CTkCalendarStat

The CalendarStat widget displays certain months, each day is rendered as Label. The background of the label is determined by the data parameter. If the value of the date differs from the average by 20% it takes the 2nd color of data_colors, if less 1st color and if more 3rd color.

Basic view on the left and with customization on the right:

image

To use just init the class and pass the parent and data. The parameters starting with title_bar are responsible for widgets inside the title bar and the ones starting with the calendar are responsible for the frame where the calendar is displayed

Creating the customized widget on the preview:

import customtkinter as ctk
from ctk_calendar_stat import CTkCalendarStat

window = ctk.CTk()
window.title("CalendarStat Widget")
ctk.set_appearance_mode("dark")

values = {(12, 7, 2023): 10,
          (15, 7, 2023): 3,
          (17, 7, 2023): 6,
          (26, 7, 2023): 7,
          (4, 7, 2023): 8,
          (9, 7, 2023): 8,
          (21, 7, 2023): 1,
          (13, 7, 2023): 7,
          (8, 7, 2023): 17}

CTkCalendarStat(window, values, width=300, height=210, border_width=3, border_color="white",
                              fg_color="#020317", title_bar_border_width=3, title_bar_border_color="white",
                              title_bar_fg_color="#020F43", calendar_fg_color="#020F43", corner_radius=30,
                              title_bar_corner_radius=10, calendar_corner_radius=10, calendar_border_color="white",
                              calendar_border_width=3, calendar_label_pad=5, data_colors=["blue", "green", "red"]
                ).pack(side="left", padx=20)

window.mainloop()

CTkGraph

The graph widgets lets you visualize the list of integer values as a graph. You can customize almost every part, except for corner radius of canvas (where the graph is drawn). You can also set a custom title and define its family, size and color. If you do not define a title the widget will display only the graph

Default view on left and with customization on the right:

image

To use just define parent and supply with list of integers. Example code:

from CTkDataVisualizingWidgets import *
import customtkinter as ctk

window = ctk.CTk()
window.title("Calendar Widget")
ctk.set_appearance_mode("dark")

values = [49, 76, 61, 65, 51, 24, 9, 29, 53, 24]

CTkGraph(window, values, width=250, height=200, fg_color="#FF7761", graph_color="#FF7761",
         graph_fg_color="#FF5330", title="Screentime", title_font_size=30, corner_radius=20).pack(side="left", padx=20, pady=20)

window.mainloop()

CTkChart

This is widget to create a chart representation of a dict[str, int]. It takes str of the dict as a key and a title for certain stat and int or float for that matter as the value and draws it on the canvas. There are also indicators like average and max value.

You can also set title, if you do not define it, it wont be rendered.

There are two values with tuple[bool, bool] format:

  • stat_info_show: first bool is responsible for drawing the value in the stat, second for drawing title
  • show_indicators: first bool is responsible for max value, second for average.

Default view on the left and with customization on the right:

image

Example code to create the widget:

from CTkDataVisualizingWidgets import *
import customtkinter as ctk

window = ctk.CTk()
window.title("Calendar Widget")
ctk.set_appearance_mode("dark")

value = {'JJ': 5, 'OO': 0, 'WW': 7, 'TT': 3, 'GG': 15, 'FF': 10, 'HH': 1, 'PP': 12, "AA": 4}
CTkChart(window, value, corner_radius=20, fg_color="#032680", stat_color="#1D6FFF", chart_fg_color="#032680",
         show_indicators=(False, True), stat_info_show=(False, True), chart_arrow="none", border_width=2,
         border_color="white", indicator_line_color="#1942AC", indicator_text_color="#020F43", stat_width=15,
         stat_title_color="#1D6FFF", chart_axis_width=3, width=300, height=200).pack(side="left", pady=20, padx=20)

window.mainloop()

About

Custom calendar, graph and chart widgets

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages