X-Git-Url: http://www.aleph1.co.uk/gitweb/?a=blobdiff_plain;f=web%2Fcore%2Fmodules%2Fimage%2Ftests%2Fmodules%2Fimage_module_test%2Fsrc%2FPlugin%2FImageEffect%2FUriDependentTestImageEffect.php;fp=web%2Fcore%2Fmodules%2Fimage%2Ftests%2Fmodules%2Fimage_module_test%2Fsrc%2FPlugin%2FImageEffect%2FUriDependentTestImageEffect.php;h=5e5ddc72bcdeb9f1f91494709fbe52bb5730f7ba;hb=a2bd1bf0c2c1f1a17d188f4dc0726a45494cefae;hp=0000000000000000000000000000000000000000;hpb=57c063afa3f66b07c4bbddc2d6129a96d90f0aad;p=yaffs-website diff --git a/web/core/modules/image/tests/modules/image_module_test/src/Plugin/ImageEffect/UriDependentTestImageEffect.php b/web/core/modules/image/tests/modules/image_module_test/src/Plugin/ImageEffect/UriDependentTestImageEffect.php new file mode 100644 index 000000000..5e5ddc72b --- /dev/null +++ b/web/core/modules/image/tests/modules/image_module_test/src/Plugin/ImageEffect/UriDependentTestImageEffect.php @@ -0,0 +1,64 @@ +getUriDependentDimensions($uri); + } + + /** + * {@inheritdoc} + */ + public function applyEffect(ImageInterface $image) { + $dimensions = $this->getUriDependentDimensions($image->getSource()); + return $image->resize($dimensions['width'], $dimensions['height']); + } + + /** + * Make the image dimensions dependent on the image file extension. + * + * @param string $uri + * Original image file URI. + * + * @return array + * Associative array. + * - width: Integer with the derivative image width. + * - height: Integer with the derivative image height. + */ + protected function getUriDependentDimensions($uri) { + $dimensions = []; + $extension = pathinfo($uri, PATHINFO_EXTENSION); + switch (strtolower($extension)) { + case 'png': + $dimensions['width'] = $dimensions['height'] = 100; + break; + + case 'gif': + $dimensions['width'] = $dimensions['height'] = 50; + break; + + default: + $dimensions['width'] = $dimensions['height'] = 20; + break; + + } + return $dimensions; + } + +}