ImageUtil is a PHP library that provides a collection of operations for image manipulation using the GD library. It simplifies tasks such as flipping, cropping, resizing, stamping, and more.
To install ImageUtil, use the following composer command:
composer require "byjg/imageutil"
ImageUtil supports the following image formats:
- GIF
- JPEG
- PNG
- BMP
- WEBP
- SVG (Partial support. Primarily for converting SVG to other formats, not for SVG manipulation.)
You can create an image from a file, URL, existing resource, or create an empty image:
<?php
use ByJG\ImageUtil\ImageUtil;
// From a file
$img = ImageUtil::fromFile('path_to_image.png');
// From a URL
$img2 = ImageUtil::fromFile('https://somesite/someimage.jpg');
// From an existing resource image
$resourceImg = imagecreatetruecolor(200, 300);
$img3 = ImageUtil::fromResource($resourceImg);
// Or an empty image
$img4 = ImageUtil::empty(200, 300, new Color(255, 255, 255));
ImageUtil provides basic support for SVG files, primarily for converting SVG images to other GD-supported formats. It does not support all SVG features and does not support operations like resize, flip, etc.
<?php
use ByJG\ImageUtil\ImageUtil;
$img = ImageUtil::fromFile('path_to_image.svg');
$img->save('path_to_image.png');
ImageUtil provides several methods for image manipulation:
- Flip: Mirror the image vertically or horizontally.
- Rotate: Rotate the image by a specified angle.
- Resize: Resize the image to specified dimensions.
- Resize Square: Resize the image to a square format while maintaining the aspect ratio. Any extra space is filled with the provided RGB color.
- Resize AspectRatio: Resize the image while maintaining the aspect ratio. Any extra space is filled with the provided RGB color.
- Stamp Image: Stamp another image onto the current image.
- Write Text: Write text onto the image.
- Crop Image: Crop the image from a specified point to another point.
- Make Transparent: Make the image transparent. The transparent color must be provided.
See some examples here.
You can save the changes to the image, restore the image to its original state, or destroy the image resource:
<?php
$img->save('filename.gif');
$img->restore();
$img->destroy();
ImageUtil also provides methods to get the image dimensions and the image resource:
<?php
$width = $img->getWidth();
$height = $img->getHeight();
$resource = $img->getResource();
ImageUtil depends on the GD extension for PHP:
flowchart TD
byjg/imageutil --> ext-gd