Usage Guide | Examples | Parameter Explanation | Whats New ?
-
Installation
pip install ctkchart
-
Importing
import ctkchart
Creating a Line | Display of data
linechart = ctkchart.CTkLineChart()
Parameter | Required / Optional | Description | Types | Example Value(s) |
---|---|---|---|---|
master | Required | Master Widget for LineChart | widget |
widget |
y_axis_values | Required | Minimum and maximum values for y-axis | tuple[int | float] |
(-1000, 1000), ... |
x_axis_values | Required | Values for x-axis | tuple[any] |
(1, 2, 3, 4, 5), ... |
width | Optional | Width of the chart | int |
300, ... |
height | Optional | Height of the chart | int |
100, ... |
axis_size | Optional | Size of the axis | int |
1<= |
axis_color | Optional | Color of the axis | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
bg_color | Optional | Background color of the chart | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
fg_color | Optional | Foreground color of the chart | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
data_font_style | Optional | Font style for data labels | tuple[str, int, str] |
("arial", 9, "bold"), ... |
axis_font_style | Optional | Font style for axis labels | tuple[str, int, str] |
("arial", 8, "normal"), ... |
x_axis_data | Optional | Data label for x-axis | str |
"X", ... |
y_axis_data | Optional | Value for y-axi data label | any |
"Y", ... |
x_axis_data_font_color | Optional | Font color for x-axis data label | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
y_axis_data_font_color | Optional | Font color for y-axis data label | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
x_axis_data_position | Optional | Position of x-axis data label | str ("top", "side") |
"top" |
y_axis_data_position | Optional | Position of y-axis data label | str ("top", "side") |
"top" |
x_axis_section_count | Optional | Number of sections on the x-axis | int |
0<= |
y_axis_section_count | Optional | Number of sections on the y-axis | int |
0<= |
x_axis_label_count | Optional | Number of x-axis labels | int |
0<= |
y_axis_label_count | Optional | Number of y-axis labels | int |
1<= |
x_axis_font_color | Optional | Font color for x-axis labels | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
y_axis_font_color | Optional | Font color for y-axis labels | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
x_axis_section_style | Optional | Style of sections on the x-axis | str ("normal", "dashed") |
"normal" |
y_axis_section_style | Optional | Style of sections on the y-axis | str ("normal", "dashed") |
"normal" |
x_axis_section_style_type | Optional | Style type for sections on the x-axis | tuple[int, int] |
(100, 50), ... |
y_axis_section_style_type | Optional | Style type for sections on the y-axis | tuple[int, int] |
(100, 50) |
x_axis_section_color | Optional | Color of sections on the x-axis | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
y_axis_section_color | Optional | Color of sections on the y-axis | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
y_axis_precision | Optional | Precision for y-axis values | int |
0<= |
x_axis_display_values_indices | Optional | Indices of values to display on the x-axis | tuple[int, ...] |
(0, 1, 2, 3, 4, 5), ... |
x_axis_point_spacing | Optional | Width of lines | int | str "auto" |
"auto" 1<= |
x_space | Optional | Space between x-axis and chart area | int |
0<= |
y_space | Optional | Space between y-axis and chart area | int |
0<= |
pointer_state | Optional | State of the pointer | str ("enabled", "disabled") |
"disabled" |
pointing_callback_function | Optional | Callback function for pointer | callable |
function(*args) function(x, y) |
pointer_color | Optional | Color of the pointer | tuple[str, str] | str |
("#FF0000", "#00FF00"), ... |
pointing_values_precision | Optional | Precision for pointing values | int |
0<= |
pointer_lock | Optional | State of pointer lock | str ("enabled", "disabled") |
"enabled" |
pointer_size | Optional | Size of the pointer | int |
1<= |
Method | Description | Supported / Required Parameters | Return Type |
---|---|---|---|
configure | Change LineChart attributes | All attributes except for master | None |
show_data | Display data | data: list line: ctkchart.CTkLine |
None |
place | Place LineChart | x: int y: int rely: float or int relx: float or int anchor: str |
None |
pack | Pack LineChart | pady: int padx: int before: widget after: widget side: str anchor: str |
None |
grid | Grid LineChart | column: int columnspan: int padx: int pady: int row: int rowspan: int sticky: str |
None |
place_forget | Place forget the chart | - | None |
pack_forget | Pack forget the chart | - | None |
grid_forget | Grid forget the chart | - | None |
set_lines_visibility | Change the visibility of all the lines | state: bool |
None |
set_line_visibility | Change the visibility of a specific line | line: ctkchart.CTkLine state: bool |
None |
get_line_visibility | Get the visibility of a specific line | line: ctkchart.CTkLine |
bool |
reset | Reset line chart | - | None |
cget | Get the value of the specified parameter | attribute_name: str | "__all__" |
any |
place_info | Get info about place | attribute_name: str | "__all__" |
any |
pack_info | Get info about pack | attribute_name: str | "__all__" |
any |
grid_info | Get info about grid | attribute_name: str | "__all__" |
any |
get_line_area | Get the are of specific line | line: ctkchart.CTkLine |
float |
get_lines_area | Get the are of all lines | - | float |
destroy | Destroy the chart | - | None |
clear_data | Clears the data for all lines within the chart, ensuring that only the most recent visible data points are retained. If the total data points exceed the maximum visible points, the older data is removed from each line's data. This method ensures that the chart displays only the relevant portion of data based on the maximum visible range. | - | None |
get_lines_data | Retrieves data points for all lines within a specified range with an optional step value. | start: int end: int step: int |
Dict[ctkchart.CTkLine, Tuple[int]] |
get_line_data | Retrieves data points for a specific line within a specified range and step. | line: ctkchart.CTkLine start: int end: int step: int |
Tuple[int | float] |
get_x_axis_visible_point_count | Retrieves the maximum number of data points that can be visible along the X-axis. | - | int |
get_lines_visible_data | Retrieves currently visible data points for all lines based on the maximum data length and visible points. | - | Dict[ctkchart.CTkLine, Tuple[int | float]] |
get_line_visible_data | Retrieves currently visible data points for a specific line. | line: ctkchart.CTkLine |
Tuple[int | float] |
Creating a LineChart | Display of data
line = ctkchart.CTkLine()
Parameter Name | Required / Optional | Description | Types | Example Value(s) |
---|---|---|---|---|
master | Required | Master of the line | ctkchart.CTkLine |
LineChart obj |
color | Optional | Color of the line | tuple[str, str] | str |
"#768df1" |
size | Optional | Size of the line | int |
1<= |
style | Optional | Style of the line | str ("normal", "dashed", "dotted") |
"normal" |
style_type | Optional | Style type for the line | tuple[int, int] |
(10, 5),... |
point_highlight | Optional | State of point highlighting | str ("enabled", "disabled") |
"disabled" |
point_highlight_size | Optional | Size of the highlighted point | int |
1<= |
point_highlight_color | Optional | Color of the highlighted point | tuple[str, str] | str |
"#768df1" |
fill | Optional | State of filling | str ("enabled", "disabled") |
"disabled" |
fill_color | Optional | Color of the fill | tuple[str, str] | str |
"#5d6db6" |
Method | Description | Supported Parameters | Return Type |
---|---|---|---|
configure | Change LineChart attributes | All attributes except for master | None |
cget | Get the value of the specified parameter | attribute_name: str | "__all__" |
any |
reset | reset line object | - | None |
set_visible | change the visibility of the line | state: bool |
None |
get_visibility | get the visibility of the line | - | bool |
clear_data | Clears the data for a specific line, ensuring that only the most recent visible data points are retained. If the line's data exceeds the maximum visible points, the older data is trimmed. This method allows each line to independently clean its data, ensuring it remains within the visible range. | - | None |
destroy | Destroy the line | - | None |
get_data | Retrieves data points from a specified range with an optional step value. If no parameters are given, it returns all available data. | start: int end: int step: int |
Tuple[int | float] |
get_current_visible_data | Returns the currently visible data points based on the maximum data length across all lines and the maximum number of visible points. | - | Tuple[int | float] |
get_x_axis_visible_point_count | Retrieves the maximum number of data points that can be visible along the X-axis. | - | int |
Creating a LineChart | Creating a Line
import tkinter as tk
import ctkchart
import random
#root
root = tk.Tk()
root.configure(bg="#151515")
#creating a chart
chart = ctkchart.CTkLineChart(
master=root,
x_axis_values = (1, 2, 3, 4, 5, 6, 7, 8, 9, 10),
y_axis_values = (-100,100)
)
chart.pack()
#creating a line
line = ctkchart.CTkLine(master=chart)
data = [x for x in range(-100,101)] #values -100 to 100
#dipslay data (random)
def loop():
chart.show_data(line=line, data=random.choices(data, k=1))
root.after(500, loop)
loop()
root.mainloop()
output.mp4
Back to the Top | Usage Guide | Examples | Whats New ?
-
y_axis_values is a tuple that containing two numeric values for the y-axis. The first value (index 0) represents the starting value of the y-axis, and the second value (index 1) represents the end value of the y-axis. This tuple defines the range of values displayed along the y-axis on chart.
-
x_axis_values is a collection of values that can include any data type. These values are assigned to the x-axis, starting from index 0 and continuing to the last index of the x_axis_values tuple. Each value in the tuple corresponds to a point along the x-axis in chart.
chart = ctkchart.CTkLineChart( master=any_widget x_axis_values=(2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025), y_axis_values=(-100, 100) )
-
refers to the value type displayed in the x-axis of a chart. Note: "X" is the default value.
-
refers to the value type displayed in the y-axis of a chart. Note: "Y" is the default value.
-
refers to the font color applied to the label representing the data type on x-axis of a chart.
-
refers to the font color applied to the label representing the data type on y-axis of a chart.
-
refers to the font style applied to the labels representing the data types on both the x-axis and y-axis of a chart.
chart = ctkchart.CTkLineChart( master=any_widget, x_axis_values=(2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025), y_axis_values=(-100, 100), y_axis_data="Y data" , x_axis_data="X data", x_axis_data_font_color="#ff0000", y_axis_data_font_color="#00ff00", data_font_style=("arial", 15, "underline") )
-
When you have a set of x-axis labels, such as years from 2018 to 2025, normally all these labels are shown. But sometimes you might want to show only a few of them for better clarity.
For instance, if you set the x_axis_label_count to 4, it means you want to display only 4 labels instead of all 8. So, the chart will automatically skip some labels to fit your specified count.
Note: len(x_axis_values) is the default value.
In other words, adjusting the x_axis_label_count allows you to control how many labels appear on the x-axis, making your visualization cleaner and easier to understand.- if there are 9 labels you can limit it to : 3, 1, 0.
- if there are 20 labels you can limit it to : 10, 5, 4, 2, 1, 0.
- if there are 15 labels you can limit it to : 5, 3, 1, 0.
In some cases, using the x_axis_label_count parameter might not be sufficient for your needs. In such situations, you can utilize the x_axis_display_values_indices parameter to precisely control which values are displayed on the x-axis.
-
By default, if you set the y-axis values to range from -100 to 100, only the extreme values (-100 and 100) will be displayed on the y-axis. However, you have the option to adjust the number of labels displayed using the y_axis_label_count parameter.
For example, if you set y_axis_label_count to 3, the system will divide the y-axis range (-100 to 100) into equal intervals and display labels at those intervals. So, for this case, with a label count of 3, you might see labels at -100, 0, and 100.
In summary, adjusting the y_axis_label_count parameter allows you to control the number of labels displayed on the y-axis, providing flexibility in customizing the visualization based on your preferences and requirements.chart = ctkchart.CTkLineChart( master=any_widget, x_axis_values=(2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025), y_axis_values=(-100, 100), x_axis_label_count=4, y_axis_label_count=10, )
-
Let's say you have a set of x-axis values representing years from 2018 to 2025: (2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025). Normally, all these values would be displayed on the x-axis.
However, there might be cases where you only want to display specific years rather than all of them. In such situations, you can use the x_axis_display_values_indices parameter to control which values are shown on the x-axis.
For example, if you only want to display the years 2019, 2022, and 2025, you can specify their indices in the x_axis_display_values_indices parameter. So, if the index of 2919 is 1, 2022 is 4, and 2025 is 7 (assuming 0-based indexing), you would set x_axis_display_values_indices to (1, 4, 7).
This way, by setting the indices of the values you want to display, you have precise control over which values appear on the x-axis in your visualization, allowing you to tailor it according to your specific requirements.chart = ctkchart.CTkLineChart( master=any_widget, x_axis_values=(2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025), y_axis_values=(-100, 100), x_axis_display_values_indices=(1, 4, 7) )
-
The x_axis_data_position parameter determines the position of the x data label. It has two
supported values:
- "top"
- "side"
Note: "top" is the default position
-
The y_axis_data_position parameter determines the position of the x data label. It has two
supported values:
- "top"
- "side"
Note: "top" is the default position
Choosing between "top" and "side" determines whether the data labels are placed horizontally above the data points or vertically beside them, respectively. This parameter allows you to customize the layout of your chart according to your preferences and available space.
chart = ctkchart.CTkLineChart( master=any_widget, x_axis_values=(2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025), y_axis_values=(-100, 100), x_axis_data_position="side", y_axis_data_position="top" )
-
The y_axis_precision parameter controls the number of decimal places displayed for the values on the y-axis.
Note: 1 is the deafault precion
For example:- If you set y_axis_precision to 0, the values on the y-axis will be displayed as whole numbers.
- If you set y_axis_precision to 1, the values on the y-axis will be displayed with one decimal place.
- If you set y_axis_precision to 2, the values on the y-axis will be displayed with two decimal places.
And so on :
- Adjusting the y_axis_precision parameter allows you to control the level of precision for the y-axis values in your chart. This parameter is particularly useful when dealing with data that requires specific precision or when you want to improve the readability of the chart by reducing the number of decimal places displayed.
chart = ctkchart.CTkLineChart( master=any_widget, x_axis_values=(2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025), y_axis_values=(-100, 100), y_axis_label_count=12, y_axis_precision=4, )
- If you set y_axis_precision to 0, the values on the y-axis will be displayed as whole numbers.
-
refers to font style of the x and y axis values
-
refers to color of x axis values
-
refers to color of y axis values
chart = ctkchart.CTkLineChart( master=any_widget, x_axis_values=(2018, 2019, 2020, 2021, 2022, 2023, 2024, 2025), y_axis_values=(-100, 100), x_axis_font_color="#00FF00", y_axis_font_color="#FF0000", axis_font_style=("arial", 13, "bold") )
-
The x_axis_section_count parameter defines the number of sections or intervals into which the x-axis range will be divided in a chart.
Here's a clearer breakdown :- Let's say you have a range of values on the x-axis, such as years from 2018 to 2025. By default, this range might be represented as a continuous line without any specific sections or intervals marked.
- However, if you set x_axis_section_count to a value, such as 8, it means you want to divide this x-axis range into equally spaced sections or intervals. Each section will represent a subset of the total x-axis range.
- Adjusting the x_axis_section_count parameter allows you to control the granularity of the x-axis in your chart, making it easier for viewers to interpret the data and identify trends within specific intervals.
-
The y_axis_section_count parameter defines the number of sections or intervals into which the y-axis range will be divided in a chart.
refer : x_axis_section_count for more... -
refers to color of y axis sections
-
refers to color of x axis sections
chart = ctkchart.CTkLineChart( master=any_widget, x_axis_section_count=8, y_axis_section_count=5, x_axis_section_color="#2C2C2C", y_axis_section_color="#2C2C2C" )
-
x_axis_section_style parameter allows you to define the visual style of the sections along the x-axis in a chart.
- Supported styles:
- "dashed": When you set x_axis_section_style to "dashed", the sections along the x-axis are displayed using dashed lines.
- "normal": Conversely, when x_axis_section_style is set to "normal", the sections along the x-axis are displayed using solid lines.
Note: "normal" is default style.
- Supported styles:
- working same as x_axis_section_style, refer x_axis_section_style for more
-
The x_axis_section_style_type parameter is a tuple that contains two integer values, specifying the style of the dashes used when the x_axis_section_style is set to "dashed".
For example:- If you set x_axis_section_style_type to (20, 10), it means :
- The width of each dash is 20 pixels.
- The spacing between dashes is 10 pixels.
These values determine the visual appearance of the dashed lines or markers used to represent the sections along the x-axis. Adjusting these values allows you to customize the appearance of the dashed sections according to your preferences or the requirements of your visualization.
- If you set x_axis_section_style_type to (20, 10), it means :
-
working same as x_axis_section_style_type, refer x_axis_section_style_type for more
chart = ctkchart.CTkLineChart( master=any_widget, x_axis_section_count=8, y_axis_section_count=5, x_axis_section_style="dashed", x_axis_section_style_type=(20,10), y_axis_section_style="dashed", y_axis_section_style_type=(20,10), )
-
The x_axis_point_spacing parameter allows your to manually set the spacing between points on the x-axis, typically measured in pixels. However, if you do not manually set this parameter, it is automatically calculated based on the length of x_axis_values.
Note: "auto" is the default value.- after configure specific value to x_axis_point_spacing, you can reset value by configure it as "auto" for set default value.
``` python chart.configure(x_axis_point_spacing = "auto") ```chart = ctkchart.CTkLineChart( master=any_widget, x_axis_point_spacing="auto" )
The x_axis_point_spacing parameter is automatically calculated based on the length of the x_axis_values tuple. This means that the spacing between points on the x-axis is determined by dividing the width of the chart by the length of the x_axis_values list.
When you set the x_axis_point_spacing parameter to a specific value, such as 40, it means that you have manually specified the spacing between points on the x-axis to be 40 units (e.g., pixels). In this case, the chart will use the user-defined spacing of 40 units between each point on the x-axis, regardless of the length of the x_axis_values tuple.
chart = ctkchart.CTkLineChart( master=any_widget, x_axis_point_spacing=40 )
-
refers to color of line.
-
refers to size(thickness) of line.
Note: 1 is the deafault sizeline = ctkchart.CTkLine( master=chart, color="#30ACC7", size=5 )
-
style parameter allows you to define the visual style of the line.
- supported styles:
- "dashed": When you set style to "dashed", the line is displayed as dashed line.
- "dotted": When you set style to "dotted", the line is displayed as dotted line.
- "normal": When you set style to "normal", the line is displayed as solid line.
Note: "normal" is the default style.
line = ctkchart.CTkLine( master=chart, line_style="dashed" )
- supported styles:
-
The style_type parameter is a tuple that contains two integer values, specifying the style of the dashes and dots used when the style is set to "dashed" or "dotted".
For example:
- If you set style_type to (20, 10), it means:
- The width of each dash or size of each dot is 20 pixels.
- The spacing between dashes or dots is 10 pixels.
Note: In the "dotted" style, the size parameter is irrelevant as the dots are of fixed size determined by the style_type tuple.
Note: In the "normal" style, the style_type parameter is do nothing.line = ctkchart.CTkLine( master=chart, line_style="dashed", line_style_type=(10,2) )
- If you set style_type to (20, 10), it means:
-
The point_highlight parameter is used to control point highlight, enabling or disabling it.
- Supported values:
- "enabled": Enable point highlight.
- "disabled": Disable point highlight.
- Supported values:
-
The point_highlight_size is used to set size of the highlight.
-
The point_highlight_color used to control color of highlight.
line = ctkchart.CTkLine( master=chart, point_highlight="enabled", point_highlight_color="#80CCFF", point_highlight_size=8 )
-
The fill parameter is utilized to control whether line fill is enabled or disabled.
- Supported Values:
- "enabled": Enable line fill.
- "disabled": Disable line fill.
- Supported Values:
-
The fill_color parameter is used to specify the color for the fill.
line = ctkchart.CTkLine( master=chart, fill="enabled", fill_color="#5D6DB6" )
For every parameter that involves color in ctkchart, you can provide either:
- A single string representing the color.
- A tuple of two strings where the first string represents the color for the light theme and the second string represents the color for the dark theme.
PyPi.org : ctkchart
GitHub.com : ctkchart