diff --git a/src/Drivers/AbstractDriver.php b/src/Drivers/AbstractDriver.php index bbef4608f..215946f6f 100644 --- a/src/Drivers/AbstractDriver.php +++ b/src/Drivers/AbstractDriver.php @@ -64,6 +64,7 @@ public function specialize( /** * {@inheritdoc} * + * @throws NotSupportedException * @see DriverInterface::specializeMultiple() */ public function specializeMultiple(array $objects): array diff --git a/src/Drivers/Gd/Driver.php b/src/Drivers/Gd/Driver.php index 090faebd4..5065b75a7 100644 --- a/src/Drivers/Gd/Driver.php +++ b/src/Drivers/Gd/Driver.php @@ -72,6 +72,7 @@ public function createImage(int $width, int $height): ImageInterface /** * {@inheritdoc} * + * @throws RuntimeException * @see DriverInterface::createAnimation() */ public function createAnimation(callable $init): ImageInterface diff --git a/src/Drivers/Gd/Modifiers/CoverDownModifier.php b/src/Drivers/Gd/Modifiers/CoverDownModifier.php index dc6fbd2d8..ac1cec11a 100644 --- a/src/Drivers/Gd/Modifiers/CoverDownModifier.php +++ b/src/Drivers/Gd/Modifiers/CoverDownModifier.php @@ -14,6 +14,6 @@ class CoverDownModifier extends CoverModifier */ public function getResizeSize(SizeInterface $size): SizeInterface { - return $size->scaleDown($this->width, $this->height); + return $size->resizeDown($this->width, $this->height); } } diff --git a/src/Drivers/Imagick/Driver.php b/src/Drivers/Imagick/Driver.php index 2c01f83b3..b7d7c1500 100644 --- a/src/Drivers/Imagick/Driver.php +++ b/src/Drivers/Imagick/Driver.php @@ -71,6 +71,7 @@ public function createImage(int $width, int $height): ImageInterface /** * {@inheritdoc} * + * @throws RuntimeException * @see DriverInterface::createAnimation() */ public function createAnimation(callable $init): ImageInterface diff --git a/src/Drivers/Imagick/Modifiers/CoverDownModifier.php b/src/Drivers/Imagick/Modifiers/CoverDownModifier.php index efc822978..44ab79e4a 100644 --- a/src/Drivers/Imagick/Modifiers/CoverDownModifier.php +++ b/src/Drivers/Imagick/Modifiers/CoverDownModifier.php @@ -14,6 +14,6 @@ class CoverDownModifier extends CoverModifier */ public function getResizeSize(SizeInterface $size): SizeInterface { - return $size->scaleDown($this->width, $this->height); + return $size->resizeDown($this->width, $this->height); } } diff --git a/src/Modifiers/CoverModifier.php b/src/Modifiers/CoverModifier.php index d71a5e42a..61e5acc5a 100644 --- a/src/Modifiers/CoverModifier.php +++ b/src/Modifiers/CoverModifier.php @@ -38,6 +38,6 @@ public function getCropSize(ImageInterface $image): SizeInterface */ public function getResizeSize(SizeInterface $size): SizeInterface { - return $size->scale($this->width, $this->height); + return $size->resize($this->width, $this->height); } } diff --git a/tests/Unit/Drivers/Gd/Modifiers/CoverDownModifierTest.php b/tests/Unit/Drivers/Gd/Modifiers/CoverDownModifierTest.php new file mode 100644 index 000000000..4b08306ac --- /dev/null +++ b/tests/Unit/Drivers/Gd/Modifiers/CoverDownModifierTest.php @@ -0,0 +1,38 @@ +readTestImage('blocks.png'); + $this->assertEquals(640, $image->width()); + $this->assertEquals(480, $image->height()); + $image->modify(new CoverDownModifier(100, 100, 'center')); + $this->assertEquals(100, $image->width()); + $this->assertEquals(100, $image->height()); + $this->assertColor(255, 0, 0, 255, $image->pickColor(90, 90)); + $this->assertColor(0, 255, 0, 255, $image->pickColor(65, 70)); + $this->assertColor(0, 0, 255, 255, $image->pickColor(70, 52)); + $this->assertTransparency($image->pickColor(90, 30)); + } + + public function testModifyOddSize(): void + { + $image = $this->createTestImage(375, 250); + $image->modify(new CoverDownModifier(240, 90, 'center')); + $this->assertEquals(240, $image->width()); + $this->assertEquals(90, $image->height()); + } +} diff --git a/tests/Unit/Drivers/Gd/Modifiers/CoverModifierTest.php b/tests/Unit/Drivers/Gd/Modifiers/CoverModifierTest.php index 20ccd37d1..83c9487b5 100644 --- a/tests/Unit/Drivers/Gd/Modifiers/CoverModifierTest.php +++ b/tests/Unit/Drivers/Gd/Modifiers/CoverModifierTest.php @@ -27,4 +27,12 @@ public function testModify(): void $this->assertColor(0, 0, 255, 255, $image->pickColor(70, 52)); $this->assertTransparency($image->pickColor(90, 30)); } + + public function testModifyOddSize(): void + { + $image = $this->createTestImage(375, 250); + $image->modify(new CoverModifier(240, 90, 'center')); + $this->assertEquals(240, $image->width()); + $this->assertEquals(90, $image->height()); + } } diff --git a/tests/Unit/Drivers/Imagick/Modifiers/CoverDownModifierTest.php b/tests/Unit/Drivers/Imagick/Modifiers/CoverDownModifierTest.php new file mode 100644 index 000000000..2ffdfc966 --- /dev/null +++ b/tests/Unit/Drivers/Imagick/Modifiers/CoverDownModifierTest.php @@ -0,0 +1,38 @@ +readTestImage('blocks.png'); + $this->assertEquals(640, $image->width()); + $this->assertEquals(480, $image->height()); + $image->modify(new CoverDownModifier(100, 100, 'center')); + $this->assertEquals(100, $image->width()); + $this->assertEquals(100, $image->height()); + $this->assertColor(255, 0, 0, 255, $image->pickColor(90, 90)); + $this->assertColor(0, 255, 0, 255, $image->pickColor(65, 70)); + $this->assertColor(0, 0, 255, 255, $image->pickColor(70, 52)); + $this->assertTransparency($image->pickColor(90, 30)); + } + + public function testModifyOddSize(): void + { + $image = $this->createTestImage(375, 250); + $image->modify(new CoverDownModifier(240, 90, 'center')); + $this->assertEquals(240, $image->width()); + $this->assertEquals(90, $image->height()); + } +} diff --git a/tests/Unit/Drivers/Imagick/Modifiers/CoverModifierTest.php b/tests/Unit/Drivers/Imagick/Modifiers/CoverModifierTest.php index 07c607a1d..87523dbd2 100644 --- a/tests/Unit/Drivers/Imagick/Modifiers/CoverModifierTest.php +++ b/tests/Unit/Drivers/Imagick/Modifiers/CoverModifierTest.php @@ -27,4 +27,12 @@ public function testModify(): void $this->assertColor(0, 0, 255, 255, $image->pickColor(70, 52)); $this->assertTransparency($image->pickColor(90, 30)); } + + public function testModifyOddSize(): void + { + $image = $this->createTestImage(375, 250); + $image->modify(new CoverModifier(240, 90, 'center')); + $this->assertEquals(240, $image->width()); + $this->assertEquals(90, $image->height()); + } }