Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tomicapretto/flexitext
Flexitext: Draw styled text in Matplotlib
https://github.com/tomicapretto/flexitext
matplotlib python text
Last synced: 10 days ago
JSON representation
Flexitext: Draw styled text in Matplotlib
- Host: GitHub
- URL: https://github.com/tomicapretto/flexitext
- Owner: tomicapretto
- License: mit
- Created: 2021-09-16T23:18:34.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-05-25T18:34:04.000Z (over 2 years ago)
- Last Synced: 2024-12-09T09:54:42.213Z (20 days ago)
- Topics: matplotlib, python, text
- Language: Python
- Homepage: https://tomicapretto.github.io/flexitext/
- Size: 1.24 MB
- Stars: 115
- Watchers: 2
- Forks: 8
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: Changelog.md
- License: LICENSE
Awesome Lists containing this project
README
[![PyPI - Version](https://img.shields.io/pypi/v/flexitext.svg)](https://pypi.org/project/flexitext/)
[![Build Status](https://github.com/tomicapretto/flexitext/actions/workflows/tests.yml/badge.svg)](https://github.com/tomicapretto/flexitext/actions/workflows/tests.yml)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/ambv/black)
[![codecov](https://codecov.io/gh/tomicapretto/flexitext/branch/main/graph/badge.svg?token=ZqH0KCLKAE)](https://codecov.io/gh/tomicapretto/flexitext)# Introduction
Flexitext is a Python library that makes it easier to draw text with multiple styles in Matplotlib. This library is inspired and influenced by the R package [`ggtext`](https://wilkelab.org/ggtext/).
## Installation
Flexitext requires a working Python interpreter (3.7+). This library can be installed using pip:
pip install flexitext
Alternatively, you can install the development version from GitHub:
pip install git+https://github.com/tomicapretto/flexitext.git
Flexitext only requires Matplotlib version 3.4 or higher.
## Overview
Albeit being inspired on [ggtext](https://wilkelab.org/ggtext/), Flexitext does not use HTML, CSS, or Markdown to specify text styles. On the contrary, it implements a tag-based styling that looks similar to HTML tags, but is not exactly like HTML. These formatted strings consist of three components:
* An opening tag that defines the styles to apply.
* The text to be styled.
* A closing tag, indicating the extent to which the styles in the opening tag apply.Let's see an example:
```python
"This is blue text> and this is regular text"
```*
<color:blue, size:16>
is the opening tag. Styles are key-value pairs separated by `:`. Multiple styles are separated by commas.
* `This is blue text` is the text block. This text is going to be drawn using a font size of 16 and blue color.
*</>
is the closing tag. Only the text within the opening and the closing tags is formatted.And finally we have ` and this is regular text`. This is going to be drawn using the default style because it is not contained within any formatting tags.
## Examples
The easiest way to use `flexitext` is through the `flexitext` function.
```python
import matplotlib as mpl
import matplotlib.pyplot as pltfrom flexitext import flexitext
mpl.rcParams['figure.facecolor'] = 'w'
``````python
fig, ax = plt.subplots(figsize=(9, 6))text = "Normal text"
ax.text(0.5, 0.7, text, size=24, ha="center")text = "Bold text>"
flexitext(0.5, 0.6, text, ha="center")text = "Italic text>"
flexitext(0.5, 0.5, text, ha="center")text = "Bold and> italic too!>"
flexitext(0.5, 0.4, text, ha="center");
```
![png](README_files/README_2_0.png)
Styles can be nested
```python
fig, ax = plt.subplots(figsize=(9, 6))text = "It is much easier >now>>"
flexitext(0.5, 0.6, text, ha="center");
```
![png](README_files/README_4_0.png)
A more convoluted example:
```python
text = (
"You can write using\n>"
"multiple formats,\nand linebreaks\n\n"
"also bold text\n\n>>"
"and why not italics> too>>"
)fig, ax = plt.subplots(figsize=(9, 6))
flexitext(0.5, 0.5, text, ha="center", ma="center");
```
![png](README_files/README_6_0.png)
Use the figure fraction coordinates to write a formatted title.
```python
fig, ax = plt.subplots(figsize=(9, 6))
fig.subplots_adjust(top=0.8, left=0.025)x = [1, 2, 3]
y_blue = [2, 2.7, 4.5]
y_red = [1, 3, 2.5]ax.scatter(x, y_blue, color="royalblue", s=120)
ax.scatter(x, y_red, color="crimson", s=120)# Add flexitext
text = (
"A great chart> showing>\n"
"the values for the "
"blues> and the reds>>>"
)
flexitext(0.025, 0.8, text, va="bottom", xycoords="figure fraction");
```
![png](README_files/README_8_0.png)
## Notes
Flexitext only supports the following styles
* alpha
* backgroundcolor
* color
* family
* name
* size
* style
* weightSee [Matplotlib's documentation](https://matplotlib.org/stable/api/_as_gen/matplotlib.axes.Axes.text.html#matplotlib.axes.Axes.text) for more information about their meaning and available values.
Flexitext logo is created with Flexitext and Matplotlib (see [here](https://github.com/tomicapretto/flexitext/tree/main/docsite/logo.ipynb)).
## Related work
* [highlight_text](https://github.com/znstrider/highlight_text): Flexitext and highlight_text have similar goals. This library, highlight_text, allows you to customize more aspects of the highlighted text, such as the bounding box of the text or the border of the text with path effects. On the other hand, it requires you to pass a styles as a separated list of dictionaries instead of within the text.