Skip to main content

Fast and high quality Font Awesome icon to image renderer

Project description

Icon to Image

Crates.io | PyPI

A high-performance Rust library with Python bindings for rendering Font Awesome icons to images, with all the customizations you may want. This library natively includes the icons from Font Awesome 7.2.0 Free (solid, regular and brands).

Features:

  • Extremely fast icon rendering (~10ms for a 512x512 image)
  • Python bindings via PyO3
  • No Python dependencies: Pillow is optional only if using as an image object
  • Supersampling for high-quality antialiased output (2x by default)
  • PNG and WebP output formats, including transparency
  • Customizable icon and background colors (hex and RGB/RGBA)
  • Flexible icon positioning in large canvases with anchors and offsets
  • Command-line interface for both Rust and Python

Disclosure: This library was mostly coded with the assistance of Claude 4.5 Opus. However, I personally have reviewed all code to ensure it is accurate, have added numerous tests and demo examples to ensure it works as both intended and advertised, and have edited documentation and comments to provide greater signal as to how the package operates. I have given this project the same care and attention as I would give a project I have written from scratch.

Installation

Python

pip install icon-to-image
uv pip install icon-to-image

Rust

cargo install icon-to-image

Or, add to your Cargo.toml:

[dependencies]
icon-to-image = "0.1.6"

Command-Line Interface

Both the Rust binary and Python package provide a CLI for rendering icons.

Basic Usage

The list of included icons can be found on Font Awesome's Icon Grid and filtering to "Free" icons. The icon names do not use the fa prefix.

# View CLI documentation
icon-to-image --help

# Render a heart icon to PNG
icon-to-image heart heart.png

# Render with custom color and size
icon-to-image star star.png --color "#FFD700" --size 256

# Render with transparent background
icon-to-image github logo.png --color "#333333" --background transparent

# Output as WebP
icon-to-image rocket rocket.webp --color "#FF6B35"

# Search for icons matching a pattern
icon-to-image search arrow

Rust Usage

See the documentation on docs.rs.

Python Usage

See also the demo Jupyter Notebook for more interactive examples.

Basic Rendering

To use render_icon(), you will also need to have Pillow installed.

from icon_to_image import IconRenderer

renderer = IconRenderer()

# Render a heart icon with default settings (512x512, solid weight, black on white)
# render_icon() returns a PIL.Image directly
img = renderer.render_icon("heart")
img.save("heart.png")

Custom Colors

# Red heart on default white background
red_heart = renderer.render_icon(
    "heart",
    icon_color="#FF0000",
)

# Blue star on yellow background
blue_star = renderer.render_icon(
    "star",
    icon_color="#0066CC",
    background_color="#FFD700",
)

# Semitransparent gray ghost on transparent background
gray_ghost = renderer.render_icon(
    "ghost",
    icon_color=(128, 128, 128, 128),
    background_color=None,
)

Brand Icons

github = renderer.render_icon("github", icon_color="#333333")
python = renderer.render_icon("python", icon_color="#3776AB")

Custom Sizes

# Small icon with padding (128px icon on 256px canvas)
small = renderer.render_icon(
    "rocket",
    canvas_width=256,
    canvas_height=256,
    icon_size=128,
    icon_color="#FF6B35",
)

Icon Positioning

# Position icon at bottom-right with padding
badge = renderer.render_icon(
    "check",
    canvas_width=256,
    canvas_height=256,
    icon_size=48,
    horizontal_anchor="right",
    vertical_anchor="bottom",
    offset_x=-16,
    offset_y=-16,
    icon_color="#4CAF50",
    background_color="#E8F5E9",
)

Icon Rotation

# Rotate an arrow 45 degrees clockwise
rotated = renderer.render_icon(
    "arrow-right",
    rotate=45,  # Positive = clockwise
    icon_color="#E91E63",
)

# Rotate counter-clockwise
rotated_ccw = renderer.render_icon(
    "egg",
    rotate=-30,  # Negative = counter-clockwise
    icon_color="#2196F3",
)

