Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/thearchitector/styled-prose

Generate images and thumbnails based on bitmap transformations of rendered prose
https://github.com/thearchitector/styled-prose

art fonts image pdf pdf2image pillow prose render text tgf the-glass-files typography writing

Last synced: 17 days ago
JSON representation

Generate images and thumbnails based on bitmap transformations of rendered prose

Awesome Lists containing this project

README

        

# styled-prose

![GitHub Workflow Status](https://raster.shields.io/github/actions/workflow/status/thearchitector/styled-prose/ci.yaml?label=tests&style=flat-square)
![PyPI - Downloads](https://raster.shields.io/pypi/dw/styled-prose?style=flat-square)
![GitHub](https://raster.shields.io/github/license/thearchitector/styled-prose?style=flat-square)

Generate images and thumbnails based on bitmap transformations of rendered prose.

Documentation: .

Tested support on Python 3.8, 3.9, 3.10, 3.11, and 3.12.

```sh
$ pdm add styled-prose
# or
$ pip install --user styled-prose
```

## Example

The following stylesheet is a super simple example that overrides the `default` style's font size and family.

```toml
# stylesheet.toml

[[fonts]]
font_name = "EB Garamond"
from_google_fonts = true

[[styles]]
name = "default"
font_size = 14
font_name = "EB Garamond"
```

Using that stylesheet, and some basic prose, you can generate an image. The requested font family `EB Garamond` and its license are downloaded from Google Fonts and cached automatically; subsequent generations use those cached fonts.

```python
from PIL import Image
from styled_prose import StyledProseGenerator

text: str = """
This is normal.

This is italicized.

This is bold.

This is bold and italicized.

This is underlined.

This is struck from the record.
"""
random.seed(771999)

generator: StyledProseGenerator = StyledProseGenerator("stylesheet.toml")
img: Image.Image = generator.create_jpg(
text,
angle=-2.5, # optional; an angle by which to rotate the image
thumbnail=(210, 210), # optional; the dimensions of a random thumbnail
)

img.save("prose.jpg", quality=95)
```

This above code produces the following image:

![example rendering](/docs/simple.jpg)