function Image::scaleDimensions

Same name in other branches
  1. 9 core/lib/Drupal/Component/Utility/Image.php \Drupal\Component\Utility\Image::scaleDimensions()
  2. 8.9.x core/lib/Drupal/Component/Utility/Image.php \Drupal\Component\Utility\Image::scaleDimensions()
  3. 10 core/lib/Drupal/Component/Utility/Image.php \Drupal\Component\Utility\Image::scaleDimensions()

Scales image dimensions while maintaining aspect ratio.

The resulting dimensions can be smaller for one or both target dimensions.

Parameters

array $dimensions: Dimensions to be modified - an array with components width and height, in pixels.

int $width: (optional) The target width, in pixels. If this value is NULL then the scaling will be based only on the height value.

int $height: (optional) The target height, in pixels. If this value is NULL then the scaling will be based only on the width value.

bool $upscale: (optional) Boolean indicating that images smaller than the target dimensions will be scaled up. This generally results in a low quality image.

Return value

bool TRUE if $dimensions was modified, FALSE otherwise.

2 calls to Image::scaleDimensions()
ImageTest::testScaleDimensions in core/tests/Drupal/Tests/Component/Utility/ImageTest.php
Tests all control flow branches in image_dimensions_scale().
ScaleImageEffect::transformDimensions in core/modules/image/src/Plugin/ImageEffect/ScaleImageEffect.php
Determines the dimensions of the styled image.

File

core/lib/Drupal/Component/Utility/Image.php, line 34

Class

Image
Provides helpers to operate on images.

Namespace

Drupal\Component\Utility

Code

public static function scaleDimensions(array &$dimensions, $width = NULL, $height = NULL, $upscale = FALSE) {
    $aspect = $dimensions['height'] / $dimensions['width'];
    // Calculate one of the dimensions from the other target dimension,
    // ensuring the same aspect ratio as the source dimensions. If one of the
    // target dimensions is missing, that is the one that is calculated. If both
    // are specified then the dimension calculated is the one that would not be
    // calculated to be bigger than its target.
    if ($width && !$height || $width && $height && $aspect < $height / $width) {
        $height = (int) round($width * $aspect);
    }
    else {
        $width = (int) round($height / $aspect);
    }
    // Don't upscale if the option isn't enabled.
    if (!$upscale && ($width >= $dimensions['width'] || $height >= $dimensions['height'])) {
        return FALSE;
    }
    $dimensions['width'] = $width;
    $dimensions['height'] = $height;
    return TRUE;
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.