class ImagePadding in Image effect kit 8
Defines IEK - Padding operation.
Plugin annotation
@ImageToolkitOperation(
id = "gd_iek_image_padding",
toolkit = "gd",
operation = "iek_image_padding",
label = @Translation("IEK - Padding"),
description = @Translation("Add padding to an image.")
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\Core\ImageToolkit\ImageToolkitOperationBase implements ImageToolkitOperationInterface
- class \Drupal\system\Plugin\ImageToolkit\Operation\gd\GDImageToolkitOperationBase
- class \Drupal\iek\Plugin\ImageToolkit\Operation\gd\ImagePadding
- class \Drupal\system\Plugin\ImageToolkit\Operation\gd\GDImageToolkitOperationBase
- class \Drupal\Core\ImageToolkit\ImageToolkitOperationBase implements ImageToolkitOperationInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of ImagePadding
File
- src/
Plugin/ ImageToolkit/ Operation/ gd/ ImagePadding.php, line 23 - Contains \Drupal\iek\Plugin\ImageToolkit\Operation\gd\ImagePadding.
Namespace
Drupal\iek\Plugin\ImageToolkit\Operation\gdView source
class ImagePadding extends GDImageToolkitOperationBase {
/**
* {@inheritdoc}
*/
protected function arguments() {
return [
'padding_top' => [
'description' => 'Padding top',
],
'padding_right' => [
'description' => 'Padding right',
],
'padding_bottom' => [
'description' => 'Padding bottom',
],
'padding_left' => [
'description' => 'Padding left',
],
'bg_color' => [
'description' => 'Background color',
],
];
}
/**
* {@inheritdoc}
*/
protected function validateArguments(array $arguments) {
// Fail when padding is negative.
if ((int) $arguments['padding_top'] < 0) {
throw new \InvalidArgumentException("Invalid padding ('{$arguments['padding_top']}') specified for the image 'iek_image_padding' operation");
}
// Fail when padding is negative.
if ((int) $arguments['padding_right'] < 0) {
throw new \InvalidArgumentException("Invalid padding ('{$arguments['padding_right']}') specified for the image 'iek_image_padding' operation");
}
// Fail when padding is negative.
if ((int) $arguments['padding_bottom'] < 0) {
throw new \InvalidArgumentException("Invalid padding ('{$arguments['padding_bottom']}') specified for the image 'iek_image_padding' operation");
}
// Fail when padding is negative.
if ((int) $arguments['padding_left'] < 0) {
throw new \InvalidArgumentException("Invalid padding ('{$arguments['padding_left']}') specified for the image 'iek_image_padding' operation");
}
// TODO - validate color code.
return $arguments;
}
/**
* {@inheritdoc}
*/
protected function execute(array $arguments = []) {
$data = $arguments;
$width = $this
->getToolkit()
->getWidth();
$height = $this
->getToolkit()
->getHeight();
$padding_top = $data['padding_top'];
$padding_right = $data['padding_right'];
$padding_bottom = $data['padding_bottom'];
$padding_left = $data['padding_left'];
$bg_color = $data['bg_color'];
$dst = imagecreatetruecolor($width, $height);
$bg_rgb = iek_hex2rgb($bg_color);
$bg = imagecolorallocate($dst, $bg_rgb['red'], $bg_rgb['green'], $bg_rgb['blue']);
imagefilledrectangle($dst, 0, 0, $width, $height, $bg);
$this
->getToolkit()
->apply('iek_image_resize', [
'width' => $width - ($padding_left + $padding_right),
'height' => $height - ($padding_top + $padding_bottom),
'blank_margin' => TRUE,
'blank_margin_bg_color' => $bg_color,
'position' => 'middle_center',
'x' => 0,
'y' => 0,
]);
if (!imagecopy($dst, $this
->getToolkit()
->getResource(), $padding_left, $padding_top, 0, 0, $width - ($padding_left + $padding_right), $height - ($padding_top + $padding_bottom))) {
return FALSE;
}
imagedestroy($this
->getToolkit()
->getResource());
// Update image object.
$this
->getToolkit()
->setResource($dst);
return TRUE;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
GDImageToolkitOperationBase:: |
protected | function |
The correctly typed image toolkit for GD operations. Overrides ImageToolkitOperationBase:: |
|
ImagePadding:: |
protected | function |
Returns the definition of the operation arguments. Overrides ImageToolkitOperationBase:: |
|
ImagePadding:: |
protected | function |
Performs the actual manipulation on the image. Overrides ImageToolkitOperationBase:: |
|
ImagePadding:: |
protected | function |
Validates the arguments. Overrides ImageToolkitOperationBase:: |
|
ImageToolkitOperationBase:: |
protected | property | A logger instance. | |
ImageToolkitOperationBase:: |
protected | property | The image toolkit. | |
ImageToolkitOperationBase:: |
final public | function |
Applies a toolkit specific operation to an image. Overrides ImageToolkitOperationInterface:: |
|
ImageToolkitOperationBase:: |
protected | function | Checks if required arguments are passed in and adds defaults for non passed in optional arguments. | |
ImageToolkitOperationBase:: |
public | function |
Constructs an image toolkit operation plugin. Overrides PluginBase:: |
|
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. |