Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fossunited/joy
Joy is a tiny creative coding library in Python.
https://github.com/fossunited/joy
Last synced: 1 day ago
JSON representation
Joy is a tiny creative coding library in Python.
- Host: GitHub
- URL: https://github.com/fossunited/joy
- Owner: fossunited
- License: mit
- Created: 2021-06-04T04:52:36.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-01-09T18:41:03.000Z (about 1 year ago)
- Last Synced: 2025-02-08T23:11:19.449Z (11 days ago)
- Language: Jupyter Notebook
- Homepage:
- Size: 604 KB
- Stars: 193
- Watchers: 6
- Forks: 19
- Open Issues: 15
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGES.md
- License: LICENSE
Awesome Lists containing this project
README
# Joy
Joy is a tiny creative coding library in Python.
## Installation
The easiest way to install it is download `joy.py` and place it in your
directory. The library has no dependencies.It can be downloaded from:
## Coordinate System
Joy uses a canvas with `(0, 0)` as the center of the canvas.
By default, the size of the canvas is `(300, 300)`.
## Using Joy
The `Joy` library integrates well with Jupyter environment and it is
recommended to explore Joy in a Jupyter lab.The first thing you need to do is import the module.
```python
from joy import *
```Once the functionality in the module is imported, you can start playing
with it.## Basic Shapes
Joy supports the basic shapes `circle`, `ellipse`, `rectangle` and `line`.
Let's start with a drawing a circle:
```
c = circle()
show(c)
```data:image/s3,"s3://crabby-images/77dc1/77dc1e2ccb185ec85c53286186fba6db09fe5b92" alt="svg"
By default circle will have center at `(0, 0)` and radius as `100`. But
you can specify different values.```
c = circle(x=50, y=50, r=50)
show(c)
```data:image/s3,"s3://crabby-images/cfd12/cfd122774775a06d8e49e81db5b96ac16d08a27c" alt="svg"
The other basic types that are supported are `ellipse`, `rectangle`,
and `line`:```
s1 = circle()
s2 = ellipse()
s3 = rectangle()
s4 = line()
show(s1, s2, s3, s4)
```data:image/s3,"s3://crabby-images/c24d0/c24d0aae8d8d997e36b02443320f4f461d75a54e" alt="svg"
## Combining Shapes
Joy supports `+` operator to join shapes.
```
def donut(x, y, r):
c1 = circle(x=x, y=y, r=r)
c2 = circle(x=x, y=y, r=r/2)
return c1+c2d = donut(0, 0, 100)
show(d)
```data:image/s3,"s3://crabby-images/bc9ad/bc9ade7ae62a93a2b7f9f92ba097d00ecb9ceacb" alt="svg"
## Transformations
Joy supports `translate`, `rotate` and `scale` transformations.
Transformations are applied using `|` operator.```
shape = circle(r=50) | translate(x=100, y=0)
show(shape)
```data:image/s3,"s3://crabby-images/3278d/3278d97d52e99bb3768974fbf31d5963f2acd467" alt="svg"
Transformations can be chained too.
```
r1 = rectangle(w=200, h=200)
r2 = r1 | rotate(angle=45) | scale(1/SQRT2)
show(r1, r2)
```
data:image/s3,"s3://crabby-images/5bc5f/5bc5f540836032ac1c76e17940efbdc525f5cf04" alt="svg"## Higer-Order Transformations
Joy supports higher-order transformation `repeat`.
The `repeat` transformation applies a transformation multiple times and
combines all the resulting shapes.For example, draw 10 circles:
```
c = circle(x=-100, y=0, r=50)
shape = c | Repeat(10, Translate(x=10, y=0)
show(shape)
```data:image/s3,"s3://crabby-images/e53de/e53ded36c8331e95f5b070d7f07fb1b21fa6c238" alt="svg"
Combined with rotation, it can create amusing patterns.
```
shape = line() | repeat(18, rotate(angle=10))
show(shape)
```data:image/s3,"s3://crabby-images/8f729/8f729f57760712a2b58507d774632ed64324bb77" alt="svg"
We could do the same with a square:
```
shape = rectangle(w=200, h=200) | repeat(18, rotate(angle=10))
show(shape)
```data:image/s3,"s3://crabby-images/8a731/8a73169d82e955e04f8816459e3f6f4198d7852f" alt="svg"
or a rectangle:
```
shape = rectangle(w=200, h=100) | repeat(18, rotate(angle=10))
show(shape)
```data:image/s3,"s3://crabby-images/e9f19/e9f195878b0f78cc260d14da98af528638289099" alt="svg"
We can combine multiple transformations and repeat.
```
shape = rectangle(w=300, h=300) | repeat(72, rotate(360/72) | scale(0.92))
show(shape)
```data:image/s3,"s3://crabby-images/8fc28/8fc28ef6911835067d942b83146b9eacebe63011" alt="svg"
You can try the same with a circle too:
```
c = circle(x=100, y=0, radius=50)
shape = c | repeat(36*4, rotate(10) | scale(0.97))
show(shape)
```
data:image/s3,"s3://crabby-images/8644a/8644a779fa4195dbf24d62a489bca0b620596ba0" alt="svg"For more information, please checkout the [tutorial](tutorial.ipynb).
## Tutorial
See [tutorial.ipynb](tutorial.ipynb).
## Acknowledgements
Special thanks to Amit Kapoor (@amitkaps). This library woundn't have
been possible without his inputs.The long discussions between @anandology and @amitkaps on functional
programming and computational artistry (for almost over an year) and the
[initial experiments](https://amitkaps.com/artistry) were some of the
seeds that gave life to this library.## License
This repository has been released under the MIT License.