swatty007 / faker-image-generator
Placeholder Image Generator for FakerPHP
Requires
- php: ^8.1
- ext-gd: *
- fakerphp/faker: ~1.13
Requires (Dev)
- ext-exif: *
- friendsofphp/php-cs-fixer: ^2.18|^3
- orchestra/testbench: ^v8.0.0
- phpmd/phpmd: @stable
- phpmetrics/phpmetrics: ^2.7
- phpunit/phpunit: ^10
This package is auto-updated.
Last update: 2024-12-26 19:28:32 UTC
README
Generator of placeholder-type images using GD for fzaninotto/Faker to quickly generate fake images within your application or tests, without the need to rely on external services.
This is a fork from bruceheller/images-generator as that package seems to not be actively maintained anymore.
Installation
You can install the package via composer:
composer require swatty007/faker-image-generator
Configuration
After installing the package you can publish the configuration file via:
php artisan vendor:publish --provider="Swatty007\FakerImageGenerator\FakerImageGeneratorServiceProvider"
It contains some optional configuration parameters and is fully documented.
The configuration allows you to define some global image properties which will be shared across all Generator Instances. This is an addition to the original package to make is easier to share a similar style throughout your application.
Usage
Use the FakerImageGenerationProvider
class in combination with Faker to produce new images:
$faker = Factory::create(); $imageGenerator = new FakerImageGenerationProvider($faker); $image = $faker->imageGenerator();
It will generate a black png picture of 640*480 pixels inside your temp directory (if available)
and return the full path of the picture like this: '/tmp/13b73edae8443990be1aa8f1a483bc27.png'
.
Parameters
The imageGenerator()
method allows you to define rendering options on a per element basis,
those options are identical to your configuration properties and will allow you quickly generate unique images.
Examples:
$faker->imageGenerator();
Will generate a 640x480 black png picture with the text '640x480' in white.
$faker->imageGenerator('img', 640, 480, 'png', true, 'Faker', '#0018ff', '#ffd800');
Will generate a 640x480 blue png picture with the text 'Faker' in yellow inside an img
directory of your project and return the full path such as 'img/f523f8bec6ed65fb1d63ae8d09850f9c.png'
like this:
More complex example using the power of Faker:
$faker->imageGenerator('img', $faker->numberBetween(600, 800), $faker->numberBetween(400, 600), 'jpg', true, $faker->word, $faker->hexColor, $faker->hexColor);
Will return a jpeg of a random color picture with a width between 600 and 800 pixels, height between 400 and 600 pixels, with a random word written in a random color!
Testing
composer test
Changelog
Please see CHANGELOG for more information what has changed recently.
TODO
As this is mainly a fork of the existing package, to get it running within modern applications, its future development plans could apply to this package as well. However, its current functionality fulfills my needs. Nonetheless, some TODOs remain & are open for pull requests 🧐
- Improve Readme
- Transition to GitHub Actions
- Improve & Extend existing tests!
- Add support for ImageMagick and/or GraphicsMagick for faster generation of pictures.
Otherwise, any suggestion is welcome! You can fork this project and submit your PR :)
Contributing
Please see CONTRIBUTING for details.
Security
If you discover any security related issues, please email info@martin-niehoff.de instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.
The Roboto font file included in this project is under Apache Licence 2.0 as mentioned on the Roboto repository.