Convert a PDF into the ZPL format. Allowing for custom images, alphabets like Hebrew, Arabic and Cyrillic (without messing with fonts on the printer) and multipage shipping labels!
composer require faerber/pdf-to-zpl
<?php
use Faerber\PdfToZpl\PdfToZplConverter;
$converter = new PdfToZplConverter();
// Get an array of ZPL commands (1 per page)
$pages = $converter->convertFromFile("myFile.pdf");
foreach ($pages as $index => $page) {
// Each page is a single ZPL statement
assert(str_starts_with($page, "^XA^GFA,"));
}
Ensure you have Imagick and GD installed using:
sudo apt install php8.4-gd
sudo apt install php8.4-imagick
Then make sure to enable them in php.ini
.
This library can work with only Imagick but GD is recommended as well because its a lot faster (see benchmarks for more details)! If you would like to only use Imagick use these settings:
<?php
use Faerber\PdfToZpl\PdfToZplConverter;
use Faerber\PdfToZpl\Settings\ConverterSettings;
use Faerber\PdfToZpl\Images\ImageProcessorOption;
$converter = new PdfToZplConverter(
new ConverterSettings(
imageProcessorOption: ImageProcessorOption::Imagick,
)
);
You may need to enable PDF permission in your Imagick settings.
The easiest way to do this is by running the setup shell script: sudo ./scripts/configure-imagick.sh
If the script doesn't meet your needs you can perform the change manually.
First edit your Imagick Policy file with: sudo nano "/etc/$(ls /etc/ | grep ImageMagick)/policy.xml"
Find this line and ensure the rights are set to read | write
:
<policy domain="coder" rights="none" pattern="PDF" />
Change to:
<policy domain="coder" rights="read | write" pattern="PDF" />
I've only tested this library on Linux and Mac so if you get it working on windows feel free to open a PR!
<?php
use Faerber\PdfToZpl\ImageToZplConverter;
$converter = new ImagetoZplConverter();
// Get an array of ZPL commands (1 per page)
[$zpl] = $converter->convertFromFile("myFile.png");
assert(str_starts_with($zpl, "^XA^GFA,"));
The labelary
API is used to generate images from ZPL allowing the label to be previewed.
This is a free API that requires no auth so it can be used with no setup. Be sure to respect their rate limits!
<?php
use Faerber\PdfToZpl\LabelImage;
use Faerber\PdfToZpl\Settings\LabelDirection;
$zpl = "^XA_ZPL_DATA_HERE...";
$labelImage = new LabelImage(
zpl: $zpl,
direction: LabelDirection::Up,
);
$labelImage->saveAs("my_label.png");
Testing is done via PHP Unit. Run composer test
.
If you make major changes you may need to regenerate the test data.
For example modifying scaling code where the output is correct but the test data is outdated.
Run composer generate-test-data
and manually verify the images are rendered correctly.
Benchmarking is done via phpbench
. Run composer benchmark
.
Formatting is done via php-cs-fixer
. Run composer format
.
- Loads the PDF and render each page as image
- Scale the image to match the DPI and aspect ratio of the label
- Convert each page into a grayscaled bitmap
- Run line encode the bitmap and marshall it into a ZPL binary representation
- Wrap the encoded data into a ZPL payload