Skip to main content

An animated, turtle-compatible drawing widget for Jupyter notebooks

Project description

turtle-widget

An animated, turtle-compatible drawing widget for Jupyter notebooks, built on anywidget.

You write ordinary turtle code in Python; the widget records each command and replays it as a smooth canvas animation right below the cell. Because it is built on anywidget, it behaves identically in VS Code, JupyterLab, Notebook 7, and Colab, and works offline. Optionally it shows the cell source beside the canvas and highlights the active line in sync with the animation (show_code=True).

Installation

# pixi
pixi workspace channel add munch-group
pixi add turtle-widget

# conda
conda install -c munch-group turtle-widget

# pip
pip install turtle-widget

Quick start

from turtle_widget import Turtle

t = Turtle()
t.speed(6)
for _ in range(4):     # a square
    t.forward(120)
    t.left(90)

The widget appears automatically at the end of the cell — no need to put t on the last line. You can also display it explicitly with t.show(), or evaluate t. Pass autoshow=False to build a turtle without displaying it (useful for headless geometry checks).

Most of the common turtle API is supported: forward/backward, left/right, goto/setheading/home, circle, pen control (penup/pendown/pensize), colours and fills (pencolor/fillcolor/begin_fill/end_fill), and markers/text (dot/stamp/write). Note that the pen-width method is pensize() (the name width is the canvas-size trait).

Documentation

Full docs and a guided showcase live at munch-group.org/turtle-widget.

Development

This repo is managed with pixi:

pixi run install-dev   # editable install into the pixi environment
pixi run test          # run the pytest suite
pixi run docs          # execute the documentation notebooks
pixi run api           # build the quartodoc API reference

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

turtle_widget-0.1.20.tar.gz (458.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

turtle_widget-0.1.20-py3-none-any.whl (36.3 kB view details)

Uploaded Python 3

File details

Details for the file turtle_widget-0.1.20.tar.gz.

File metadata

  • Download URL: turtle_widget-0.1.20.tar.gz
  • Upload date:
  • Size: 458.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for turtle_widget-0.1.20.tar.gz
Algorithm Hash digest
SHA256 24426c6682f3137ad4cf7f3ef730d76fc045c95305049906f802f5f99df2648a
MD5 181c05392576b439924d563d500c9848
BLAKE2b-256 a2f938fd92d6e4ed8b0e0b8c50754f79ed38b15c3120338a650f71c7e9fba245

See more details on using hashes here.

File details

Details for the file turtle_widget-0.1.20-py3-none-any.whl.

File metadata

  • Download URL: turtle_widget-0.1.20-py3-none-any.whl
  • Upload date:
  • Size: 36.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for turtle_widget-0.1.20-py3-none-any.whl
Algorithm Hash digest
SHA256 fdcaec83aacc59c4db79210a3819b223845d8cb0c6dd3c18b45d971a601b6596
MD5 aae26fc027ab051a383d728b93d69bee
BLAKE2b-256 cd3aee2a03284888e5ed04c8a42989be0e05bd16587c9d77e2914516861b7414

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page