2017 © Pedro Peláez
 

library avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

image

laravolt/avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

  • Wednesday, June 6, 2018
  • by uyab
  • Repository
  • 38 Watchers
  • 779 Stars
  • 126,442 Installations
  • PHP
  • 13 Dependents
  • 0 Suggesters
  • 55 Forks
  • 8 Open issues
  • 30 Versions
  • 19 % Grown

The README.md

laravolt/avatar

Total Downloads Monthly Downloads Daily Downloads Run Tests, (*1)

Preview, (*2)

Display unique avatar for any user based on their (initials) name., (*3)

Preview

Preview, (*4)

:film_strip: Video Tutorial

, (*5)

Installation

This package originally built for Laravel, but can also be used in any PHP project., (*6)

Read more about integration with PHP project here., (*7)

Laravel >= 5.2:

composer require laravolt/avatar

Laravel 5.1:

composer require laravolt/avatar ~0.3

Service Provider & Facade

Note: only for Laravel 5.4 and below, because since Laravel 5.5 we use package auto-discovery., (*8)

Laravolt\Avatar\ServiceProvider::class,

...

'Avatar'    => Laravolt\Avatar\Facade::class,

Publish Config (optional)

php artisan vendor:publish --provider="Laravolt\Avatar\ServiceProvider"

This will create config file located in config/laravolt/avatar.php., (*9)

Lumen Service Provider

$app->register(Laravolt\Avatar\LumenServiceProvider);

Usage

Output as base64

//this will output data-uri (base64 image data)
//something like data:image/png;base64,iVBORw0KGg....
Avatar::create('Joko Widodo')->toBase64();

//use in view
//this will display initials JW as an image
<img src="{{ Avatar::create('Joko Widodo')->toBase64() }}" />

Save as file

Avatar::create('Susilo Bambang Yudhoyono')->save('sample.png');
Avatar::create('Susilo Bambang Yudhoyono')->save('sample.jpg', 100); // quality = 100

Output as Gravatar

Avatar::create('uyab@example.net')->toGravatar();
// Output: http://gravatar.com/avatar/0c5cbf5a8762d91d930795a6107b2ce5814a6ab26e60c7ec6b75bc81c7dfe3ee

Avatar::create('uyab@example.net')->toGravatar(['d' => 'identicon', 'r' => 'pg', 's' => 100]);
// Output: http://gravatar.com/avatar/0c5cbf5a8762d91d930795a6107b2ce5814a6ab26e60c7ec6b75bc81c7dfe3ee?d=identicon&r=pg&s=100

Gravatar parameter reference: https://docs.gravatar.com/api/avatars/images/, (*10)

Output as SVG

Avatar::create('Susilo Bambang Yudhoyono')->toSvg();

You may specify custom font-family for your SVG text., (*11)

<head>
    <!--Prepare custom font family, using Google Fonts-->
    <link href="https://fonts.googleapis.com/css?family=Laravolt" rel="stylesheet">

    <!--OR-->

    <!--Setup your own style-->
    <style>
    @font-face {
        font-family: Laravolt;
        src: url({{ asset('fonts/laravolt.woff')) }});
    }
    </style>
</head>
Avatar::create('Susilo Bambang Yudhoyono')->setFontFamily('Laravolt')->toSvg();

Get underlying Intervention image object

Avatar::create('Abdul Somad')->getImageObject();

The method will return an instance of Intervention image object, so you can use it for further purposes., (*12)

Non-ASCII Character

By default, this package will try to output any initials letter as it is. If the name supplied contains any non-ASCII character (e.g. ā, Ě, ǽ) then the result will depend on which font used (see config). It the font supports characters supplied, it will successfully displayed, otherwise it will not., (*13)

Alternatively, we can convert all non-ascii to their closest ASCII counterparts. If no closest coutnerparts found, those characters are removed. Thanks to Stringy for providing such useful functions. What we need is just change one line in config/avatar.php:, (*14)

    'ascii'    => true,

Configuration

<?php
/*
 * Set specific configuration variables here
 */
