tomloprod/radiance

A deterministic mesh gradient avatar generator for PHP.

Fund package maintenance!
www.paypal.com/paypalme/tomloprod

Installs: 0

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 0

Forks: 0

Open Issues: 0

pkg:composer/tomloprod/radiance

v1.0.0 2026-01-11 17:05 UTC

This package is auto-updated.

Last update: 2026-01-11 17:07:49 UTC


README

Radiance - Deterministic Avatar Generator

Beautifully deterministic avatars for PHP

PHP >= 8.2 Version CI Downloads License

✨ About Radiance

Radiance is a modern PHP library designed to generate beautiful, deterministic mesh gradient avatars from any string. Same input always produces the same unique avatar, making it perfect for user profiles, identicons and more.

radiance.mp4

πŸ‘‰ Try the interactive playground

πŸ“‘ Features

  • 🎨 Deterministic Generation: Same seed, same avatar. Always.
  • 🌈 Mesh Gradients: Smooth, vibrant, and perceptually balanced color transitions.
  • πŸ“ Multiple Shapes: Circles, Squircles, and Rectangles.
  • ⌨️ Text Overlay: Add initials or names with automatic font resizing and shadow effects.
  • 🧩 Pixel Patterns: Optional identicon-style pixel overlays with customizable shapes and colors.
  • ⚑ Fluent API: An intuitive and expressive interface.

πŸš€ Installation

Requires PHP 8.2+.

Install Radiance via Composer:

composer require tomloprod/radiance

✨ Usage

Basic Usage

Generate a simple avatar from a seed:

$svg = radiance()
    ->seed('tomloprod')
    ->text('TL')
    ->toSvg();

Advanced Customization

Radiance provides a fluent API to fully customize your avatars:

$svg = radiance()
    ->seed('tomloprod')
    ->text('TL')
    ->size(256)
    ->squircle()
    ->baseColor('#3498db')
    ->saturation(1.5)
    ->contrast(1.2)
    ->toSvg();

Pixel Patterns

Add a identicon-like pixelated overlay:

$svg = radiance()
    ->seed('tomloprod')
    ->enablePixelPattern()
    ->pixelGridSize(8)
    ->pixelOpacity(0.4)
    ->pixelDensity(0.5)
    ->pixelShapeCircles()
    ->pixelColorAccent()
    ->toSvg();

Text Controls

Fine-tune how text is displayed:

$svg = radiance()
    ->seed('tomloprod')
    ->text('TL')
    ->fontFamily('Inter')
    ->fontSizeRatio(0.45)
    ->fontSizeRatioAuto(false)
    ->textShadow(0.8)
    ->toSvg();

🧱 API Reference

Base

Method Description Default
seed(string $seed) Set the deterministic seed. null (random)

Shape & Size

Method Description Default
size(int $size) Set the dimension in pixels (width/height). 512
circle() Set the shape to Circle. -
square() Set the shape to Square. (Square)
squircle() Set the shape to Squircle (rounded). -

Colors

Method Description Default
baseColor(string $color) Influence the generated palette hue. Accepts hex, rgb, or hsl. null
solidColor(string $color) Use a fixed background instead of gradient. null

Gradient Filters

Method Description Default
saturation(float $val) Adjust gradient saturation. 1.0 = original, >1 = vivid, <1 = muted. 1.0
contrast(float $val) Adjust gradient contrast. 1.0 = original, >1 = higher contrast. 1.0
fadeDistance(int $val) Control gradient circle size (40-200). Lower = colors more separated. 50

Text Overlay

Method Description Default
text(string $text) Add a centered text overlay. null
fontFamily(string $font) Set the font-family for the text. monospace
fontSizeRatio(float $ratio) Set font size as ratio of avatar size (0.01-1.0). Disables auto-sizing. 0.5
fontSizeRatioAuto(bool $enabled) Enable/disable automatic font sizing based on text length. true
textShadow(float $val) Set text shadow intensity. 0 = no shadow. 1.0

Pixel Pattern

Method Description Default
enablePixelPattern(bool $enable) Enable/disable the identicon-style overlay. true
pixelGridSize(int $size) Set the pixel grid size (3, 5, 7...). Must be odd for symmetry. 13
pixelOpacity(float $opacity) Set pixel pattern opacity (0.0-1.0). 0.3
pixelDensity(float $density) Control how many pixels are drawn (0.0-1.0). 0.25
pixelColorGradient() Use gradient-derived colors for pixels. (Gradient)
pixelColorMonochrome() Use white color for all pixels. -
pixelColorAccent() Use complementary accent color for pixels. -
pixelShapeSquares() Use square shapes for pixels. (Squares)
pixelShapeCircles() Use circle shapes for pixels. -
pixelShapeMix() Use mixed shapes (deterministic per seed). -

Output

Method Description
toSvg() Get the avatar as an SVG string.
toBase64() Get the avatar as a Base64 encoded data URI.

πŸ§‘β€πŸ€β€πŸ§‘ Contributing

Contributions are welcome! Please review the Contributing Guidelines before submitting a pull request.

  1. Fork the project.
  2. Create a new branch (git checkout -b feature/amazing-feature).
  3. Commit your changes (git commit -m 'Add some feature').
  4. Push to the branch (git push origin feature/amazing-feature).
  5. Open a Pull Request.

πŸ“ License

Radiance is open-sourced software licensed under the MIT license.

Created by TomΓ‘s LΓ³pez β€’ Powered by Colority