class ImageBorder in Image effect kit 8
Defines IEK - Border operation.
Plugin annotation
@ImageToolkitOperation(
id = "gd_iek_image_border",
toolkit = "gd",
operation = "iek_image_border",
label = @Translation("IEK - Border"),
description = @Translation("Add border 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\ImageBorder
- 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 ImageBorder
File
- src/
Plugin/ ImageToolkit/ Operation/ gd/ ImageBorder.php, line 23 - Contains \Drupal\iek\Plugin\ImageToolkit\Operation\gd\ImageBorder.
Namespace
Drupal\iek\Plugin\ImageToolkit\Operation\gdView source
class ImageBorder extends GDImageToolkitOperationBase {
/**
* {@inheritdoc}
*/
protected function arguments() {
return [
'border_color' => [
'description' => 'Border color',
],
'border_thick_top' => [
'description' => 'Border thick - top',
],
'border_thick_right' => [
'description' => 'Border thick - right',
],
'border_thick_bottom' => [
'description' => 'Border thick - bottom',
],
'border_thick_left' => [
'description' => 'Border thick - left',
],
];
}
/**
* {@inheritdoc}
*/
protected function validateArguments(array $arguments) {
// TODO - validate color code.
// Fail when border width is 0 or negative.
if ((int) $arguments['border_thick_top'] <= 0) {
throw new \InvalidArgumentException("Invalid border width ('{$arguments['border_thick_top']}') specified for the image 'iek_image_border' operation");
}
// Fail when border width is 0 or negative.
if ((int) $arguments['border_thick_right'] <= 0) {
throw new \InvalidArgumentException("Invalid border width ('{$arguments['border_thick_right']}') specified for the image 'iek_image_border' operation");
}
// Fail when border width is 0 or negative.
if ((int) $arguments['border_thick_bottom'] <= 0) {
throw new \InvalidArgumentException("Invalid border width ('{$arguments['border_thick_bottom']}') specified for the image 'iek_image_border' operation");
}
// Fail when border width is 0 or negative.
if ((int) $arguments['border_thick_left'] <= 0) {
throw new \InvalidArgumentException("Invalid border width ('{$arguments['border_thick_left']}') specified for the image 'iek_image_border' operation");
}
return $arguments;
}
/**
* {@inheritdoc}
*/
protected function execute(array $arguments = []) {
$data = $arguments;
$border_color = $data['border_color'];
$border_thick_top = $data['border_thick_top'];
$border_thick_right = $data['border_thick_right'];
$border_thick_bottom = $data['border_thick_bottom'];
$border_thick_left = $data['border_thick_left'];
$width = $this
->getToolkit()
->getWidth();
$height = $this
->getToolkit()
->getHeight();
$border_rgb = iek_hex2rgb($border_color);
$bg_rgb = iek_hex2rgb('#ffffff');
$dst = imagecreatetruecolor($width, $height);
// Creates background.
$bg = imagecolorallocate($dst, $bg_rgb['red'], $bg_rgb['green'], $bg_rgb['blue']);
// Defines border color.
$border_colors = imagecolorallocate($dst, $border_rgb['red'], $border_rgb['green'], $border_rgb['blue']);
imagefilledrectangle($dst, 0, 0, $width, $height, $border_colors);
imagefilledrectangle($dst, $border_thick_left, $border_thick_top, $width - $border_thick_right - 1, $height - $border_thick_bottom - 1, $bg);
$this
->getToolkit()
->apply('iek_image_resize', [
'width' => $width - ($border_thick_left + $border_thick_right),
'height' => $height - ($border_thick_top + $border_thick_bottom),
'blank_margin' => FALSE,
'blank_margin_bg_color' => $border_color,
'position' => 'middle_center',
'x' => 0,
'y' => 0,
]);
if (!imagecopy($dst, $this
->getToolkit()
->getResource(), $border_thick_left, $border_thick_top, 0, 0, $width - ($border_thick_left + $border_thick_right), $height - ($border_thick_top + $border_thick_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:: |
|
ImageBorder:: |
protected | function |
Returns the definition of the operation arguments. Overrides ImageToolkitOperationBase:: |
|
ImageBorder:: |
protected | function |
Performs the actual manipulation on the image. Overrides ImageToolkitOperationBase:: |
|
ImageBorder:: |
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. |