php-barcode-generator/LICENSE.md 0000644 00000016743 15024774422 0012342 0 ustar 00 GNU LESSER GENERAL PUBLIC LICENSE
Version 3, 29 June 2007
Copyright (C) 2007 Free Software Foundation, Inc.
Everyone is permitted to copy and distribute verbatim copies
of this license document, but changing it is not allowed.
This version of the GNU Lesser General Public License incorporates
the terms and conditions of version 3 of the GNU General Public
License, supplemented by the additional permissions listed below.
0. Additional Definitions.
As used herein, "this License" refers to version 3 of the GNU Lesser
General Public License, and the "GNU GPL" refers to version 3 of the GNU
General Public License.
"The Library" refers to a covered work governed by this License,
other than an Application or a Combined Work as defined below.
An "Application" is any work that makes use of an interface provided
by the Library, but which is not otherwise based on the Library.
Defining a subclass of a class defined by the Library is deemed a mode
of using an interface provided by the Library.
A "Combined Work" is a work produced by combining or linking an
Application with the Library. The particular version of the Library
with which the Combined Work was made is also called the "Linked
Version".
The "Minimal Corresponding Source" for a Combined Work means the
Corresponding Source for the Combined Work, excluding any source code
for portions of the Combined Work that, considered in isolation, are
based on the Application, and not on the Linked Version.
The "Corresponding Application Code" for a Combined Work means the
object code and/or source code for the Application, including any data
and utility programs needed for reproducing the Combined Work from the
Application, but excluding the System Libraries of the Combined Work.
1. Exception to Section 3 of the GNU GPL.
You may convey a covered work under sections 3 and 4 of this License
without being bound by section 3 of the GNU GPL.
2. Conveying Modified Versions.
If you modify a copy of the Library, and, in your modifications, a
facility refers to a function or data to be supplied by an Application
that uses the facility (other than as an argument passed when the
facility is invoked), then you may convey a copy of the modified
version:
a) under this License, provided that you make a good faith effort to
ensure that, in the event an Application does not supply the
function or data, the facility still operates, and performs
whatever part of its purpose remains meaningful, or
b) under the GNU GPL, with none of the additional permissions of
this License applicable to that copy.
3. Object Code Incorporating Material from Library Header Files.
The object code form of an Application may incorporate material from
a header file that is part of the Library. You may convey such object
code under terms of your choice, provided that, if the incorporated
material is not limited to numerical parameters, data structure
layouts and accessors, or small macros, inline functions and templates
(ten or fewer lines in length), you do both of the following:
a) Give prominent notice with each copy of the object code that the
Library is used in it and that the Library and its use are
covered by this License.
b) Accompany the object code with a copy of the GNU GPL and this license
document.
4. Combined Works.
You may convey a Combined Work under terms of your choice that,
taken together, effectively do not restrict modification of the
portions of the Library contained in the Combined Work and reverse
engineering for debugging such modifications, if you also do each of
the following:
a) Give prominent notice with each copy of the Combined Work that
the Library is used in it and that the Library and its use are
covered by this License.
b) Accompany the Combined Work with a copy of the GNU GPL and this license
document.
c) For a Combined Work that displays copyright notices during
execution, include the copyright notice for the Library among
these notices, as well as a reference directing the user to the
copies of the GNU GPL and this license document.
d) Do one of the following:
0) Convey the Minimal Corresponding Source under the terms of this
License, and the Corresponding Application Code in a form
suitable for, and under terms that permit, the user to
recombine or relink the Application with a modified version of
the Linked Version to produce a modified Combined Work, in the
manner specified by section 6 of the GNU GPL for conveying
Corresponding Source.
1) Use a suitable shared library mechanism for linking with the
Library. A suitable mechanism is one that (a) uses at run time
a copy of the Library already present on the user's computer
system, and (b) will operate properly with a modified version
of the Library that is interface-compatible with the Linked
Version.
e) Provide Installation Information, but only if you would otherwise
be required to provide such information under section 6 of the
GNU GPL, and only to the extent that such information is
necessary to install and execute a modified version of the
Combined Work produced by recombining or relinking the
Application with a modified version of the Linked Version. (If
you use option 4d0, the Installation Information must accompany
the Minimal Corresponding Source and Corresponding Application
Code. If you use option 4d1, you must provide the Installation
Information in the manner specified by section 6 of the GNU GPL
for conveying Corresponding Source.)
5. Combined Libraries.
You may place library facilities that are a work based on the
Library side by side in a single library together with other library
facilities that are not Applications and are not covered by this
License, and convey such a combined library under terms of your
choice, if you do both of the following:
a) Accompany the combined library with a copy of the same work based
on the Library, uncombined with any other library facilities,
conveyed under the terms of this License.
b) Give prominent notice with the combined library that part of it
is a work based on the Library, and explaining where to find the
accompanying uncombined form of the same work.
6. Revised Versions of the GNU Lesser General Public License.
The Free Software Foundation may publish revised and/or new versions
of the GNU Lesser General Public License from time to time. Such new
versions will be similar in spirit to the present version, but may
differ in detail to address new problems or concerns.
Each version is given a distinguishing version number. If the
Library as you received it specifies that a certain numbered version
of the GNU Lesser General Public License "or any later version"
applies to it, you have the option of following the terms and
conditions either of that published version or of any later version
published by the Free Software Foundation. If the Library as you
received it does not specify a version number of the GNU Lesser
General Public License, you may choose any version of the GNU Lesser
General Public License ever published by the Free Software Foundation.
If the Library as you received it specifies that a proxy can decide
whether future versions of the GNU Lesser General Public License shall
apply, that proxy's public statement of acceptance of any version is
permanent authorization for you to choose that version for the
Library.
php-barcode-generator/.gitignore 0000644 00000000103 15024774422 0012705 0 ustar 00 vendor
composer.lock
composer.phar
.phpunit.result.cache
.DS_Store
php-barcode-generator/examples.md 0000644 00000005543 15024774422 0013072 0 ustar 00 # Examples of supported barcodes
These are examples of supported barcodes with this library.
### C39

### C39+

### C39E+

### C93

### S25

### S25+

### I25

### I25+

### EAN13



### C128


### C128A

### C128B


### EAN2

### EAN5

### EAN8

### UPCA

### UPCE

### MSI

### MSI+

### POSTNET

### PLANET

### RMS4CC

### KIX

### IMB

### CODABAR

### CODE11

### PHARMA

### PHARMA2T

