class Replace in Image Replace 8
Same name in this branch
- 8 src/Plugin/ImageToolkit/Operation/gd/Replace.php \Drupal\image_replace\Plugin\ImageToolkit\Operation\gd\Replace
- 8 src/Plugin/ImageToolkit/Operation/imagemagick/Replace.php \Drupal\image_replace\Plugin\ImageToolkit\Operation\imagemagick\Replace
Defines GD2 image_replace operation.
Plugin annotation
@ImageToolkitOperation(
id = "image_replace_gd",
toolkit = "gd",
operation = "image_replace",
label = @Translation("Replace"),
description = @Translation("Swap the original image with a replacement 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\image_replace\Plugin\ImageToolkit\Operation\gd\Replace
- 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 Replace
File
- src/
Plugin/ ImageToolkit/ Operation/ gd/ Replace.php, line 20
Namespace
Drupal\image_replace\Plugin\ImageToolkit\Operation\gdView source
class Replace extends GDImageToolkitOperationBase {
/**
* {@inheritdoc}
*/
protected function arguments() {
return [
'replacement_image' => [
'description' => 'The replacement image',
],
];
}
/**
* {@inheritdoc}
*/
protected function validateArguments(array $arguments) {
if (!($arguments['replacement_image'] instanceof ImageInterface || !$arguments['replacement_image']
->getToolkit() instanceof GDToolkit)) {
throw new \InvalidArgumentException("Invalid replacement image specified for the 'image_replace' operation.");
}
return $arguments;
}
/**
* {@inheritdoc}
*/
protected function execute(array $arguments = []) {
// Create a new resource of the required dimensions, and replace the
// original resource on it with resampling. Destroy the original resource
// upon success.
$replacement_toolkit = $this
->getReplacementImageToolkit($arguments);
$original_resource = $this
->getToolkit()
->getResource();
$data = [
'width' => $replacement_toolkit
->getWidth(),
'height' => $replacement_toolkit
->getHeight(),
'extension' => image_type_to_extension($this
->getToolkit()
->getType(), FALSE),
'transparent_color' => $replacement_toolkit
->getTransparentColor(),
'is_temp' => TRUE,
];
if ($this
->getToolkit()
->apply('create_new', $data)) {
if (imagecopy($this
->getToolkit()
->getResource(), $replacement_toolkit
->getResource(), 0, 0, 0, 0, $data['width'], $data['height'])) {
imagedestroy($original_resource);
return TRUE;
}
else {
// In case of failure, destroy the temporary resource and restore
// the original one.
imagedestroy($this
->getToolkit()
->getResource());
$this
->getToolkit()
->setResource($original_resource);
}
}
return FALSE;
}
/**
* Returns the correctly typed replacement image toolkit for GD operations.
*
* @param array $arguments
* An associative array of data to be used by the toolkit operation.
*
* @return \Drupal\system\Plugin\ImageToolkit\GDToolkit
* The correctly typed replacement image toolkit for GD operations.
*/
protected function getReplacementImageToolkit(array $arguments = []) {
return $arguments['replacement_image']
->getToolkit();
}
}
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:: |
|
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. | |
Replace:: |
protected | function |
Returns the definition of the operation arguments. Overrides ImageToolkitOperationBase:: |
|
Replace:: |
protected | function |
Performs the actual manipulation on the image. Overrides ImageToolkitOperationBase:: |
|
Replace:: |
protected | function | Returns the correctly typed replacement image toolkit for GD operations. | |
Replace:: |
protected | function |
Validates the arguments. Overrides ImageToolkitOperationBase:: |
|
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. |