Note
December 2024 / January 2025: Hey there👋 We are currently working to ship the first release of Manim Notebook. The version already available on the VSCode Marketplace is outdated. If you are interested in the current state of the extension, just clone this repo and follow the Developing guide.
Warning
This VSCode extension is specifically for 3b1b's original manim library
and NOT the Manim Community Edition (Manim CE).
Manim Notebook is a VSCode extension that tailors your needs when writing Python code to animate mathematical concepts with 3Blue1Brown's Manim library. It's NOT a Jupyter Notebook; instead it enriches your existing Python files with interactive Manim cells that let you live-preview parts of the code and instantly see the animations.
Originally, the motivation for this extension was Grant Sanderson's video How I animate 3Blue1Brown where he shows his Manim workflow in Sublime Text. This extension brings a similar workflow to VSCode but even goes further and provides a rich VSCode integration.
Our VSCode walkthrough will guide you through the first steps and provide a sample file. It should open automatically upon installation of the Manim Notebook extension. If not, you can invoke it manually: open the command palette (Ctrl/Cmd + Shift + P
) and search for Manim Notebook: Open Walkthrough
.
The main concept is that of a Manim Cell, which is just a regular Python comment, but one that starts with ##
instead of #
.
Tip
For customization options, troubleshooting tips and a lot more, check out the Wiki.
- Manim Cells. Split your code into Manim Cells that start with
##
. You will be presented with a CodeLens to preview the animation. - Preview any code. Simple as that, select any code and preview it.
- With or without Terminal. The extension parses the
manimgl
terminal output to provide rich VSCode integrations and makes possible an almost terminal-free workflow.- Shows the progress of the live Manim preview as VSCode progress bar.
- Takes a user-defined delay into account, e.g. to wait for custom shell startup scripts (like
venv
activation). - State management: keeps track of the ManimGL state to react accordingly in different situations, e.g. prevent from running multiple statements at the same time.
- Video export. Export your animations to a video file. A small wizard will guide you through the most important settings.
- And more... Find all commands in the command palette (
Ctrl/Cmd + Shift + P
) by searching for> Manim Notebook
. E.g. another command lets youclear()
the window. Yet with another one you can start the scene at your cursor.
TODO: Add a more complete feature list (maybe to the Wiki?). Add images to showcase each feature.