class Image

Same name in this branch
  1. 11.x core/modules/media/src/Plugin/media/Source/Image.php \Drupal\media\Plugin\media\Source\Image
  2. 11.x core/modules/ckeditor5/src/Plugin/CKEditor5Plugin/Image.php \Drupal\ckeditor5\Plugin\CKEditor5Plugin\Image
  3. 11.x core/lib/Drupal/Core/Image/Image.php \Drupal\Core\Image\Image
Same name in other branches
  1. 9 core/modules/media/src/Plugin/media/Source/Image.php \Drupal\media\Plugin\media\Source\Image
  2. 9 core/modules/ckeditor5/src/Plugin/CKEditor5Plugin/Image.php \Drupal\ckeditor5\Plugin\CKEditor5Plugin\Image
  3. 9 core/modules/quickedit/src/Plugin/InPlaceEditor/Image.php \Drupal\quickedit\Plugin\InPlaceEditor\Image
  4. 9 core/modules/image/src/Plugin/InPlaceEditor/Image.php \Drupal\image\Plugin\InPlaceEditor\Image
  5. 9 core/lib/Drupal/Core/Image/Image.php \Drupal\Core\Image\Image
  6. 9 core/lib/Drupal/Component/Utility/Image.php \Drupal\Component\Utility\Image
  7. 8.9.x core/modules/media/src/Plugin/media/Source/Image.php \Drupal\media\Plugin\media\Source\Image
  8. 8.9.x core/modules/image/src/Plugin/InPlaceEditor/Image.php \Drupal\image\Plugin\InPlaceEditor\Image
  9. 8.9.x core/lib/Drupal/Core/Image/Image.php \Drupal\Core\Image\Image
  10. 8.9.x core/lib/Drupal/Component/Utility/Image.php \Drupal\Component\Utility\Image
  11. 10 core/modules/media/src/Plugin/media/Source/Image.php \Drupal\media\Plugin\media\Source\Image
  12. 10 core/modules/ckeditor5/src/Plugin/CKEditor5Plugin/Image.php \Drupal\ckeditor5\Plugin\CKEditor5Plugin\Image
  13. 10 core/lib/Drupal/Core/Image/Image.php \Drupal\Core\Image\Image
  14. 10 core/lib/Drupal/Component/Utility/Image.php \Drupal\Component\Utility\Image

Provides helpers to operate on images.

Hierarchy

  • class \Drupal\Component\Utility\Image

Expanded class hierarchy of Image

Related topics

4 files declare their use of Image
CropImageEffect.php in core/modules/image/src/Plugin/ImageEffect/CropImageEffect.php
ImageTest.php in core/tests/Drupal/Tests/Component/Utility/ImageTest.php
ScaleAndCropImageEffect.php in core/modules/image/src/Plugin/ImageEffect/ScaleAndCropImageEffect.php
ScaleImageEffect.php in core/modules/image/src/Plugin/ImageEffect/ScaleImageEffect.php
328 string references to 'Image'
344b943c-b231-4d73-9669-0b0a2be12aa5.yml in core/tests/fixtures/default_content/media/344b943c-b231-4d73-9669-0b0a2be12aa5.yml
core/tests/fixtures/default_content/media/344b943c-b231-4d73-9669-0b0a2be12aa5.yml
AjaxFileManagedMultipleTest::testMultipleFilesUpload in core/modules/file/tests/src/FunctionalJavascript/AjaxFileManagedMultipleTest.php
Tests if managed file form element works well with multiple files upload.
banner.component.yml in core/profiles/demo_umami/themes/umami/components/banner/banner.component.yml
core/profiles/demo_umami/themes/umami/components/banner/banner.component.yml
ckeditor5.ckeditor5.yml in core/modules/ckeditor5/ckeditor5.ckeditor5.yml
core/modules/ckeditor5/ckeditor5.ckeditor5.yml
CKEditor5AllowedTagsTest::testImgAddedViaUploadPlugin in core/modules/ckeditor5/tests/src/FunctionalJavascript/CKEditor5AllowedTagsTest.php
Tests that the img tag is added after enabling image uploads.

... See full list

File

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

Namespace

Drupal\Component\Utility
View source
class Image {
    
    /**
     * Scales image dimensions while maintaining aspect ratio.
     *
     * The resulting dimensions can be smaller for one or both target dimensions.
     *
     * @param array $dimensions
     *   Dimensions to be modified - an array with components width and height, in
     *   pixels.
     * @param int $width
     *   (optional) The target width, in pixels. If this value is NULL then the
     *   scaling will be based only on the height value.
     * @param int $height
     *   (optional) The target height, in pixels. If this value is NULL then the
     *   scaling will be based only on the width value.
     * @param 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 bool
     *   TRUE if $dimensions was modified, FALSE otherwise.
     */
    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;
    }
    
    /**
     * Returns the offset in pixels from the anchor.
     *
     * @param string $anchor
     *   The anchor ('top', 'left', 'bottom', 'right', 'center').
     * @param int $current_size
     *   The current size, in pixels.
     * @param int $new_size
     *   The new size, in pixels.
     *
     * @return int
     *   The offset from the anchor, in pixels.
     *
     * @throws \InvalidArgumentException
     *   When the $anchor argument is not valid.
     */
    public static function getKeywordOffset(string $anchor, int $current_size, int $new_size) : int {
        return match ($anchor) {    'bottom', 'right' => $current_size - $new_size,
            'center' => (int) round($current_size / 2 - $new_size / 2),
            'top', 'left' => 0,
            default => throw new \InvalidArgumentException("Invalid anchor '{$anchor}' provided to getKeywordOffset()"),
        
        };
    }

}

Members

Title Sort descending Modifiers Object type Summary
Image::getKeywordOffset public static function Returns the offset in pixels from the anchor.
Image::scaleDimensions public static function Scales image dimensions while maintaining aspect ratio.

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