Skip to content

MatplotlibChart

Displays a Matplotlib chart.

Warning

This control requires the matplotlib Python package to be installed.

See this installation guide for more information.

Inherits: GestureDetector

Properties

  • figure(Figure) –

    Matplotlib figure to draw - an instance of

Events

Methods

Examples#

Example 1#

Based on an official Matplotlib example.

MatplotlibChart example 1

import flet as ft
import matplotlib
import matplotlib.pyplot as plt

import flet_charts as fch

matplotlib.use("svg")


def main(page: ft.Page):

    fig, ax = plt.subplots()

    fruits = ["apple", "blueberry", "cherry", "orange"]
    counts = [40, 100, 30, 55]
    bar_labels = ["red", "blue", "_red", "orange"]
    bar_colors = ["tab:red", "tab:blue", "tab:red", "tab:orange"]

    ax.bar(fruits, counts, label=bar_labels, color=bar_colors)

    ax.set_ylabel("fruit supply")
    ax.set_title("Fruit supply by kind and color")
    ax.legend(title="Fruit color")

    page.add(fch.MatplotlibChart(figure=fig, expand=True))


ft.run(main)

Example 2#

Based on an official Matplotlib example.

MatplotlibChart example 1

import flet as ft
import matplotlib
import matplotlib.pyplot as plt
import numpy as np

import flet_charts as fch

matplotlib.use("svg")


def main(page: ft.Page):

    # Fixing random state for reproducibility
    np.random.seed(19680801)

    dt = 0.01
    t = np.arange(0, 30, dt)
    nse1 = np.random.randn(len(t))  # white noise 1
    nse2 = np.random.randn(len(t))  # white noise 2

    # Two signals with a coherent part at 10Hz and a random part
    s1 = np.sin(2 * np.pi * 10 * t) + nse1
    s2 = np.sin(2 * np.pi * 10 * t) + nse2

    fig, axs = plt.subplots(2, 1)
    axs[0].plot(t, s1, t, s2)
    axs[0].set_xlim(0, 2)
    axs[0].set_xlabel("time")
    axs[0].set_ylabel("s1 and s2")
    axs[0].grid(True)

    cxy, f = axs[1].cohere(s1, s2, 256, 1.0 / dt)
    axs[1].set_ylabel("coherence")

    fig.tight_layout()

    page.add(fch.MatplotlibChart(figure=fig, expand=True))


ft.run(main)

Properties#

figure #

figure: Figure = field(metadata={'skip': True})

Matplotlib figure to draw - an instance of matplotlib.figure.Figure.

Events#

on_message #

on_message: (
    EventHandler[MatplotlibChartMessageEvent] | None
) = None

The event is triggered on figure message update.

on_toolbar_buttons_update #

on_toolbar_buttons_update: (
    EventHandler[MatplotlibChartToolbarButtonsUpdateEvent]
    | None
) = None

Triggers when toolbar buttons status is updated.

Methods#

back #

back()

build #

build()

download #

download(format)

forward #

forward()

home #

home()

on_canvas_resize #

on_canvas_resize(e: CanvasResizeEvent)

pan #

pan()

send_binary #

send_binary(blob)

send_json #

send_json(content)

send_message #

send_message(message)

will_unmount #

will_unmount()

zoom #

zoom()