return [

    /*
    |--------------------------------------------------------------------------
    | Image Driver
    |--------------------------------------------------------------------------
    | Avatar use Intervention Image library to process image.
    | Meanwhile, Intervention Image supports "GD Library" and "Imagick" to process images
    | internally. You may choose one of them according to your PHP
    | configuration. By default PHP's "Imagick" implementation is used.
    |
    | Supported: "gd", "imagick"
    |
    */
    'driver'    => 'gd',

    // Initial generator class
    'generator' => \Laravolt\Avatar\Generator\DefaultGenerator::class,

    // Whether all characters supplied must be replaced with their closest ASCII counterparts
    'ascii'    => false,

    // Image shape: circle or square
    'shape' => 'circle',

    // Image width, in pixel
    'width'    => 100,

    // Image height, in pixel
    'height'   => 100,

    // Number of characters used as initials. If name consists of single word, the first N character will be used
    'chars'    => 2,

    // font size
    'fontSize' => 48,

    // convert initial letter in uppercase
    'uppercase' => false,

    // Right to Left (RTL)
    'rtl' => false,

    // Fonts used to render text.
    // If contains more than one fonts, randomly selected based on name supplied
    'fonts'    => [__DIR__.'/../fonts/OpenSans-Bold.ttf', __DIR__.'/../fonts/rockwell.ttf'],

    // List of foreground colors to be used, randomly selected based on name supplied
    'foregrounds'   => [
        '#FFFFFF',
    ],

    // List of background colors to be used, randomly selected based on name supplied
    'backgrounds'   => [
        '#f44336',
        '#E91E63',
        '#9C27B0',
        '#673AB7',
        '#3F51B5',
        '#2196F3',
        '#03A9F4',
        '#00BCD4',
        '#009688',
        '#4CAF50',
        '#8BC34A',
        '#CDDC39',
        '#FFC107',
        '#FF9800',
        '#FF5722',
    ],

    'border'    => [
        'size'  => 1,

        // border color, available value are:
        // 'foreground' (same as foreground color)
        // 'background' (same as background color)
        // or any valid hex ('#aabbcc')
        'color' => 'background',

        // border radius, only works for SVG
        'radius' => 0,
    ],

    // List of theme name to be used when rendering avatar
    // Possible values are:
    // 1. Theme name as string: 'colorful'
    // 2. Or array of string name: ['grayscale-light', 'grayscale-dark']
    // 3. Or wildcard "*" to use all defined themes
    'theme' => ['*'],

    // Predefined themes
    // Available theme attributes are:
    // shape, chars, backgrounds, foregrounds, fonts, fontSize, width, height, ascii, uppercase, and border.
    'themes' => [
        'grayscale-light' => [
            'backgrounds' => ['#edf2f7', '#e2e8f0', '#cbd5e0'],
            'foregrounds' => ['#a0aec0'],
        ],
        'grayscale-dark' => [
            'backgrounds' => ['#2d3748', '#4a5568', '#718096'],
            'foregrounds' => ['#e2e8f0'],
        ],
        'colorful' => [
            'backgrounds' => [
                '#f44336',
                '#E91E63',
                '#9C27B0',
                '#673AB7',
                '#3F51B5',
                '#2196F3',
                '#03A9F4',
                '#00BCD4',
                '#009688',
                '#4CAF50',
                '#8BC34A',
                '#CDDC39',
                '#FFC107',
                '#FF9800',
                '#FF5722',
            ],
            'foregrounds' => ['#FFFFFF'],
        ],
    ]
];

Overriding config at runtime

We can overriding configuration at runtime by using following functions:, (*15)

Avatar::create('Soekarno')->setDimension(100);//width = height = 100 pixel
Avatar::create('Soekarno')->setDimension(100, 200); // width = 100, height = 200
Avatar::create('Soekarno')->setBackground('#001122');
Avatar::create('Soekarno')->setForeground('#999999');
Avatar::create('Soekarno')->setFontSize(72);
Avatar::create('Soekarno')->setFont('/path/to/font.ttf');
Avatar::create('Soekarno')->setBorder(1, '#aabbcc'); // size = 1, color = #aabbcc
Avatar::create('Soekarno')->setBorder(1, '#aabbcc', 10); // size = 1, color = #aabbcc, border radius = 10 (only for SVG)
Avatar::create('Soekarno')->setShape('square');

// Available since 3.0.0
Avatar::create('Soekarno')->setTheme('colorful'); // set exact theme
Avatar::create('Soekarno')->setTheme(['grayscale-light', 'grayscale-dark']); // theme will be randomized from these two options

// chaining
Avatar::create('Habibie')->setDimension(50)->setFontSize(18)->toBase64();

Integration with other PHP project

// include composer autoload
require 'vendor/autoload.php';

// import the Avatar class
use Laravolt\Avatar\Avatar;

// create your first avatar
$avatar = new Avatar($config);
$avatar->create('John Doe')->toBase64();
$avatar->create('John Doe')->save('path/to/file.png', $quality = 90);

$config is just an ordinary array with same format as explained above (See Configuration)., (*16)

Support Us

Buy Me A Coffee

"Buy Me A Coffee", (*17)

paypal, (*18)

Traktir Saya

Trakteer Saya, (*19)

The Versions

06/06 2018

dev-master

9999999-dev https://github.com/laravolt/avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

06/06 2018

2.0.4

2.0.4.0 https://github.com/laravolt/avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

27/02 2018

2.0.3

2.0.3.0 https://github.com/laravolt/avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

17/11 2017

2.0.2

2.0.2.0 https://github.com/laravolt/avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

27/08 2017

2.0.1

2.0.1.0 https://github.com/laravolt/avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

21/08 2017

2.0.0

2.0.0.0 https://github.com/laravolt/avatar

Turn name, email, and any other string into beautiful, initial-based avatar.

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

03/06 2017

dev-analysis-qyEpxb

dev-analysis-qyEpxb https://github.com/laravolt/avatar

Display avatar as base64

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

03/06 2017

1.0.x-dev

1.0.9999999.9999999-dev https://github.com/laravolt/avatar

Display avatar as base64

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

24/01 2016

0.x-dev

0.9999999.9999999.9999999-dev https://github.com/laravolt/avatar

Display avatar as base64

  Sources   Download

MIT

The Requires

 

The Development Requires

laravel avatar laravolt

24/01 2016
22/01 2016
19/01 2016
18/01 2016
06/01 2016
06/01 2016
25/12 2015
21/10 2015

0.2.0

0.2.0.0 https://github.com/laravolt/avatar

Display avatar as base64

  Sources   Download

MIT

The Requires

 

The Development Requires

avatar laravolt

12/10 2015

0.1.0

0.1.0.0 https://github.com/laravolt/avatar

Display avatar as base64

  Sources   Download

MIT

The Requires

 

The Development Requires

avatar laravolt