From a9339a5384fffdf24fbaa7ddeb1ccb94ff2b5c60 Mon Sep 17 00:00:00 2001 From: Casper Bakker Date: Sat, 21 Sep 2024 14:41:23 +0200 Subject: [PATCH 1/3] Add support for background colors --- generate-verified-files.php | 7 ++++ src/Renderers/DynamicHtmlRenderer.php | 10 ++++- src/Renderers/HtmlRenderer.php | 12 +++++- src/Renderers/JpgRenderer.php | 9 ++++- src/Renderers/PngRenderer.php | 35 ++++++++++++++--- src/Renderers/SvgRenderer.php | 13 +++++++ tests/HtmlRendererTest.php | 11 ++++++ tests/SvgRendererTest.php | 11 ++++++ .../081231723897-code128-red-background.html | 30 +++++++++++++++ .../081231723897-ean13-red-background.svg | 38 +++++++++++++++++++ 10 files changed, 167 insertions(+), 9 deletions(-) create mode 100644 tests/verified-files/081231723897-code128-red-background.html create mode 100644 tests/verified-files/081231723897-ean13-red-background.svg diff --git a/generate-verified-files.php b/generate-verified-files.php index 386da50..3d02f76 100644 --- a/generate-verified-files.php +++ b/generate-verified-files.php @@ -14,8 +14,15 @@ file_put_contents('tests/verified-files/081231723897-ean13.svg', $svgRenderer->render($barcode, $barcode->getWidth() * 2)); file_put_contents('tests/verified-files/081231723897-ean13-fractional-width.svg', $svgRenderer->render($barcode, $barcode->getWidth() * 0.25, 25.75)); +$svgRendererRed = new Picqer\Barcode\Renderers\SvgRenderer(); +$svgRendererRed->setBackgroundColor('red'); +file_put_contents('tests/verified-files/081231723897-ean13-red-background.svg', $svgRendererRed->render($barcode, $barcode->getWidth() * 2)); + $barcode = $typeEncoderCode128->getBarcode('081231723897'); file_put_contents('tests/verified-files/081231723897-code128.html', $htmlRenderer->render($barcode, $barcode->getWidth() * 2)); +$htmlRendererRed = new Picqer\Barcode\Renderers\HtmlRenderer(); +$htmlRendererRed->setBackgroundColor('red'); +file_put_contents('tests/verified-files/081231723897-code128-red-background.html', $htmlRendererRed->render($barcode, $barcode->getWidth() * 2)); $barcode = $typeEncoderIMB->getBarcode('12345678903'); file_put_contents('tests/verified-files/12345678903-imb.html', $htmlRenderer->render($barcode, $barcode->getWidth() * 2)); diff --git a/src/Renderers/DynamicHtmlRenderer.php b/src/Renderers/DynamicHtmlRenderer.php index 66a3e52..45500e5 100644 --- a/src/Renderers/DynamicHtmlRenderer.php +++ b/src/Renderers/DynamicHtmlRenderer.php @@ -10,10 +10,11 @@ class DynamicHtmlRenderer protected const WIDTH_PRECISION = 6; protected string $foregroundColor = 'black'; + protected ?string $backgroundColor = null; public function render(Barcode $barcode): string { - $html = '
' . PHP_EOL; + $html = '
' . PHP_EOL; $positionHorizontal = 0; /** @var BarcodeBar $bar */ @@ -36,10 +37,17 @@ public function render(Barcode $barcode): string return $html; } + // Use HTML color definitions, like 'red' or '#ff0000' public function setForegroundColor(string $color): self { $this->foregroundColor = $color; + return $this; + } + // Use HTML color definitions, like 'red' or '#ff0000' + public function setBackgroundColor(?string $color): self + { + $this->backgroundColor = $color; return $this; } } diff --git a/src/Renderers/HtmlRenderer.php b/src/Renderers/HtmlRenderer.php index 77ba389..fae8ffa 100644 --- a/src/Renderers/HtmlRenderer.php +++ b/src/Renderers/HtmlRenderer.php @@ -8,12 +8,13 @@ class HtmlRenderer { protected string $foregroundColor = 'black'; + protected ?string $backgroundColor = null; public function render(Barcode $barcode, float $width = 200, float $height = 30): string { $widthFactor = $width / $barcode->getWidth(); - $html = '
' . PHP_EOL; + $html = '
' . PHP_EOL; $positionHorizontal = 0; /** @var BarcodeBar $bar */ @@ -36,10 +37,17 @@ public function render(Barcode $barcode, float $width = 200, float $height = 30) return $html; } + // Use HTML color definitions, like 'red' or '#ff0000' public function setForegroundColor(string $color): self { $this->foregroundColor = $color; - + return $this; + } + + // Use HTML color definitions, like 'red' or '#ff0000' + public function setBackgroundColor(?string $color): self + { + $this->backgroundColor = $color; return $this; } } diff --git a/src/Renderers/JpgRenderer.php b/src/Renderers/JpgRenderer.php index 132ec10..1c835f7 100644 --- a/src/Renderers/JpgRenderer.php +++ b/src/Renderers/JpgRenderer.php @@ -9,7 +9,14 @@ class JpgRenderer extends PngRenderer protected function createImagickImageObject(int $width, int $height): Imagick { $image = new Imagick(); - $image->newImage($width, $height, 'none', 'JPG'); + if ($this->backgroundColor !== null) { + // Colored background + $backgroundColor = new ImagickPixel('rgb(' . implode(',', $this->backgroundColor) . ')'); + } else { + // Use transparent background + $backgroundColor = new ImagickPixel('none'); + } + $image->newImage($width, $height, $backgroundColor, 'JPG'); return $image; } diff --git a/src/Renderers/PngRenderer.php b/src/Renderers/PngRenderer.php index 8297d88..226a7b7 100644 --- a/src/Renderers/PngRenderer.php +++ b/src/Renderers/PngRenderer.php @@ -12,6 +12,8 @@ class PngRenderer { protected array $foregroundColor = [0, 0, 0]; + protected ?array $backgroundColor = null; + protected bool $useImagick; /** @@ -52,6 +54,7 @@ public function render(Barcode $barcode, int $widthFactor = 2, int $height = 30) $width = (int)round($barcode->getWidth() * $widthFactor); if ($this->useImagick) { + $image = $this->createImagickImageObject($width, $height); $imagickBarsShape = new ImagickDraw(); $imagickBarsShape->setFillColor(new ImagickPixel('rgb(' . implode(',', $this->foregroundColor) .')')); } else { @@ -80,7 +83,6 @@ public function render(Barcode $barcode, int $widthFactor = 2, int $height = 30) } if ($this->useImagick) { - $image = $this->createImagickImageObject($width, $height); $image->drawImage($imagickBarsShape); return $image->getImageBlob(); } else { @@ -90,18 +92,34 @@ public function render(Barcode $barcode, int $widthFactor = 2, int $height = 30) } } + // Use RGB color definitions, like [0, 0, 0] or [255, 255, 255] public function setForegroundColor(array $color): self { $this->foregroundColor = $color; - + return $this; + } + + // Use RGB color definitions, like [0, 0, 0] or [255, 255, 255] + // If no color is set, the background will be transparent + public function setBackgroundColor(?array $color): self + { + $this->backgroundColor = $color; return $this; } protected function createGdImageObject(int $width, int $height) { $image = \imagecreate($width, $height); - $colorBackground = \imagecolorallocate($image, 255, 255, 255); - \imagecolortransparent($image, $colorBackground); + + if ($this->backgroundColor !== null) { + // Colored background + $backgroundColor = \imagecolorallocate($image, $this->backgroundColor[0], $this->backgroundColor[1], $this->backgroundColor[2]); + \imagefill($image, 0, 0, $backgroundColor); + } else { + // Use transparent background + $backgroundColor = \imagecolorallocate($image, 255, 255, 255); + \imagecolortransparent($image, $backgroundColor); + } return $image; } @@ -109,7 +127,14 @@ protected function createGdImageObject(int $width, int $height) protected function createImagickImageObject(int $width, int $height): Imagick { $image = new Imagick(); - $image->newImage($width, $height, 'none', 'PNG'); + if ($this->backgroundColor !== null) { + // Colored background + $backgroundColor = new ImagickPixel('rgb(' . implode(',', $this->backgroundColor) . ')'); + } else { + // Use transparent background + $backgroundColor = new ImagickPixel('none'); + } + $image->newImage($width, $height, $backgroundColor, 'PNG'); return $image; } diff --git a/src/Renderers/SvgRenderer.php b/src/Renderers/SvgRenderer.php index 6af44b3..418333a 100644 --- a/src/Renderers/SvgRenderer.php +++ b/src/Renderers/SvgRenderer.php @@ -9,6 +9,7 @@ class SvgRenderer { protected string $foregroundColor = 'black'; + protected ?string $backgroundColor = null; protected string $svgType = self::TYPE_SVG_STANDALONE; public const TYPE_SVG_STANDALONE = 'standalone'; @@ -25,6 +26,12 @@ public function render(Barcode $barcode, float $width = 200, float $height = 30) } $svg .= '' . PHP_EOL; $svg .= "\t" . '' . htmlspecialchars($barcode->getBarcode()) . '' . PHP_EOL; + + // Add background rectangle if backgroundColor is set + if ($this->backgroundColor !== null) { + $svg .= "\t" . '' . PHP_EOL; + } + $svg .= "\t" . '' . PHP_EOL; // print bars @@ -55,6 +62,12 @@ public function setForegroundColor(string $color): self return $this; } + public function setBackgroundColor(?string $color): self + { + $this->backgroundColor = $color; + return $this; + } + public function setSvgType(string $svgType): self { if (! in_array($svgType, [self::TYPE_SVG_INLINE, self::TYPE_SVG_STANDALONE])) { diff --git a/tests/HtmlRendererTest.php b/tests/HtmlRendererTest.php index 803d2c0..387a43e 100644 --- a/tests/HtmlRendererTest.php +++ b/tests/HtmlRendererTest.php @@ -23,4 +23,15 @@ public function test_html_barcode_generator_can_generate_imb_barcode_to_test_hei $this->assertStringEqualsFile('tests/verified-files/12345678903-imb.html', $generated); } + + public function test_html_barcode_generator_with_background() + { + $barcode = (new Picqer\Barcode\Types\TypeCode128())->getBarcode('081231723897'); + + $renderer = new Picqer\Barcode\Renderers\HtmlRenderer(); + $renderer->setBackgroundColor('red'); + $generated = $renderer->render($barcode, $barcode->getWidth() * 2); + + $this->assertStringEqualsFile('tests/verified-files/081231723897-code128-red-background.html', $generated); + } } diff --git a/tests/SvgRendererTest.php b/tests/SvgRendererTest.php index aa1e97f..a8d73e6 100644 --- a/tests/SvgRendererTest.php +++ b/tests/SvgRendererTest.php @@ -56,4 +56,15 @@ public function test_svg_renderer_throws_exception_wrong_type() $renderer = new Picqer\Barcode\Renderers\SvgRenderer(); $renderer->setSvgType('other'); } + + public function test_svg_barcode_generator_can_use_background_color() + { + $barcode = (new Picqer\Barcode\Types\TypeEan13())->getBarcode('081231723897'); + + $renderer = new Picqer\Barcode\Renderers\SvgRenderer(); + $renderer->setBackgroundColor('red'); + $generated = $renderer->render($barcode, 190); + + $this->assertStringEqualsFile('tests/verified-files/081231723897-ean13-red-background.svg', $generated); + } } diff --git a/tests/verified-files/081231723897-code128-red-background.html b/tests/verified-files/081231723897-code128-red-background.html new file mode 100644 index 0000000..6023c22 --- /dev/null +++ b/tests/verified-files/081231723897-code128-red-background.html @@ -0,0 +1,30 @@ +
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
 
+
diff --git a/tests/verified-files/081231723897-ean13-red-background.svg b/tests/verified-files/081231723897-ean13-red-background.svg new file mode 100644 index 0000000..406af57 --- /dev/null +++ b/tests/verified-files/081231723897-ean13-red-background.svg @@ -0,0 +1,38 @@ + + + + 0812317238973 + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + From c48fd714d39cd6ebc7e9d4471e89c965093f3252 Mon Sep 17 00:00:00 2001 From: Casper Bakker Date: Sat, 21 Sep 2024 14:43:45 +0200 Subject: [PATCH 2/3] Fix import --- src/Renderers/JpgRenderer.php | 1 + 1 file changed, 1 insertion(+) diff --git a/src/Renderers/JpgRenderer.php b/src/Renderers/JpgRenderer.php index 1c835f7..0b30226 100644 --- a/src/Renderers/JpgRenderer.php +++ b/src/Renderers/JpgRenderer.php @@ -3,6 +3,7 @@ namespace Picqer\Barcode\Renderers; use Imagick; +use ImagickPixel; class JpgRenderer extends PngRenderer { From 110b2ce1086fa427409f15cb586c000a0b763366 Mon Sep 17 00:00:00 2001 From: Casper Bakker Date: Sat, 21 Sep 2024 14:47:20 +0200 Subject: [PATCH 3/3] Docs --- Readme.md | 12 ++++++++---- 1 file changed, 8 insertions(+), 4 deletions(-) diff --git a/Readme.md b/Readme.md index 2692cca..2a5b960 100644 --- a/Readme.md +++ b/Readme.md @@ -67,7 +67,8 @@ Each renderer has their own options. Only the barcode is required, the rest is o A vector based SVG image. Gives the best quality to print. ```php $renderer = new Picqer\Barcode\Renderers\SvgRenderer(); -$renderer->setForegroundColor('red'); // Give a color for the bars, the background is always white +$renderer->setForegroundColor('red'); // Give a color for the bars, default is black +$renderer->setBackgroundColor('blue'); // Give a color for the background, default is transparent $renderer->setSvgType($renderer::TYPE_SVG_INLINE); // Changes the output to be used inline inside HTML documents, instead of a standalone SVG image (default) $renderer->setSvgType($renderer::TYPE_SVG_STANDALONE); // If you want to force the default, create a stand alone SVG image @@ -78,7 +79,8 @@ $renderer->render($barcode, 450.20, 75); // Width and height support floats All options for PNG and JPG are the same. ```php $renderer = new Picqer\Barcode\Renderers\PngRenderer(); -$renderer->setForegroundColor([255, 0, 0]); // Give a color for the bars, the background is always white. Give it as 3 times 0-255 values for red, green and blue. +$renderer->setForegroundColor([255, 0, 0]); // Give a color for the bars, default is black. Give it as 3 times 0-255 values for red, green and blue. +$renderer->setBackgroundColor([0, 255, 255]); // Give a color for the background, default is transparent (in PNG) or white (in JPG). Give it as 3 times 0-255 values for red, green and blue. $renderer->useGd(); // If you have Imagick and GD installed, but want to use GD $renderer->useImagick(); // If you have Imagick and GD installed, but want to use Imagick @@ -89,7 +91,8 @@ $renderer->render($barcode, 5, 40); // Width factor (how many pixel wide every b Gives HTML to use inline in a full HTML document. ```php $renderer = new Picqer\Barcode\Renderers\HtmlRenderer(); -$renderer->setForegroundColor('red'); // Give a color for the bars, the background is always white +$renderer->setForegroundColor('red'); // Give a color for the bars, default is black +$renderer->setBackgroundColor('blue'); // Give a color for the background, default is transparent $renderer->render($barcode, 450.20, 75); // Width and height support floats ```` @@ -98,7 +101,8 @@ $renderer->render($barcode, 450.20, 75); // Width and height support floats Give HTML here the barcode is using the full width and height, to put inside a container/div that has a fixed size. ```php $renderer = new Picqer\Barcode\Renderers\DynamicHtmlRenderer(); -$renderer->setForegroundColor('red'); // Give a color for the bars, the background is always white +$renderer->setForegroundColor('red'); // Give a color for the bars, default is black +$renderer->setBackgroundColor('blue'); // Give a color for the background, default is transparent $renderer->render($barcode); ````