class Image in Zircon Profile 8
Same name in this branch
- 8 vendor/symfony/validator/Constraints/Image.php \Symfony\Component\Validator\Constraints\Image
- 8 core/lib/Drupal/Core/Image/Image.php \Drupal\Core\Image\Image
- 8 core/lib/Drupal/Component/Utility/Image.php \Drupal\Component\Utility\Image
Same name and namespace in other branches
- 8.0 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
2 files declare their use of Image
- ImageTest.php in core/
tests/ Drupal/ Tests/ Component/ Utility/ ImageTest.php - Contains \Drupal\Tests\Component\Utility\ImageTest.
- ScaleImageEffect.php in core/
modules/ image/ src/ Plugin/ ImageEffect/ ScaleImageEffect.php - Contains \Drupal\image\Plugin\ImageEffect\ScaleImageEffect.
11 string references to 'Image'
- aggregator_entity_extra_field_info in core/
modules/ aggregator/ aggregator.module - Implements hook_entity_extra_field_info().
- DrupalImage::getButtons in core/
modules/ ckeditor/ src/ Plugin/ CKEditorPlugin/ DrupalImage.php - Returns the buttons that this plugin provides, along with metadata.
- EditorImageDialog::buildForm in core/
modules/ editor/ src/ Form/ EditorImageDialog.php - field.field.node.article.field_image.yml in core/
profiles/ standard/ config/ install/ field.field.node.article.field_image.yml - core/profiles/standard/config/install/field.field.node.article.field_image.yml
- FormTestFormStateValuesCleanAdvancedForm::buildForm in core/
modules/ system/ tests/ modules/ form_test/ src/ Form/ FormTestFormStateValuesCleanAdvancedForm.php - Form constructor.
File
- core/
lib/ Drupal/ Component/ Utility/ Image.php, line 15 - Contains \Drupal\Component\Utility\Image.
Namespace
Drupal\Component\UtilityView 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.
*
* @see image_scale()
*/
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;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
Image:: |
public static | function | Scales image dimensions while maintaining aspect ratio. |