Font Styles

Some Font Awesome icons have different styles. You can explicitly specify which style to use:

# Solid style (filled) - default for most icons
solid_bell = renderer.render_icon("bell", style="solid")

# Regular style (outlined)
regular_bell = renderer.render_icon("bell", style="regular")

render_icon() and render_icon_bytes()

render_icon() returns a PIL.Image directly. render_icon_bytes() returns raw encoded bytes (PNG or WebP) without requiring Pillow, which can be useful for tasks such as APIs.

# render_icon() returns PIL.Image (requires Pillow)
img = renderer.render_icon("heart", icon_color="#FF0000")
img.save("heart.png")  # Use PIL's save method

# render_icon_bytes() returns raw bytes (no Pillow needed)
png_data = renderer.render_icon_bytes("heart", icon_color="#FF0000")
with open("heart.png", "wb") as f:
    f.write(png_data)

# render_icon_bytes() supports output format selection
webp_data = renderer.render_icon_bytes("heart", output_format="webp")

Save Directly to File

The save_icon() method writes the image to disk directly from Rust for maximum performance.

renderer.save_icon("check-circle", "check.png", icon_color="#4CAF50")
renderer.save_icon("times-circle", "times.webp", icon_color="#F44336")

Query Available Icons

# Get total icon count
print(f"Total icons: {renderer.icon_count()}")

# List all icons
all_icons = renderer.list_icons()

# Search for specific icons
arrow_icons = [name for name in all_icons if "arrow" in name]

# Check if an icon exists
if renderer.has_icon("heart"):
    print("Heart icon is available")

Rust Usage

use icon_to_image::{IconRenderer, RenderConfig, Color, ImageFormat, encode};

fn main() -> Result<(), icon_to_image::IconFontError> {
    // Use embedded assets
    let renderer = IconRenderer::new()?;

    let config = RenderConfig::new()
        .canvas_size(1024, 1024)
        .icon_size(800)
        .icon_color(Color::from_hex("#FF5733")?)
        .background_color(Color::transparent());

    let (width, height, pixels) = renderer.render("heart", &config)?;
    let png_data = encode(&pixels, width, height, ImageFormat::Png)?;
    std::fs::write("heart.png", png_data)?;

    Ok(())
}

API Reference

Python

Parameters

Applies to both render_icon() and render_icon_bytes():

Parameter Type Default Description
name str required Icon name
canvas_width int 512 Output width in pixels
canvas_height int 512 Output height in pixels
icon_size int 95% of canvas Icon size in pixels
supersample int 2 Antialiasing factor (1, 2, or 4)
icon_color str/tuple "#000000" Hex or RGB(A) tuple
background_color str/tuple/None "#FFFFFF" Hex, RGB(A), or None
horizontal_anchor str "center" "left", "center", "right"
vertical_anchor str "center" "top", "center", "bottom"
offset_x int 0 Horizontal offset in pixels
offset_y int 0 Vertical offset in pixels
rotate float 0 Rotation in degrees (+ = clockwise)
style str/None None "solid", "regular", or "brands"

Notes

  • This project is a recreation of my four year old Python project, icon-image. However, there were several issues with that project: the generations are slow, the generated icons were annoyingly aliased, and the Pillow code was a mess and prone to breaking. Therefore, I looked to Rust with Python bindings as it addressed all of the above issues: Claude 4.5 Opus handled them all easily. Normally this type of bespoke project would be kept as private personal project as I have a specific need for this workflow for a certain upcoming project, but Claude's generated code was good enough such that it wasn't a huge lift to polish it for public release.
  • Normally I would use fontdue for rendering the glyphs as it's more performant, however fontdue does not have the ability to render curves which is very important for most icons.
  • This library technically supports using provided Font Awesome files (e.g. the Pro variants) but I do not have access to Pro for testing.

License

MIT

Font Awesome CSS included per its MIT License.

Font Awesome font files included per their SIL Open Font 1.1 License.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

