Skip to content

💫 ManimGL with interactive previewing in VSCode. [Currently in its beta stage. Not yet published.]

License

Notifications You must be signed in to change notification settings

Manim-Notebook/manim-notebook

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

69 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Manim Notebook Logo showing a physical notebook with an 'M' letter on its title page

Manim Notebook

VSCode extension to interactively preview your Manim animations

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).

🎈 What is this?

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.

💻 Usage

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 #.

manim-cell-preview

Tip

For customization options, troubleshooting tips and a lot more, check out the Wiki.


🚀 Features

  • 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 you clear() 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.

About

💫 ManimGL with interactive previewing in VSCode. [Currently in its beta stage. Not yet published.]

Resources

License

Stars

Watchers

Forks