artisansweb/image-optimizer

Optimize the images on the fly.

0.0.5 2020-04-20 10:12 UTC

This package is auto-updated.

Last update: 2024-04-20 19:09:17 UTC


README

This library helps you to compress JPGs, PNGs, GIFs images on the fly. Apart from this package, you don't need to install any additional software or package to perform optimization task.

Installation

You can install the package via composer:

composer require artisansweb/image-optimizer

Under the hood, this package uses resmush.it service to compress the images. Alternatively, package using native PHP functions - imagecreatefromjpeg, imagecreatefrompng, imagecreatefromgif, imagejpeg.

Usage

This package is straight-forward to use. All you need to do is pass source path of your image.

use ArtisansWeb\Optimizer;

$img = new Optimizer();

$source = 'SOURCE_PATH_OF_IMAGE';
$img->optimize($source);

Above code will optimize the image and replace the original image with the optimized version.

Optionally, you can also pass destination path where optimized version will stored.

$source = 'SOURCE_PATH_OF_IMAGE';
$destination = 'DESTINATION_PATH_OF_IMAGE';
$img->optimize($source, $destination);

Recommeded way of using this code is on image upload. The user should optimize image on upload which will result in better performance.

Let's say you want to store optimized version in the 'images' folder. You can use the below code for this purpose.

<?php
require_once "vendor/autoload.php";

use ArtisansWeb\Optimizer;

if (isset($_POST['submit'])) {
    $img = new Optimizer();
    move_uploaded_file($_FILES['file']['tmp_name'], 'images/'.$_FILES['file']['name']);
    $img->optimize('images/'.$_FILES['file']['name']);
}
?>

<form method="post" enctype="multipart/form-data">
    <input type="file" name="file" />
    <input type="submit" name="submit" value="Submit" />
</form>

License

The MIT License (MIT). Please see License File for more information.