*This file is generated by generate-examples.php* php-barcode-generator/composer.json 0000644 00000002647 15024774422 0013456 0 ustar 00 {
"name": "picqer/php-barcode-generator",
"type": "library",
"description": "An easy to use, non-bloated, barcode generator in PHP. Creates SVG, PNG, JPG and HTML images from the most used 1D barcode standards.",
"keywords": [ "php", "barcode", "barcode generator", "EAN", "EAN13", "UPC", "Code39", "Code128", "Code93", "Standard 2 of 5", "MSI", "POSTNET", "KIX", "KIXCODE", "CODABAR", "PHARMA", "Code11", "SVG", "PNG", "HTML", "JPG", "JPEG" ],
"homepage": "https://github.com/picqer/php-barcode-generator",
"license": "LGPL-3.0-or-later",
"authors": [
{
"name": "Nicola Asuni",
"email": "info@tecnick.com",
"homepage": "http://nicolaasuni.tecnick.com"
},
{
"name": "Casper Bakker",
"email": "info@picqer.com",
"homepage": "https://picqer.com"
}
],
"require": {
"php": "^7.3|^8.0",
"ext-mbstring": "*"
},
"require-dev": {
"phpunit/phpunit": "^9.5"
},
"suggest": {
"ext-bcmath": "Barcode IMB (Intelligent Mail Barcode) needs bcmath extension",
"ext-gd": "For JPG and PNG generators, GD or Imagick is required",
"ext-imagick": "For JPG and PNG generators, GD or Imagick is required"
},
"autoload": {
"psr-4": {
"Picqer\\Barcode\\": "src"
}
},
"scripts": {
"test": "vendor/bin/phpunit"
}
}
php-barcode-generator/CHANGELOG.md 0000644 00000003450 15024774422 0012536 0 ustar 00 # Changelog
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [Unreleased]
## [2.0.1] - 2020-01-28
### Fixed
- Removed special chars from filenames we use for test validation #94
## [2.0.0] - 2020-01-11
### Added
- Introduced Barcode and BarcodeBar classes to standardise generator output.
- Introduced methods to force use of GD or Imagick, see readme.
- Loads of new tests added, including tests on Github Actions.
### Changed
- Splitted all barcode types to different files.
- Refactored a lot of code for better readability, stricter checking, and to be more efficient.
- Merged JPG and PNG generators, because of duplicate code.
### Fixed
- Fixed a bug in Codabar generation 2d1128f5222d9368fc6151d2b51801ea29ba1052
- Do not draw multiple bars on the same position #74
- Do not try to draw barcodes for empty strings #42
- Fixed possible casting issue in Codabar #92
## [0.4.0] - 2019-12-31
### Added
- Added support for PHP 7.4, thanks to @pilif #80
## [0.3.0] - 2019-01-12
### Added
- SVG: Add viewBox attribute to allow svg scaling #68 by @cuchac
- Adjust CODE_128 to handle odd number of digits #55 by @richayles
### Fixed
- Bugfix update imagick function #51 by @Keinbockwurst
## [0.2.2] - 2017-09-28
### Added
- Raising exceptions if we cannot generate JPG or PNG because of missing libraries. Thanks @OskarStark
## [0.2.1] - 2016-10-24
### Fixed
- Bugfixes for wrong constant values.
## [0.2.0] - 2016-05-14
### Added
- This release adds exceptions to this package. Now it is easier to detect if the generated barcode is correct or not.
## [0.1.0] - 2015-08-13
### Added
- Everything. First release of this package.
php-barcode-generator/src/Helpers/BinarySequenceConverter.php 0000644 00000001567 15024774422 0020443 0 ustar 00 addBar(new BarcodeBar($barWidth, 1, $drawBar));
$barWidth = 0;
}
}
return $barcode;
}
}
php-barcode-generator/src/BarcodeGeneratorSVG.php 0000644 00000004506 15024774422 0016016 0 ustar 00 getBarcodeData($barcode, $type);
// replace table for special characters
$repstr = ["\0" => '', '&' => '&', '<' => '<', '>' => '>'];
$width = round(($barcodeData->getWidth() * $widthFactor), 3);
$svg = '' . PHP_EOL;
$svg .= '' . PHP_EOL;
$svg .= '' . PHP_EOL;
return $svg;
}
}
php-barcode-generator/src/BarcodeGeneratorHTML.php 0000644 00000003633 15024774422 0016123 0 ustar 00 getBarcodeData($barcode, $type);
$html = '
The Barcode Identifier shall be assigned by USPS to encode the
* presort identification that is currently printed in human readable form on the optional endorsement line (OEL)
* as well as for future USPS use. This shall be two digits, with the second digit in the range of 0–4. The
* allowable encoding ranges shall be 00–04, 10–14, 20–24, 30–34, 40–44, 50–54, 60–64, 70–74, 80–84, and
* 90–94.
The Service Type Identifier shall be assigned by USPS for any combination of services requested
* on the mailpiece. The allowable encoding range shall be 000http://it2.php.net/manual/en/function.dechex.php–999.
* Each 3-digit value shall correspond to a particular mail class with a particular combination of service(s). Each
* service program, such as OneCode Confirm and OneCode ACS, shall provide the list of Service Type Identifier
* values.
The Mailer or Customer Identifier shall be assigned by USPS as a unique, 6 or 9 digit number
* that identifies a business entity. The allowable encoding range for the 6 digit Mailer ID shall be 000000-
* 899999, while the allowable encoding range for the 9 digit Mailer ID shall be 900000000-999999999.
The
* Serial or Sequence Number shall be assigned by the mailer for uniquely identifying and tracking mailpieces. The
* allowable encoding range shall be 000000000–999999999 when used with a 6 digit Mailer ID and 000000-999999 when
* used with a 9 digit Mailer ID. e. The Delivery Point ZIP Code shall be assigned by the mailer for routing the
* mailpiece. This shall replace POSTNET for routing the mailpiece to its final delivery point. The length may be
* 0, 5, 9, or 11 digits. The allowable encoding ranges shall be no ZIP Code, 00000–99999, 000000000–999999999,
* and 00000000000–99999999999.
*
* code to print, separate the ZIP (routing code) from the rest using a minus char '-'
* (BarcodeID_ServiceTypeID_MailerID_SerialNumber-RoutingCode)
*/
class TypeIntelligentMailBarcode implements TypeInterface
{
public function getBarcodeData(string $code): Barcode
{
$asc_chr = [
4,
0,
2,
6,
3,
5,
1,
9,
8,
7,
1,
2,
0,
6,
4,
8,
2,
9,
5,
3,
0,
1,
3,
7,
4,
6,
8,
9,
2,
0,
5,
1,
9,
4,
3,
8,
6,
7,
1,
2,
4,
3,
9,
5,
7,
8,
3,
0,
2,
1,
4,
0,
9,
1,
7,
0,
2,
4,
6,
3,
7,
1,
9,
5,
8
];
$dsc_chr = [
7,
1,
9,
5,
8,
0,
2,
4,
6,
3,
5,
8,
9,
7,
3,
0,
6,
1,
7,
4,
6,
8,
9,
2,
5,
1,
7,
5,
4,
3,
8,
7,
6,
0,
2,
5,
4,
9,
3,
0,
1,
6,
8,
2,
0,
4,
5,
9,
6,
7,
5,
2,
6,
3,
8,
5,
1,
9,
8,
7,
4,
0,
2,
6,
3
];
$asc_pos = [
3,
0,
8,
11,
1,
12,
8,
11,
10,
6,
4,
12,
2,
7,
9,
6,
7,
9,
2,
8,
4,
0,
12,
7,
10,
9,
0,
7,
10,
5,
7,
9,
6,
8,
2,
12,
1,
4,
2,
0,
1,
5,
4,
6,
12,
1,
0,
9,
4,
7,
5,
10,
2,
6,
9,
11,
2,
12,
6,
7,
5,
11,
0,
3,
2
];
$dsc_pos = [
2,
10,
12,
5,
9,
1,
5,
4,
3,
9,
11,
5,
10,
1,
6,
3,
4,
1,
10,
0,
2,
11,
8,
6,
1,
12,
3,
8,
6,
4,
4,
11,
0,
6,
1,
9,
11,
5,
3,
7,
3,
10,
7,
11,
8,
2,
10,
3,
5,
8,
0,
3,
12,
11,
8,
4,
5,
1,
3,
0,
7,
12,
9,
8,
10
];
$code_arr = explode('-', $code);
$tracking_number = $code_arr[0];
if (isset($code_arr[1])) {
$routing_code = $code_arr[1];
} else {
$routing_code = '';
}
// Conversion of Routing Code
switch (strlen($routing_code)) {
case 0:
$binary_code = 0;
break;
case 5:
$binary_code = bcadd($routing_code, '1');
break;
case 9:
$binary_code = bcadd($routing_code, '100001');
break;
case 11:
$binary_code = bcadd($routing_code, '1000100001');
break;
default:
throw new BarcodeException('Routing code unknown');
}
$binary_code = bcmul($binary_code, 10);
$binary_code = bcadd($binary_code, $tracking_number[0]);
$binary_code = bcmul($binary_code, 5);
$binary_code = bcadd($binary_code, $tracking_number[1]);
$binary_code .= substr($tracking_number, 2, 18);
// convert to hexadecimal
$binary_code = $this->dec_to_hex($binary_code);
// pad to get 13 bytes
$binary_code = str_pad($binary_code, 26, '0', STR_PAD_LEFT);
// convert string to array of bytes
$binary_code_arr = chunk_split($binary_code, 2, "\r");
$binary_code_arr = substr($binary_code_arr, 0, -1);
$binary_code_arr = explode("\r", $binary_code_arr);
// calculate frame check sequence
$fcs = $this->imb_crc11fcs($binary_code_arr);
// exclude first 2 bits from first byte
$first_byte = sprintf('%2s', dechex((hexdec($binary_code_arr[0]) << 2) >> 2));
$binary_code_102bit = $first_byte . substr($binary_code, 2);
// convert binary data to codewords
$codewords = [];
$data = $this->hex_to_dec($binary_code_102bit);
$codewords[0] = bcmod($data, 636) * 2;
$data = bcdiv($data, 636);
for ($i = 1; $i < 9; ++$i) {
$codewords[$i] = bcmod($data, 1365);
$data = bcdiv($data, 1365);
}
$codewords[9] = $data;
if (($fcs >> 10) == 1) {
$codewords[9] += 659;
}
// generate lookup tables
$table2of13 = $this->imb_tables(2, 78);
$table5of13 = $this->imb_tables(5, 1287);
// convert codewords to characters
$characters = [];
$bitmask = 512;
foreach ($codewords as $k => $val) {
if ($val <= 1286) {
$chrcode = $table5of13[$val];
} else {
$chrcode = $table2of13[($val - 1287)];
}
if (($fcs & $bitmask) > 0) {
// bitwise invert
$chrcode = ((~$chrcode) & 8191);
}
$characters[] = $chrcode;
$bitmask /= 2;
}
$characters = array_reverse($characters);
// build bars
$barcode = new Barcode($code);
for ($i = 0; $i < 65; ++$i) {
$asc = (($characters[$asc_chr[$i]] & pow(2, $asc_pos[$i])) > 0);
$dsc = (($characters[$dsc_chr[$i]] & pow(2, $dsc_pos[$i])) > 0);
if ($asc AND $dsc) {
// full bar (F)
$p = 0;
$h = 3;
} elseif ($asc) {
// ascender (A)
$p = 0;
$h = 2;
} elseif ($dsc) {
// descender (D)
$p = 1;
$h = 2;
} else {
// tracker (T)
$p = 1;
$h = 1;
}
$barcode->addBar(new BarcodeBar(1, $h, true, $p));
if ($i < 64) {
$barcode->addBar(new BarcodeBar(1, 2, false, 0));
}
}
return $barcode;
}
/**
* Convert large integer number to hexadecimal representation.
* (requires PHP bcmath extension)
*
* @param $number (string) number to convert specified as a string
* @return string hexadecimal representation
*/
protected function dec_to_hex($number)
{
if ($number == 0) {
return '00';
}
$hex = [];
while ($number > 0) {
array_push($hex, strtoupper(dechex(bcmod($number, '16'))));
$number = bcdiv($number, '16', 0);
}
$hex = array_reverse($hex);
return implode($hex);
}
/**
* Intelligent Mail Barcode calculation of Frame Check Sequence
*
* @param $code_arr (string) array of hexadecimal values (13 bytes holding 102 bits right justified).
* @return int 11 bit Frame Check Sequence as integer (decimal base)
* @protected
*/
protected function imb_crc11fcs($code_arr)
{
$genpoly = 0x0F35; // generator polynomial
$fcs = 0x07FF; // Frame Check Sequence
// do most significant byte skipping the 2 most significant bits
$data = hexdec($code_arr[0]) << 5;
for ($bit = 2; $bit < 8; ++$bit) {
if (($fcs ^ $data) & 0x400) {
$fcs = ($fcs << 1) ^ $genpoly;
} else {
$fcs = ($fcs << 1);
}
$fcs &= 0x7FF;
$data <<= 1;
}
// do rest of bytes
for ($byte = 1; $byte < 13; ++$byte) {
$data = hexdec($code_arr[$byte]) << 3;
for ($bit = 0; $bit < 8; ++$bit) {
if (($fcs ^ $data) & 0x400) {
$fcs = ($fcs << 1) ^ $genpoly;
} else {
$fcs = ($fcs << 1);
}
$fcs &= 0x7FF;
$data <<= 1;
}
}
return $fcs;
}
/**
* Convert large hexadecimal number to decimal representation (string).
* (requires PHP bcmath extension)
*
* @param $hex (string) hexadecimal number to convert specified as a string
* @return string hexadecimal representation
*/
protected function hex_to_dec($hex)
{
$dec = 0;
$bitval = 1;
$len = strlen($hex);
for ($pos = ($len - 1); $pos >= 0; --$pos) {
$dec = bcadd($dec, bcmul(hexdec($hex[$pos]), $bitval));
$bitval = bcmul($bitval, 16);
}
return $dec;
}
/**
* generate Nof13 tables used for Intelligent Mail Barcode
*
* @param $n (int) is the type of table: 2 for 2of13 table, 5 for 5of13table
* @param $size (int) size of table (78 for n=2 and 1287 for n=5)
* @return array requested table
* @protected
*/
protected function imb_tables($n, $size)
{
$table = [];
$lli = 0; // LUT lower index
$lui = $size - 1; // LUT upper index
for ($count = 0; $count < 8192; ++$count) {
$bit_count = 0;
for ($bit_index = 0; $bit_index < 13; ++$bit_index) {
$bit_count += intval(($count & (1 << $bit_index)) != 0);
}
// if we don't have the right number of bits on, go on to the next value
if ($bit_count == $n) {
$reverse = ($this->imb_reverse_us($count) >> 3);
// if the reverse is less than count, we have already visited this pair before
if ($reverse >= $count) {
// If count is symmetric, place it at the first free slot from the end of the list.
// Otherwise, place it at the first free slot from the beginning of the list AND place $reverse ath the next free slot from the beginning of the list
if ($reverse == $count) {
$table[$lui] = $count;
--$lui;
} else {
$table[$lli] = $count;
++$lli;
$table[$lli] = $reverse;
++$lli;
}
}
}
}
return $table;
}
/**
* Reverse unsigned short value
*
* @param $num (int) value to reversr
* @return int reversed value
* @protected
*/
protected function imb_reverse_us($num)
{
$rev = 0;
for ($i = 0; $i < 16; ++$i) {
$rev <<= 1;
$rev |= ($num & 1);
$num >>= 1;
}
return $rev;
}
}
php-barcode-generator/src/Types/TypeCode128A.php 0000644 00000000547 15024774422 0015405 0 ustar 00 '11111221',
'1' => '11112211',
'2' => '11121121',
'3' => '22111111',
'4' => '11211211',
'5' => '21111211',
'6' => '12111121',
'7' => '12112111',
'8' => '12211111',
'9' => '21121111',
'-' => '11122111',
'$' => '11221111',
':' => '21112121',
'/' => '21211121',
'.' => '21212111',
'+' => '11222221',
'A' => '11221211',
'B' => '12121121',
'C' => '11121221',
'D' => '11122211'
];
public function getBarcodeData(string $code): Barcode
{
$barcode = new Barcode($code);
$code = 'A' . strtoupper($code) . 'A';
for ($i = 0; $i < strlen($code); ++$i) {
if (! isset($this->conversionTable[(string)$code[$i]])) {
throw new InvalidCharacterException('Char ' . $code[$i] . ' is unsupported');
}
$seq = $this->conversionTable[(string)$code[$i]];
for ($j = 0; $j < 8; ++$j) {
if (($j % 2) == 0) {
$drawBar = true;
} else {
$drawBar = false;
}
$barWidth = $seq[$j];
$barcode->addBar(new BarcodeBar($barWidth, 1, $drawBar));
}
}
return $barcode;
}
}
php-barcode-generator/src/Types/TypeCode128C.php 0000644 00000000547 15024774422 0015407 0 ustar 00 length;
$dataLength = $length - 1;
// Add zero padding in front
$code = str_pad($code, $dataLength, '0', STR_PAD_LEFT);
$checksumDigit = $this->calculateChecksumDigit($code);
if (strlen($code) == $dataLength) {
$code .= $checksumDigit;
} elseif ($checksumDigit !== intval($code[$dataLength])) {
// If length of given barcode is same as final length, barcode is including checksum
// Make sure that checksum is the same as we calculated
throw new InvalidCheckDigitException();
}
if ($this->upca || $this->upce) {
$code = '0' . $code;
++$length;
}
if ($this->upce) {
// convert UPC-A to UPC-E
$tmp = substr($code, 4, 3);
if (($tmp == '000') OR ($tmp == '100') OR ($tmp == '200')) {
// manufacturer code ends in 000, 100, or 200
$upce_code = substr($code, 2, 2) . substr($code, 9, 3) . substr($code, 4, 1);
} else {
$tmp = substr($code, 5, 2);
if ($tmp == '00') {
// manufacturer code ends in 00
$upce_code = substr($code, 2, 3) . substr($code, 10, 2) . '3';
} else {
$tmp = substr($code, 6, 1);
if ($tmp == '0') {
// manufacturer code ends in 0
$upce_code = substr($code, 2, 4) . substr($code, 11, 1) . '4';
} else {
// manufacturer code does not end in zero
$upce_code = substr($code, 2, 5) . substr($code, 11, 1);
}
}
}
}
// Convert digits to bars
$codes = [
'A' => [ // left odd parity
'0' => '0001101',
'1' => '0011001',
'2' => '0010011',
'3' => '0111101',
'4' => '0100011',
'5' => '0110001',
'6' => '0101111',
'7' => '0111011',
'8' => '0110111',
'9' => '0001011'
],
'B' => [ // left even parity
'0' => '0100111',
'1' => '0110011',
'2' => '0011011',
'3' => '0100001',
'4' => '0011101',
'5' => '0111001',
'6' => '0000101',
'7' => '0010001',
'8' => '0001001',
'9' => '0010111'
],
'C' => [ // right
'0' => '1110010',
'1' => '1100110',
'2' => '1101100',
'3' => '1000010',
'4' => '1011100',
'5' => '1001110',
'6' => '1010000',
'7' => '1000100',
'8' => '1001000',
'9' => '1110100'
]
];
$parities = [
'0' => ['A', 'A', 'A', 'A', 'A', 'A'],
'1' => ['A', 'A', 'B', 'A', 'B', 'B'],
'2' => ['A', 'A', 'B', 'B', 'A', 'B'],
'3' => ['A', 'A', 'B', 'B', 'B', 'A'],
'4' => ['A', 'B', 'A', 'A', 'B', 'B'],
'5' => ['A', 'B', 'B', 'A', 'A', 'B'],
'6' => ['A', 'B', 'B', 'B', 'A', 'A'],
'7' => ['A', 'B', 'A', 'B', 'A', 'B'],
'8' => ['A', 'B', 'A', 'B', 'B', 'A'],
'9' => ['A', 'B', 'B', 'A', 'B', 'A'],
];
$upce_parities = [
[
'0' => ['B', 'B', 'B', 'A', 'A', 'A'],
'1' => ['B', 'B', 'A', 'B', 'A', 'A'],
'2' => ['B', 'B', 'A', 'A', 'B', 'A'],
'3' => ['B', 'B', 'A', 'A', 'A', 'B'],
'4' => ['B', 'A', 'B', 'B', 'A', 'A'],
'5' => ['B', 'A', 'A', 'B', 'B', 'A'],
'6' => ['B', 'A', 'A', 'A', 'B', 'B'],
'7' => ['B', 'A', 'B', 'A', 'B', 'A'],
'8' => ['B', 'A', 'B', 'A', 'A', 'B'],
'9' => ['B', 'A', 'A', 'B', 'A', 'B'],
],
[
'0' => ['A', 'A', 'A', 'B', 'B', 'B'],
'1' => ['A', 'A', 'B', 'A', 'B', 'B'],
'2' => ['A', 'A', 'B', 'B', 'A', 'B'],
'3' => ['A', 'A', 'B', 'B', 'B', 'A'],
'4' => ['A', 'B', 'A', 'A', 'B', 'B'],
'5' => ['A', 'B', 'B', 'A', 'A', 'B'],
'6' => ['A', 'B', 'B', 'B', 'A', 'A'],
'7' => ['A', 'B', 'A', 'B', 'A', 'B'],
'8' => ['A', 'B', 'A', 'B', 'B', 'A'],
'9' => ['A', 'B', 'B', 'A', 'B', 'A'],
],
];
$seq = '101'; // left guard bar
if ($this->upce) {
$barcode = new Barcode($upce_code);
$p = $upce_parities[$code[1]][$checksumDigit];
for ($i = 0; $i < 6; ++$i) {
$seq .= $codes[$p[$i]][$upce_code[$i]];
}
$seq .= '010101'; // right guard bar
} else {
$barcode = new Barcode($code);
$half_len = intval(ceil($length / 2));
if ($length == 8) {
for ($i = 0; $i < $half_len; ++$i) {
$seq .= $codes['A'][$code[$i]];
}
} else {
$p = $parities[$code[0]];
for ($i = 1; $i < $half_len; ++$i) {
$seq .= $codes[$p[$i - 1]][$code[$i]];
}
}
$seq .= '01010'; // center guard bar
for ($i = $half_len; $i < $length; ++$i) {
if (! isset($codes['C'][$code[$i]])) {
throw new InvalidCharacterException('Char ' . $code[$i] . ' not allowed');
}
$seq .= $codes['C'][$code[$i]];
}
$seq .= '101'; // right guard bar
}
$clen = strlen($seq);
$w = 0;
for ($i = 0; $i < $clen; ++$i) {
$w += 1;
if (($i == ($clen - 1)) OR (($i < ($clen - 1)) AND ($seq[$i] != $seq[($i + 1)]))) {
if ($seq[$i] == '1') {
$t = true; // bar
} else {
$t = false; // space
}
$barcode->addBar(new BarcodeBar($w, 1, $t));
$w = 0;
}
}
return $barcode;
}
protected function calculateChecksumDigit(string $code)
{
// calculate check digit
$sum_a = 0;
for ($i = 1; $i < $this->length - 1; $i += 2) {
$sum_a += $code[$i];
}
if ($this->length > 12) {
$sum_a *= 3;
}
$sum_b = 0;
for ($i = 0; $i < $this->length - 1; $i += 2) {
$sum_b += intval(($code[$i]));
}
if ($this->length < 13) {
$sum_b *= 3;
}
$checksumDigit = ($sum_a + $sum_b) % 10;
if ($checksumDigit > 0) {
$checksumDigit = (10 - $checksumDigit);
}
return $checksumDigit;
}
}
php-barcode-generator/src/Types/TypeInterface.php 0000644 00000000234 15024774422 0016070 0 ustar 00 [2, 2, 1, 1, 1],
1 => [1, 1, 1, 2, 2],
2 => [1, 1, 2, 1, 2],
3 => [1, 1, 2, 2, 1],
4 => [1, 2, 1, 1, 2],
5 => [1, 2, 1, 2, 1],
6 => [1, 2, 2, 1, 1],
7 => [2, 1, 1, 1, 2],
8 => [2, 1, 1, 2, 1],
9 => [2, 1, 2, 1, 1]
];
public function getBarcodeData(string $code): Barcode
{
$code = str_replace(['-', ' '], '', $code);
$len = strlen($code);
$barcode = new Barcode($code);
// calculate checksum
$sum = 0;
for ($i = 0; $i < $len; ++$i) {
$sum += intval($code[$i]);
}
$chkd = ($sum % 10);
if ($chkd > 0) {
$chkd = (10 - $chkd);
}
$code .= $chkd;
$len = strlen($code);
// start bar
$barcode->addBar(new BarcodeBar(1, 2, 1));
$barcode->addBar(new BarcodeBar(1, 2, 0));
for ($i = 0; $i < $len; ++$i) {
for ($j = 0; $j < 5; ++$j) {
$h = $this->barlen[$code[$i]][$j];
$p = floor(1 / $h);
$barcode->addBar(new BarcodeBar(1, $h, 1, $p));
$barcode->addBar(new BarcodeBar(1, 2, 0));
}
}
// end bar
$barcode->addBar(new BarcodeBar(1, 2, 1));
return $barcode;
}
}
php-barcode-generator/src/BarcodeBar.php 0000644 00000001540 15024774422 0014207 0 ustar 00 width = $width;
$this->height = $height;
$this->positionVertical = $positionVertical;
$this->type = $drawBar ? self::TYPE_BAR : self::TYPE_SPACING;
}
public function getWidth(): int
{
return $this->width;
}
public function getHeight(): int
{
return $this->height;
}
public function getPositionVertical(): int
{
return $this->positionVertical;
}
public function isBar(): bool
{
return $this->type === self::TYPE_BAR;
}
} php-barcode-generator/src/BarcodeGeneratorPNG.php 0000644 00000007630 15024774422 0016004 0 ustar 00 useImagick = true;
} elseif (function_exists('imagecreate')) {
$this->useImagick = false;
} else {
throw new BarcodeException('Neither gd-lib or imagick are installed!');
}
}
/**
* Force the use of Imagick image extension
*/
public function useImagick()
{
$this->useImagick = true;
}
/**
* Force the use of the GD image library
*/
public function useGd()
{
$this->useImagick = false;
}
/**
* Return a PNG image representation of barcode (requires GD or Imagick library).
*
* @param string $barcode code to print
* @param string $type type of barcode:
* @param int $widthFactor Width of a single bar element in pixels.
* @param int $height Height of a single bar element in pixels.
* @param array $foregroundColor RGB (0-255) foreground color for bar elements (background is transparent).
* @return string image data or false in case of error.
*/
public function getBarcode($barcode, $type, int $widthFactor = 2, int $height = 30, array $foregroundColor = [0, 0, 0])
{
$barcodeData = $this->getBarcodeData($barcode, $type);
$width = round($barcodeData->getWidth() * $widthFactor);
if ($this->useImagick) {
$imagickBarsShape = new imagickdraw();
$imagickBarsShape->setFillColor(new imagickpixel('rgb(' . implode(',', $foregroundColor) . ')'));
} else {
$image = $this->createGdImageObject($width, $height);
$gdForegroundColor = imagecolorallocate($image, $foregroundColor[0], $foregroundColor[1], $foregroundColor[2]);
}
// print bars
$positionHorizontal = 0;
/** @var BarcodeBar $bar */
foreach ($barcodeData->getBars() as $bar) {
$barWidth = round(($bar->getWidth() * $widthFactor), 3);
if ($bar->isBar() && $barWidth > 0) {
$y = round(($bar->getPositionVertical() * $height / $barcodeData->getHeight()), 3);
$barHeight = round(($bar->getHeight() * $height / $barcodeData->getHeight()), 3);
// draw a vertical bar
if ($this->useImagick && isset($imagickBarsShape)) {
$imagickBarsShape->rectangle($positionHorizontal, $y, ($positionHorizontal + $barWidth - 1), ($y + $barHeight));
} else {
imagefilledrectangle($image, $positionHorizontal, $y, ($positionHorizontal + $barWidth - 1), ($y + $barHeight), $gdForegroundColor);
}
}
$positionHorizontal += $barWidth;
}
if ($this->useImagick && isset($imagickBarsShape)) {
$image = $this->createImagickImageObject($width, $height);
$image->drawImage($imagickBarsShape);
return $image->getImageBlob();
}
ob_start();
$this->generateGdImage($image);
return ob_get_clean();
}
protected function createGdImageObject(int $width, int $height)
{
$image = imagecreate($width, $height);
$colorBackground = imagecolorallocate($image, 255, 255, 255);
imagecolortransparent($image, $colorBackground);
return $image;
}
protected function createImagickImageObject(int $width, int $height): Imagick
{
$image = new Imagick();
$image->newImage($width, $height, 'none', 'PNG');
return $image;
}
protected function generateGdImage($image)
{
imagepng($image);
imagedestroy($image);
}
}
php-barcode-generator/tests/VerifiedBarcodeTest.php 0000644 00000007423 15024774422 0016461 0 ustar 00 BarcodeGenerator::TYPE_CODE_39, 'barcodes' => ['1234567890ABC']],
['type' => BarcodeGenerator::TYPE_CODE_39_CHECKSUM, 'barcodes' => ['1234567890ABC']],
['type' => BarcodeGenerator::TYPE_CODE_39E, 'barcodes' => ['1234567890abcABC']],
['type' => BarcodeGenerator::TYPE_CODE_39E_CHECKSUM, 'barcodes' => ['1234567890abcABC']],
['type' => BarcodeGenerator::TYPE_CODE_93, 'barcodes' => ['1234567890abcABC']],
['type' => BarcodeGenerator::TYPE_STANDARD_2_5, 'barcodes' => ['1234567890']],
['type' => BarcodeGenerator::TYPE_STANDARD_2_5_CHECKSUM, 'barcodes' => ['1234567890']],
['type' => BarcodeGenerator::TYPE_INTERLEAVED_2_5, 'barcodes' => ['1234567890']],
['type' => BarcodeGenerator::TYPE_INTERLEAVED_2_5_CHECKSUM, 'barcodes' => ['1234567890']],
['type' => BarcodeGenerator::TYPE_EAN_13, 'barcodes' => ['081231723897', '0049000004632', '004900000463']],
['type' => BarcodeGenerator::TYPE_CODE_128, 'barcodes' => ['081231723897', '1234567890abcABC-283*33']],
['type' => BarcodeGenerator::TYPE_CODE_128_A, 'barcodes' => ['1234567890']],
['type' => BarcodeGenerator::TYPE_CODE_128_B, 'barcodes' => ['081231723897', '1234567890abcABC-283*33']],
['type' => BarcodeGenerator::TYPE_EAN_2, 'barcodes' => ['22']],
['type' => BarcodeGenerator::TYPE_EAN_5, 'barcodes' => ['1234567890abcABC-283*33']],
['type' => BarcodeGenerator::TYPE_EAN_8, 'barcodes' => ['1234568']],
['type' => BarcodeGenerator::TYPE_UPC_A, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_UPC_E, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_MSI, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_MSI_CHECKSUM, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_POSTNET, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_PLANET, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_RMS4CC, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_KIX, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_IMB, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_CODABAR, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_CODE_11, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_PHARMA_CODE, 'barcodes' => ['123456789']],
['type' => BarcodeGenerator::TYPE_PHARMA_CODE_TWO_TRACKS, 'barcodes' => ['123456789']],
];
public function testAllSupportedBarcodeTypes()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
foreach ($this::$supportedBarcodes as $barcodeTestSet) {
foreach ($barcodeTestSet['barcodes'] as $barcode) {
$result = $generator->getBarcode($barcode, $barcodeTestSet['type']);
$this->assertStringEqualsFile(
sprintf('tests/verified-files/%s.svg', $this->getSaveFilename($barcodeTestSet['type'] . '-' . $barcode)),
$result,
sprintf('%s x %s dynamic test failed', $barcodeTestSet['type'], $barcode)
);
}
}
}
protected function getSaveFilename($value) {
return preg_replace('/[^a-zA-Z0-9_ \-+]/s', '-', $value);
}
}
php-barcode-generator/tests/GeneratorTest.php 0000644 00000005212 15024774422 0015364 0 ustar 00 expectException(Picqer\Barcode\Exceptions\InvalidLengthException::class);
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generator->getBarcode('', $generator::TYPE_EAN_13);
}
public function test_throws_exception_if_empty_barcode_is_used_in_code128()
{
$this->expectException(Picqer\Barcode\Exceptions\InvalidLengthException::class);
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generator->getBarcode('', $generator::TYPE_CODE_128);
}
public function test_ean13_generator_throws_exception_if_invalid_chars_are_used()
{
$this->expectException(Picqer\Barcode\Exceptions\InvalidCharacterException::class);
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generator->getBarcode('A123', $generator::TYPE_EAN_13);
}
public function test_ean13_generator_accepting_13_chars()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generated = $generator->getBarcode('0049000004632', $generator::TYPE_EAN_13);
$this->assertStringEqualsFile('tests/verified-files/0049000004632-ean13.svg', $generated);
}
public function test_ean13_generator_accepting_12_chars_and_generates_13th_check_digit()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generated = $generator->getBarcode('004900000463', $generator::TYPE_EAN_13);
$this->assertStringEqualsFile('tests/verified-files/0049000004632-ean13.svg', $generated);
}
public function test_ean13_generator_accepting_11_chars_and_generates_13th_check_digit_and_adds_leading_zero()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generated = $generator->getBarcode('04900000463', $generator::TYPE_EAN_13);
$this->assertStringEqualsFile('tests/verified-files/0049000004632-ean13.svg', $generated);
}
public function test_ean13_generator_throws_exception_when_wrong_check_digit_is_given()
{
$this->expectException(Picqer\Barcode\Exceptions\InvalidCheckDigitException::class);
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generator->getBarcode('0049000004633', $generator::TYPE_EAN_13);
}
public function test_generator_throws_unknown_type_exceptions()
{
$this->expectException(Picqer\Barcode\Exceptions\UnknownTypeException::class);
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$generator->getBarcode('0049000004633', 'vladimir');
}
} php-barcode-generator/tests/BarcodePngTest.php 0000644 00000010646 15024774422 0015451 0 ustar 00 useGd();
$generated = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128);
$this->assertEquals('PNG', substr($generated, 1, 3));
}
public function test_png_barcode_generator_can_generate_code_39_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
$generator->useGd();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_39, 1);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(224, $imageInfo[0]); // Image width
$this->assertEquals(30, $imageInfo[1]); // Image height
$this->assertEquals('image/png', $imageInfo['mime']);
}
public function test_png_barcode_generator_can_use_different_height()
{
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
$generator->useGd();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 2, 45);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(202, $imageInfo[0]); // Image width
$this->assertEquals(45, $imageInfo[1]); // Image height
$this->assertEquals('image/png', $imageInfo['mime']);
}
public function test_png_barcode_generator_can_use_different_width_factor()
{
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
$generator->useGd();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 5);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(505, $imageInfo[0]); // Image width
$this->assertEquals('image/png', $imageInfo['mime']);
}
// Copied as Imagick
public function test_png_barcode_generator_can_generate_code_128_barcode_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
$generator->useImagick();
$generated = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128);
$this->assertEquals('PNG', substr($generated, 1, 3));
}
public function test_png_barcode_generator_can_generate_code_39_barcode_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
$generator->useImagick();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_39, 1);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(224, $imageInfo[0]); // Image width
$this->assertEquals(30, $imageInfo[1]); // Image height
$this->assertEquals('image/png', $imageInfo['mime']);
}
public function test_png_barcode_generator_can_use_different_height_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
$generator->useImagick();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 2, 45);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(202, $imageInfo[0]); // Image width
$this->assertEquals(45, $imageInfo[1]); // Image height
$this->assertEquals('image/png', $imageInfo['mime']);
}
public function test_png_barcode_generator_can_use_different_width_factor_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
$generator->useImagick();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 5);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(505, $imageInfo[0]); // Image width
$this->assertEquals('image/png', $imageInfo['mime']);
}
}
php-barcode-generator/tests/PharmacodeTest.php 0000644 00000000564 15024774422 0015506 0 ustar 00 expectException(Picqer\Barcode\Exceptions\InvalidLengthException::class);
$pharmacode->getBarcodeData('0');
}
}
php-barcode-generator/tests/TypesTest.php 0000644 00000020671 15024774422 0014550 0 ustar 00 getBarcode('1234567890ABC', $generator::TYPE_CODE_39);
$this->assertStringEqualsFile('tests/verified-files/C39-1234567890ABC.svg', $result);
}
public function test_generator_can_generate_code_39_checksum_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890ABC', $generator::TYPE_CODE_39_CHECKSUM);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_code_39_extended_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890abcABC', $generator::TYPE_CODE_39E);
$this->assertStringEqualsFile('tests/verified-files/C39E-1234567890abcABC.svg', $result);
}
public function test_generator_can_generate_code_39_extended_checksum_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890abcABC', $generator::TYPE_CODE_39E_CHECKSUM);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_code_93_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890abcABC', $generator::TYPE_CODE_93);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_standard_2_5_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890', $generator::TYPE_STANDARD_2_5);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_standard_2_5_checksum_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890', $generator::TYPE_STANDARD_2_5_CHECKSUM);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_interleaved_2_5_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890', $generator::TYPE_INTERLEAVED_2_5);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_interleaved_2_5_checksum_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890', $generator::TYPE_INTERLEAVED_2_5_CHECKSUM);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_code_128_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890abcABC-283*33', $generator::TYPE_CODE_128);
$this->assertStringEqualsFile('tests/verified-files/C128-1234567890abcABC-283-33.svg', $result);
}
public function test_generator_can_generate_code_128_a_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890', $generator::TYPE_CODE_128_A);
$this->assertStringEqualsFile('tests/verified-files/C128A-1234567890.svg', $result);
}
public function test_generator_can_generate_code_128_b_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890abcABC-283*33', $generator::TYPE_CODE_128_B);
$this->assertStringEqualsFile('tests/verified-files/C128B-1234567890abcABC-283-33.svg', $result);
}
public function test_generator_can_generate_ean_2_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('22', $generator::TYPE_EAN_2);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_ean_5_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890abcABC-283*33', $generator::TYPE_EAN_5);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_ean_8_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234568', $generator::TYPE_EAN_8);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_ean_13_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('1234567890', $generator::TYPE_EAN_13);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_upc_a_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_UPC_A);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_upc_e_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_UPC_E);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_msi_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_MSI);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_msi_checksum_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_MSI_CHECKSUM);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_postnet_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_POSTNET);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_planet_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_PLANET);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_rms4cc_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_RMS4CC);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_kix_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_KIX);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_imb_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_IMB);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_codabar_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_CODABAR);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_code_11_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_CODE_11);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_pharma_code_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_PHARMA_CODE);
$this->assertGreaterThan(100, strlen($result));
}
public function test_generator_can_generate_pharma_code_2_tracks_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorSVG();
$result = $generator->getBarcode('123456789', $generator::TYPE_PHARMA_CODE_TWO_TRACKS);
$this->assertGreaterThan(100, strlen($result));
}
} php-barcode-generator/tests/BarcodeHtmlTest.php 0000644 00000001410 15024774422 0015616 0 ustar 00 getBarcode('081231723897', $generator::TYPE_CODE_128);
$this->assertStringEqualsFile('tests/verified-files/081231723897-code128.html', $generated);
}
public function test_html_barcode_generator_can_generate_imb_barcode_to_test_heights()
{
$generator = new Picqer\Barcode\BarcodeGeneratorHTML();
$generated = $generator->getBarcode('12345678903', $generator::TYPE_IMB);
$this->assertStringEqualsFile('tests/verified-files/12345678903-imb.html', $generated);
}
}
php-barcode-generator/tests/BarcodeJpgTest.php 0000644 00000011606 15024774422 0015442 0 ustar 00 useGd();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(202, $imageInfo[0]); // Image width
$this->assertEquals(30, $imageInfo[1]); // Image height
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
public function test_jpg_barcode_generator_can_generate_code_39_barcode()
{
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
$generator->useGd();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_39, 1);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(224, $imageInfo[0]); // Image width
$this->assertEquals(30, $imageInfo[1]); // Image height
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
public function test_jpg_barcode_generator_can_use_different_height()
{
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
$generator->useGd();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 2, 45);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(202, $imageInfo[0]); // Image width
$this->assertEquals(45, $imageInfo[1]); // Image height
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
public function test_jpg_barcode_generator_can_use_different_width_factor()
{
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
$generator->useGd();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 5);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(505, $imageInfo[0]); // Image width
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
// Copied as Imagick
public function test_jpg_barcode_generator_can_generate_code_128_barcode_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
$generator->useImagick();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(202, $imageInfo[0]); // Image width
$this->assertEquals(30, $imageInfo[1]); // Image height
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
public function test_jpg_barcode_generator_can_generate_code_39_barcode_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
$generator->useImagick();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_39, 1);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(224, $imageInfo[0]); // Image width
$this->assertEquals(30, $imageInfo[1]); // Image height
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
public function test_jpg_barcode_generator_can_use_different_height_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
$generator->useImagick();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 2, 45);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(202, $imageInfo[0]); // Image width
$this->assertEquals(45, $imageInfo[1]); // Image height
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
public function test_jpg_barcode_generator_can_use_different_width_factor_imagick()
{
if (! extension_loaded('imagick')) {
$this->markTestSkipped();
}
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
$generator->useImagick();
$result = $generator->getBarcode('081231723897', $generator::TYPE_CODE_128, 5);
$imageInfo = getimagesizefromstring($result);
$this->assertGreaterThan(100, strlen($result));
$this->assertEquals(505, $imageInfo[0]); // Image width
$this->assertEquals('image/jpeg', $imageInfo['mime']);
}
}
php-barcode-generator/tests/BarcodeSvgTest.php 0000644 00000000643 15024774422 0015460 0 ustar 00 getBarcode('081231723897', $generator::TYPE_EAN_13);
$this->assertStringEqualsFile('tests/verified-files/081231723897-ean13.svg', $generated);
}
}
php-barcode-generator/tests/BarcodeDynamicHtmlTest.php 0000644 00000001475 15024774422 0017136 0 ustar 00 getBarcode('081231723897', $generator::TYPE_CODE_128);
$this->assertStringEqualsFile('tests/verified-files/081231723897-dynamic-code128.html', $generated);
}
public function test_dynamic_html_barcode_generator_can_generate_imb_barcode_to_test_heights()
{
$generator = new Picqer\Barcode\BarcodeGeneratorDynamicHTML();
$generated = $generator->getBarcode('12345678903', $generator::TYPE_IMB);
$this->assertStringEqualsFile('tests/verified-files/12345678903-dynamic-imb.html', $generated);
}
}
php-barcode-generator/tests/verified-files/081231723897-ean13.svg 0000644 00000003260 15024774422 0017653 0 ustar 00
php-barcode-generator/tests/verified-files/C39E+-1234567890abcABC.svg 0000644 00000012552 15024774422 0020274 0 ustar 00
php-barcode-generator/tests/verified-files/12345678903-dynamic-imb.html 0000644 00000017465 15024774422 0021233 0 ustar 00
php-barcode-generator/tests/verified-files/POSTNET-123456789.svg 0000644 00000005313 15024774422 0017653 0 ustar 00
php-barcode-generator/tests/verified-files/UPCE-123456789.svg 0000644 00000002106 15024774422 0017250 0 ustar 00
php-barcode-generator/tests/verified-files/EAN13-004900000463.svg 0000644 00000003261 15024774422 0017463 0 ustar 00
php-barcode-generator/tests/verified-files/C128B-081231723897.svg 0000644 00000004642 15024774422 0017470 0 ustar 00
php-barcode-generator/tests/verified-files/I25+-1234567890.svg 0000644 00000003554 15024774422 0017216 0 ustar 00
php-barcode-generator/tests/verified-files/I25-1234567890.svg 0000644 00000003177 15024774422 0017144 0 ustar 00
php-barcode-generator/tests/verified-files/EAN8-1234568.svg 0000644 00000002464 15024774422 0017036 0 ustar 00
php-barcode-generator/tests/verified-files/C128B-1234567890abcABC-283-33.svg 0000644 00000007674 15024774422 0021043 0 ustar 00
php-barcode-generator/tests/verified-files/EAN13-081231723897.svg 0000644 00000003260 15024774422 0017513 0 ustar 00
php-barcode-generator/tests/verified-files/MSI-123456789.svg 0000644 00000004123 15024774422 0017145 0 ustar 00
php-barcode-generator/tests/verified-files/C39-1234567890ABC.svg 0000644 00000007366 15024774422 0017455 0 ustar 00
php-barcode-generator/tests/verified-files/PLANET-123456789.svg 0000644 00000005301 15024774422 0017477 0 ustar 00
php-barcode-generator/tests/verified-files/KIX-123456789.svg 0000644 00000003717 15024774422 0017160 0 ustar 00
php-barcode-generator/tests/verified-files/RMS4CC-123456789.svg 0000644 00000004353 15024774422 0017455 0 ustar 00
php-barcode-generator/tests/verified-files/0049000004632-ean13.svg 0000644 00000003261 15024774422 0017705 0 ustar 00
php-barcode-generator/tests/verified-files/S25+-1234567890.svg 0000644 00000006136 15024774422 0017227 0 ustar 00
php-barcode-generator/tests/verified-files/CODABAR-123456789.svg 0000644 00000004473 15024774422 0017560 0 ustar 00
php-barcode-generator/tests/verified-files/C93-1234567890abcABC.svg 0000644 00000007021 15024774422 0020107 0 ustar 00
php-barcode-generator/tests/verified-files/S25-1234567890.svg 0000644 00000005562 15024774422 0017156 0 ustar 00
php-barcode-generator/tests/verified-files/IMB-123456789.svg 0000644 00000006456 15024774422 0017137 0 ustar 00
php-barcode-generator/Readme.md 0000644 00000011450 15024774422 0012443 0 ustar 00 # PHP Barcode Generator
[](https://travis-ci.org/picqer/php-barcode-generator) [](https://travis-ci.org/picqer/php-barcode-generator) [](https://packagist.org/packages/picqer/php-barcode-generator)
This is an easy to use, non-bloated, framework independent, barcode generator in PHP.
It creates SVG, PNG, JPG and HTML images, from the most used 1D barcode standards.
*The codebase is based on the [TCPDF barcode generator](https://github.com/tecnickcom/TCPDF) by Nicola Asuni. This code is therefor licensed under LGPLv3.*
## No support for...
- No support for any **2D** barcodes, like QR codes.
- We only generate the 'bars' part of a barcode, without text below the barcode. If you want text of the code below the barcode, you could add it later to the output of this package.
## Installation
Install through [composer](https://getcomposer.org/doc/00-intro.md):
```
composer require picqer/php-barcode-generator
```
If you want to generate PNG or JPG images, you need the GD library or Imagick installed on your system as well.
## Usage
Initiate the barcode generator for the output you want, then call the ->getBarcode() routine as many times as you want.
```php
getBarcode('081231723897', $generator::TYPE_CODE_128);
```
The `getBarcode()` method accepts the following parameters:
- `$barcode` String needed to encode in the barcode
- `$type` Type of barcode, use the constants defined in the class
- `$widthFactor` Width is based on the length of the data, with this factor you can make the barcode bars wider than default
- `$height` The total height of the barcode in pixels
- `$foregroundColor` Hex code as string, or array of RGB, of the colors of the bars (the foreground color)
Example of usage of all parameters:
```php
getBarcode('081231723897', $generator::TYPE_CODE_128, 3, 50, $redColor));
```
## Image types
```php
$generatorSVG = new Picqer\Barcode\BarcodeGeneratorSVG(); // Vector based SVG
$generatorPNG = new Picqer\Barcode\BarcodeGeneratorPNG(); // Pixel based PNG
$generatorJPG = new Picqer\Barcode\BarcodeGeneratorJPG(); // Pixel based JPG
$generatorHTML = new Picqer\Barcode\BarcodeGeneratorHTML(); // Pixel based HTML
$generatorHTML = new Picqer\Barcode\BarcodeGeneratorDynamicHTML(); // Vector based HTML
```
## Accepted barcode types
These barcode types are supported. All types support different character sets or have mandatory lengths. Please see wikipedia for supported chars and lengths per type.
Most used types are TYPE_CODE_128 and TYPE_CODE_39. Because of the best scanner support, variable length and most chars supported.
- TYPE_CODE_32 (italian pharmaceutical code 'MINSAN')
- TYPE_CODE_39
- TYPE_CODE_39_CHECKSUM
- TYPE_CODE_39E
- TYPE_CODE_39E_CHECKSUM
- TYPE_CODE_93
- TYPE_STANDARD_2_5
- TYPE_STANDARD_2_5_CHECKSUM
- TYPE_INTERLEAVED_2_5
- TYPE_INTERLEAVED_2_5_CHECKSUM
- TYPE_CODE_128
- TYPE_CODE_128_A
- TYPE_CODE_128_B
- TYPE_CODE_128_C
- TYPE_EAN_2
- TYPE_EAN_5
- TYPE_EAN_8
- TYPE_EAN_13
- TYPE_UPC_A
- TYPE_UPC_E
- TYPE_MSI
- TYPE_MSI_CHECKSUM
- TYPE_POSTNET
- TYPE_PLANET
- TYPE_RMS4CC
- TYPE_KIX
- TYPE_IMB
- TYPE_CODABAR
- TYPE_CODE_11
- TYPE_PHARMA_CODE
- TYPE_PHARMA_CODE_TWO_TRACKS
[See example images for all supported barcode types](examples.md)
## A note about PNG and JPG images
If you want to use PNG or JPG images, you need to install [Imagick](https://www.php.net/manual/en/intro.imagick.php) or the [GD library](https://www.php.net/manual/en/intro.image.php). This package will use Imagick if that is installed, or fall back to GD. If you have both installed but you want a specific method, you can use `$generator->useGd()` or `$generator->useImagick()` to force your preference.
## Examples
### Embedded PNG image in HTML
```php
$generator = new Picqer\Barcode\BarcodeGeneratorPNG();
echo '';
```
### Save JPG barcode to disk
```php
$generator = new Picqer\Barcode\BarcodeGeneratorJPG();
file_put_contents('barcode.jpg', $generator->getBarcode('081231723897', $generator::TYPE_CODABAR));
```
### Oneliner SVG output to disk
```php
file_put_contents('barcode.svg', (new Picqer\Barcode\BarcodeGeneratorSVG())->getBarcode('6825ME601', Picqer\Barcode\BarcodeGeneratorSVG::TYPE_KIX));
```
php-barcode-generator/generate-verified-files.php 0000644 00000003335 15024774422 0016125 0 ustar 00 getBarcode('081231723897', $generatorSVG::TYPE_EAN_13));
$generatorHTML = new Picqer\Barcode\BarcodeGeneratorHTML();
file_put_contents('tests/verified-files/081231723897-code128.html', $generatorHTML->getBarcode('081231723897', $generatorHTML::TYPE_CODE_128));
file_put_contents('tests/verified-files/12345678903-imb.html', $generatorHTML->getBarcode('12345678903', $generatorHTML::TYPE_IMB));
$generatorDynamicHTML = new Picqer\Barcode\BarcodeGeneratorDynamicHTML();
file_put_contents('tests/verified-files/081231723897-dynamic-code128.html', $generatorDynamicHTML->getBarcode('081231723897', $generatorDynamicHTML::TYPE_CODE_128));
file_put_contents('tests/verified-files/12345678903-dynamic-imb.html', $generatorDynamicHTML->getBarcode('12345678903', $generatorDynamicHTML::TYPE_IMB));
$generatorSVG = new Picqer\Barcode\BarcodeGeneratorSVG();
file_put_contents('tests/verified-files/0049000004632-ean13.svg', $generatorSVG->getBarcode('0049000004632', $generatorSVG::TYPE_EAN_13));
// New style of verified files
require(__DIR__ . '/tests/VerifiedBarcodeTest.php');
$verifiedFiles = VerifiedBarcodeTest::$supportedBarcodes;
$generatorSVG = new Picqer\Barcode\BarcodeGeneratorSVG();
foreach ($verifiedFiles as $verifiedFile) {
foreach ($verifiedFile['barcodes'] as $barcode) {
file_put_contents('tests/verified-files/' . getSaveFilename($verifiedFile['type'] . '-' . $barcode) . '.svg', $generatorSVG->getBarcode($barcode, $verifiedFile['type']));
}
}
php-barcode-generator/.github/FUNDING.yml 0000644 00000000025 15024774422 0014075 0 ustar 00 github: casperbakker
php-barcode-generator/.github/workflows/phpunit.yml 0000644 00000001126 15024774422 0016532 0 ustar 00 name: phpunit
on: [push, pull_request]
jobs:
build:
runs-on: ubuntu-latest
strategy:
matrix:
php-versions: ['7.3', '7.4', '8.0', '8.1']
steps:
- uses: actions/checkout@v2
- name: Setup PHP
uses: shivammathur/setup-php@v2
with:
php-version: ${{ matrix.php-versions }}
extensions: mbstring, gd, bcmath, imagick
- name: Validate composer.json
run: composer validate
- name: Install dependencies
run: composer install --prefer-dist --no-progress
- name: Run test suite
run: composer run-script test
php-barcode-generator/generate-examples.php 0000644 00000001563 15024774422 0015047 0 ustar 00
./tests/./src