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.22.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.22-py3-none-any.whl (36.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: turtle_widget-0.1.22.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.22.tar.gz
Algorithm Hash digest
SHA256 4d6b4bb0b396c21291fc0134b5b515e751d3d6fd2f0b5c7626d256cb8783bb64
MD5 4d13ed1b0484655c789f91aad22a2d43
BLAKE2b-256 c5d3711659d2ab5491b4d9039a0ab0fe265650d8fb64685044850ff13bde1cf7

See more details on using hashes here.

File details

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

File metadata

  • Download URL: turtle_widget-0.1.22-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.22-py3-none-any.whl
Algorithm Hash digest
SHA256 c7be59c8c65549e9fd40329e92a20a61a0b307366fd4cd04ca57a723e92ffc47
MD5 2a5ed3c974760eb8ab13edbf77f0dfd5
BLAKE2b-256 e7adada2cc411f462a8403017f3082d5e8d95cc893f78693a64a3c4e582b1797

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