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
Requires
- php: ^8.2.0
- ext-mbstring: *
- tomloprod/colority: ^1.7.0
Requires (Dev)
- laravel/pint: ^1.22.1
- pestphp/pest: ^3.8.2
- pestphp/pest-plugin-type-coverage: ^3.5.0
- phpstan/phpstan: ^2.0.3
- rector/rector: ^2.0
README
Beautifully deterministic avatars for PHP
β¨ 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.
- Fork the project.
- Create a new branch (
git checkout -b feature/amazing-feature). - Commit your changes (
git commit -m 'Add some feature'). - Push to the branch (
git push origin feature/amazing-feature). - Open a Pull Request.
π License
Radiance is open-sourced software licensed under the MIT license.
Created by TomΓ‘s LΓ³pez β’ Powered by Colority