Resizing
Grafika support 5 ways of resizing an image: fit, fill, exact, exactWidth, and exactHeight.
Opening an Image
To open an existing image, all you need is to create an editor instance and call the open method:
require_once 'path/to/grafika/src/autoloader.php'; // Automatically load our needed classes
use Grafika\Grafika; // Import package
// Create editor
$editor = Grafika::createEditor();
// Open jpeg image and store it in $image variable
$editor->open( $image, "images/sample-jpeg.jpg" );
Resize Fit
Resize Fit will fit the image within the given dimension:
$editor->open( $image1, "images/sample.jpg" ); // Open jpeg image for editing
$editor->resizeFit( $image1, 200, 200 ); // Fit an image to 200 x 200 box
$editor->save( $image1, "images/testResizeFit.jpg"); // Save the image as jpeg
$editor->open( $image2, "images/portrait.jpg" ); // Open another image for editing
$editor->resizeFit( $image2, 200, 200 ); // Fit an image to 200 x 200 box
$editor->save( $image2, "images/testResizeFitPortrait.jpg"); // Save the image as jpeg
The gray box shows the 200x200 dimension that the images fit in.
data:image/s3,"s3://crabby-images/9a3e0/9a3e092b79cc1f16c775125aaed67253aab4c07c" alt="testResizeFit"
data:image/s3,"s3://crabby-images/26f6b/26f6bb1a02798e7812493772c5e7373e62e7ba9c" alt="testResizeFitPortrait"
Resize Exact
Resize Exact will use the exact dimensions given, ignoring the aspect ratio. Here images appear squashed. It is useful if you want to force exact dimensions:
$editor->open( $image1, "images/sample.jpg" );
$editor->resizeExact( $image1, 200, 200 );
$editor->save( $image1, "images/testResizeExact.jpg");
$editor->open( $image2, "images/portrait.jpg" );
$editor->resizeExact( $image2, 200, 200 );
$editor->save( $image2, "images/testResizeExactPortrait.jpg");
data:image/s3,"s3://crabby-images/0e21f/0e21f11650afc0f131ca9935327c769dc1494db3" alt="testResizeExact"
data:image/s3,"s3://crabby-images/980f0/980f03d401532bce890937c60ac19442614ae986" alt="testResizeExactPortrait"
Resize Fill
Resize Fill will fill the entire dimension given. Excess parts are cropped:
$editor->open( $image1, "images/sample.jpg" );
$editor->resizeFill( $image1, 200, 200 );
$editor->save( $image1, "images/testResizeFill.jpg");
$editor->open( $image2, "images/portrait.jpg" );
$editor->resizeFill( $image2, 200, 200 );
$editor->save( $image2, "images/testResizeFillPortrait.jpg");
data:image/s3,"s3://crabby-images/a36c0/a36c0a3dd5bec8bda23aaccab50b7f56e0fc780f" alt="testResizeFill"
data:image/s3,"s3://crabby-images/5b7ac/5b7acc7fe11a6dbd48567700f8f6f3922985f9ea" alt="testResizeFillPortrait"
Resize Exact Width
With resizeExactWidth, the height is auto calculated. Useful if you want column of images to be exactly the same width:
$editor->open( $image1, "images/sample.jpg" );
$editor->resizeExactWidth( $image1, 100 );
$editor->save( $image1, "images/testResizeExactWidth.jpg");
$editor->open( $image2, "images/portrait.jpg" );
$editor->resizeExactWidth( $image2, 100 );
$editor->save( $image2, "images/testResizeExactWidthPortrait.jpg");
data:image/s3,"s3://crabby-images/8ac0b/8ac0bd77845d98e2ed1d30de841d1047242bda24" alt="testResizeExactWidth"
data:image/s3,"s3://crabby-images/6ba73/6ba73b2d0ca6d2c5e9f9dd6392a8d66ecde52ec7" alt="testResizeExactWidthPortrait"
Resize Exact Height
With resizeExactHeight, the width is auto calculated. Useful if you want row of images to be exactly the same height:
$editor->open( $image1, "images/sample.jpg" );
$editor->resizeExactHeight( $image1, 100 );
$editor->save( $image1, "images/testResizeExactHeight.jpg");
$editor->open( $image2, "images/portrait.jpg" );
$editor->resizeExactHeight( $image2, 100 );
$editor->save( $image2, "images/testResizeExactHeightPortrait.jpg");
data:image/s3,"s3://crabby-images/07813/0781304be239ca0dbe149c0f6882fb0430897bae" alt="testResizeExactHeight"
data:image/s3,"s3://crabby-images/f7b7e/f7b7e7cfcdd64c4aaa4f654850ac71d8db33422d" alt="testResizeExactHeightPortrait"