Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dhaitz/mplcyberpunk
"Cyberpunk style" for matplotlib plots
https://github.com/dhaitz/mplcyberpunk
dataviz matplotlib plotting python visualization
Last synced: 1 day ago
JSON representation
"Cyberpunk style" for matplotlib plots
- Host: GitHub
- URL: https://github.com/dhaitz/mplcyberpunk
- Owner: dhaitz
- Created: 2020-03-29T17:22:58.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-11-28T08:35:14.000Z (3 months ago)
- Last Synced: 2025-02-11T23:46:57.732Z (8 days ago)
- Topics: dataviz, matplotlib, plotting, python, visualization
- Language: Python
- Homepage:
- Size: 2.89 MB
- Stars: 1,726
- Watchers: 17
- Forks: 74
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# mplcyberpunk
[data:image/s3,"s3://crabby-images/78d28/78d2876deb78ba1ebc42ec293e02547ceaa3b6b3" alt="Latest PyPI version"](https://pypi.python.org/pypi/mplcyberpunk)
data:image/s3,"s3://crabby-images/cf0f6/cf0f6894409b5e8aa48c16bb155e5497998bec7c" alt="example workflow"
data:image/s3,"s3://crabby-images/c1b34/c1b348d24fec4fb545baee639d65028698ba779f" alt="Python 3.12"A Python package on top of `matplotlib` to create 'cyberpunk' style plots with 3 additional lines of code.
data:image/s3,"s3://crabby-images/76a47/76a471b68d48a3baf82c24f3bc26ef58e2356322" alt=""
## Installation
pip install mplcyberpunk
## Usage
After importing the package, the _cyberpunk_ stylesheet (dark background etc.) is available via `plt.style.use`.
The line glow and 'underglow' effects are added via calling `add_glow_effects`:```python
import matplotlib.pyplot as plt
import mplcyberpunkplt.style.use("cyberpunk")
plt.plot([1, 3, 9, 5, 2, 1, 1], marker='o')
plt.plot([4, 5, 5, 7, 9, 8, 6], marker='o')mplcyberpunk.add_glow_effects()
plt.show()
```Result:
data:image/s3,"s3://crabby-images/76a47/76a471b68d48a3baf82c24f3bc26ef58e2356322" alt=""
This effect is currently only implemented for lines.
The individual steps are described [here](https://matplotlib.org/matplotblog/posts/matplotlib-cyberpunk-style/) in more detail.
#### Add effects individually
Instead of `add_glow_effects`, you can add the line glow and underglow effects separately:
mplcyberpunk.make_lines_glow()
mplcyberpunk.add_underglow()You can also add the effect to a specific axis object explicitly:
fig, ax = plt.subplots()
...
mplcyberpunk.make_lines_glow(ax)data:image/s3,"s3://crabby-images/da5b4/da5b431fc0d724d4ce666a9f920715e59783143f" alt=""
To activate the glow effect only for specific lines, pass a Line2D object or a list of Line2Ds to `make_lines_glow`.
#### Gradient glow
Gradient underglow effect can be added with
mplcyberpunk.add_glow_effects(gradient_fill=True)
or independently of line glow with
mplcyberpunk.add_gradient_fill(alpha_gradientglow=0.5)
`add_gradient_fill` takes a `gradient_start` argument for different gradient starting values:
data:image/s3,"s3://crabby-images/d9d32/d9d32c0fa6fd790b95f86180f8f5553d982e68ec" alt="gradient_start"
#### Different glow configurations:
data:image/s3,"s3://crabby-images/b99bf/b99bf6fad15d9a97ecee0b1a6d93cceb3104a164" alt="underglows"#### Scatter plots
Glow effect can be added to scatter plots via `mplcyberpunk.make_scatter_glow()`:
data:image/s3,"s3://crabby-images/4197f/4197f7504304e9c473268506b4b66e1ee1d472c0" alt=""
#### Colormap
The default colormap is `cool`:
data:image/s3,"s3://crabby-images/b30af/b30af8b65d4082e3f540bdeef2bd2d0b8a8df695" alt="colormap"
Others:
data:image/s3,"s3://crabby-images/96055/9605505802b1d0ef6c05b25d7fbd7b796b5ab28e" alt="colormaps"
#### Bar charts
```python
import matplotlib.pyplot as plt
import mplcyberpunkplt.style.use('cyberpunk')
categories = ['A', 'B', 'C', 'D', 'E']
values = [25, 67, 19, 45, 10]
colors = ["C0", "C1", "C2", "C3", "C4"]bars = plt.bar(categories, values, color=colors, zorder=2)
mplcyberpunk.add_bar_gradient(bars=bars)
plt.show()
```data:image/s3,"s3://crabby-images/02693/02693e5c93e3439e77d7246cc39f158ee32ebe1b" alt="colormap"
## Gallery
data:image/s3,"s3://crabby-images/a4d62/a4d6286d114d528b5856cea28890a9cf1c4a8e50" alt="europe"
data:image/s3,"s3://crabby-images/99118/9911834243e0420d56f3d39741522e3e39032013" alt="world"data:image/s3,"s3://crabby-images/cc348/cc3487f1f6c6777c14386047bb3be29e73e5eca5" alt="gradient-fill_1"
data:image/s3,"s3://crabby-images/e585c/e585c566f7760a9acd68194450f867bf71676ce1" alt="gradient-fill_2"Some images can be bought as posters [here](https://displate.com/sr-artworks/dhaitz).