icon_to_image-0.2.0.tar.gz (632.4 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

icon_to_image-0.2.0-cp310-abi3-win_amd64.whl (730.1 kB view details)

Uploaded CPython 3.10+Windows x86-64

icon_to_image-0.2.0-cp310-abi3-manylinux_2_34_x86_64.whl (833.5 kB view details)

Uploaded CPython 3.10+manylinux: glibc 2.34+ x86-64

icon_to_image-0.2.0-cp310-abi3-manylinux_2_34_aarch64.whl (811.2 kB view details)

Uploaded CPython 3.10+manylinux: glibc 2.34+ ARM64

icon_to_image-0.2.0-cp310-abi3-macosx_11_0_arm64.whl (784.1 kB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

icon_to_image-0.2.0-cp310-abi3-macosx_10_12_x86_64.whl (802.2 kB view details)

Uploaded CPython 3.10+macOS 10.12+ x86-64

File details

Details for the file icon_to_image-0.2.0.tar.gz.

File metadata

  • Download URL: icon_to_image-0.2.0.tar.gz
  • Upload date:
  • Size: 632.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for icon_to_image-0.2.0.tar.gz
Algorithm Hash digest
SHA256 623aac53084b16408adb90b5624f7ee2e9cf2d946a1ae15c6d193b1628bd4371
MD5 ade8b275529186ef47116c5fd6b17a94
BLAKE2b-256 5b1ae1a507d4aea65f6188e12a679df44e08df20c469c4e8eb2eb6f14c489069

See more details on using hashes here.

File details

Details for the file icon_to_image-0.2.0-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for icon_to_image-0.2.0-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 91cb60e9e57a523f617835b45f101551599dbbbf62636243290e76f5de6ccdde
MD5 c3e893ac6e78b1cee51ea55a939f0276
BLAKE2b-256 77dd00669d7a8d22666108cb402857580334a362a0472ad3857d997e84754d60

See more details on using hashes here.

File details

Details for the file icon_to_image-0.2.0-cp310-abi3-manylinux_2_34_x86_64.whl.

File metadata

File hashes

Hashes for icon_to_image-0.2.0-cp310-abi3-manylinux_2_34_x86_64.whl
Algorithm Hash digest
SHA256 fa6cb29b10b58bafed4174038eee82e664691ebfc82fa31442ca3eadb51817c6
MD5 f82f16e7d657586177177a0b3ac29a4d
BLAKE2b-256 b961152a27280e1acaa47eda1a60f07eb98cda0ed28178136537c6ca344ff152

See more details on using hashes here.

File details

Details for the file icon_to_image-0.2.0-cp310-abi3-manylinux_2_34_aarch64.whl.

File metadata

File hashes

Hashes for icon_to_image-0.2.0-cp310-abi3-manylinux_2_34_aarch64.whl
Algorithm Hash digest
SHA256 5ff58d5f524e22003b04d477907c46e9dd8da2d1010e22b1290996fbb831a8e0
MD5 d0f63c25c806bd1ef62ead3e6a6d7a0c
BLAKE2b-256 4e21ca48ad904d3b70da41413dddde15620d04c5750d41bb774acdaab8ed3ace

See more details on using hashes here.

File details

Details for the file icon_to_image-0.2.0-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for icon_to_image-0.2.0-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 ca2c6b7bdc1852d0835d8c1c1df22e0a2cd3c4d618b1b640de83cfbd016c077e
MD5 91cba7dafbe67fe5283f45d3ded2330e
BLAKE2b-256 bfa36a6e9246af68b44ac2b1baf7b0a70b1c435de78c4dc24a6f31cd82477290

See more details on using hashes here.

File details

Details for the file icon_to_image-0.2.0-cp310-abi3-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for icon_to_image-0.2.0-cp310-abi3-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 3ae634239fd0aef7e435fdbc65cbbef38e5c54eb8fa0fc1ded2c6807f798760e
MD5 9943516aebec3d7ca70d63140471c5ab
BLAKE2b-256 af684e65e75dc04bf6585bef18af9b4cfd38b9b886f59abffd05f90d0dba63ca

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page