Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jtpio/ipyp5
p5.js Jupyter Widget
https://github.com/jtpio/ipyp5
jupyter jupyter-widget jupyterlab jupyterlab-extension
Last synced: 4 months ago
JSON representation
p5.js Jupyter Widget
- Host: GitHub
- URL: https://github.com/jtpio/ipyp5
- Owner: jtpio
- License: bsd-3-clause
- Created: 2018-03-06T17:50:12.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2023-01-04T06:51:10.000Z (about 2 years ago)
- Last Synced: 2024-10-16T22:24:14.175Z (4 months ago)
- Topics: jupyter, jupyter-widget, jupyterlab, jupyterlab-extension
- Language: Python
- Homepage:
- Size: 8.75 MB
- Stars: 42
- Watchers: 4
- Forks: 5
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-jupyter-resources - GitHub
README
ipyp5
====[data:image/s3,"s3://crabby-images/b138e/b138e4f0918466b2c57063e64b6cb799744c2202" alt="Build Status"](https://travis-ci.org/jtpio/ipyp5)
[data:image/s3,"s3://crabby-images/39dff/39dffbfd158883697f6a6917ecd1f5107d658c4c" alt="Documentation Status"](http://ipyp5.readthedocs.io/en/latest)
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Code style: black"](https://github.com/ambv/black)
[data:image/s3,"s3://crabby-images/be77c/be77c8e5cc805f31f9603b157c6aea8300e2c5d6" alt="pypi"](https://pypi.python.org/pypi/ipyp5)
[data:image/s3,"s3://crabby-images/901cd/901cd88894c312af2c7854e8e56020fc02149f50" alt="Python Versions"](https://pypi.python.org/pypi/ipyp5)
[data:image/s3,"s3://crabby-images/d47aa/d47aa6849ae761fc67b0a37446cc44500440fc6c" alt="License"](https://pypi.python.org/pypi/ipyp5)
[data:image/s3,"s3://crabby-images/fbe1d/fbe1d2f89215b7589b3f89aa2112c2614f97d3b5" alt="Binder"](https://mybinder.org/v2/gh/jtpio/ipyp5/stable?urlpath=lab%2Ftree%2Fexamples%2Fintroduction.ipynb):warning: **Disclaimer: this is a work in progress!** :warning:
[p5.js](https://p5js.org) in the Jupyter Notebook using the Jupyter Widgets.
This project aims to be a follow-up of [p5-jupyter-notebook](https://github.com/jtpio/p5-jupyter-notebook), so that p5 can be used in JupyterLab (and in the classic Notebook) as a proper package.
## Current Status
data:image/s3,"s3://crabby-images/f4d05/f4d05a7c35158cce6155f19dd596fcd89bc3fb98" alt="screencast"
- Define a sketch using the [instance mode of p5](https://github.com/processing/p5.js/wiki/Global-and-instance-mode). This explains the use of `p` in the sample sketch.
- The sketch is synced to the widget as a raw string and evaluated on the frontend.## TODO
- Figure out how to expose a Python wrapper to the p5 API
- How to avoid round trips to the server (syncing of values) when making animations (updating values at every frame)?
- Proper testing, packaging and documentation once the problems above are solved### Goal
The **ideal goal** (disclaimer: not implemented yet) would be to write code like this in a notebook cell:
```python
class MySketch(BaseSketch):
W, H = 400, 400def setup(s):
s.createCanvas(s.W, s.H)
s.rectMode(s.CENTER)def draw(s):
s.background('#ddd')
s.translate(200, 200)
for i in range(4):
s.push()
s.rotate(s.frameCount / 200 * (i + 1))
s.fill(i * 5, i * 100, i * 150)
s.rect(0, 0, 200, 200)
s.pop()sketch = MySketch()
sketch
```## Contributing
See [CONTRIBUTING.md](./CONTRIBUTING.md)