function Crop::validateArguments
Validates the arguments.
Image toolkit operation implementers should place any argument validation in this method, throwing an InvalidArgumentException when an error is encountered.
Validation typically includes things like:
- Checking that width and height are not negative.
- Checking that a color value is indeed a color.
But validation may also include correcting the arguments, e.g:
- Casting arguments to the correct type.
- Rounding pixel values to an integer.
This base implementation just returns the array of arguments and thus does not need to be called by overriding methods.
Parameters
array $arguments: An associative array of arguments to be used by the toolkit operation.
Return value
array The validated and corrected arguments array.
Overrides ImageToolkitOperationBase::validateArguments
File
- 
              core/modules/ system/ src/ Plugin/ ImageToolkit/ Operation/ gd/ Crop.php, line 45 
Class
- Crop
- Defines GD2 Crop operation.
Namespace
Drupal\system\Plugin\ImageToolkit\Operation\gdCode
protected function validateArguments(array $arguments) {
  // Assure at least one dimension.
  if (empty($arguments['width']) && empty($arguments['height'])) {
    throw new \InvalidArgumentException("At least one dimension ('width' or 'height') must be provided to the image 'crop' operation");
  }
  // Preserve aspect.
  $aspect = $this->getToolkit()
    ->getHeight() / $this->getToolkit()
    ->getWidth();
  $arguments['height'] = empty($arguments['height']) ? $arguments['width'] * $aspect : $arguments['height'];
  $arguments['width'] = empty($arguments['width']) ? $arguments['height'] / $aspect : $arguments['width'];
  // Assure integers for all arguments.
  foreach ([
    'x',
    'y',
    'width',
    'height',
  ] as $key) {
    $arguments[$key] = (int) round($arguments[$key]);
  }
  // Fail when width or height are 0 or negative.
  if ($arguments['width'] <= 0) {
    throw new \InvalidArgumentException("Invalid width ('{$arguments['width']}') specified for the image 'crop' operation");
  }
  if ($arguments['height'] <= 0) {
    throw new \InvalidArgumentException("Invalid height ('{$arguments['height']}') specified for the image 'crop' operation");
  }
  return $arguments;
}Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.
