NAME
Barcode::Code128 - Generate CODE 128 bar codes
SYNOPSIS
use Barcode::Code128;
$code = new Barcode::Code128;
REQUIRES
Perl 5.004, Carp, Exporter, GD
EXPORTS
By default, nothing. However there are a number of constants that represent special characters used in the CODE 128 symbology that you may wish to include. For example if you are using the EAN-128 or UCC-128 code, the string to encode begins with the FNC1 character. To encode the EAN-128 string "00 0 0012345 555555555 8", you would do the following:
use Barcode::Code128 'FNC1';
$code = new Barcode::Code128;
$code->text(FNC1.'00000123455555555558');
To have this module export one or more of these characters, specify them on the use
statement or use the special token ':all' instead to include all of them. Examples:
use Barcode::Code128 qw(FNC1 FNC2 FNC3 FNC4 Shift);
use Barcode::Code128 qw(:all);
Here is the complete list of the exportable characters. They are assigned to high-order ASCII characters purely arbitrarily for the purposes of this module; the values used do not reflect any part of the CODE 128 standard. Warning: Using the CodeA
, CodeB
, CodeC
, StartA
, StartB
, StartC
, and Stop
codes may cause your barcodes to be invalid, and be rejected by scanners. They are inserted automatically as needed by this module.
CodeA 0xf4 CodeB 0xf5 CodeC 0xf6
FNC1 0xf7 FNC2 0xf8 FNC3 0xf9
FNC4 0xfa Shift 0xfb StartA 0xfc
StartB 0xfd StartC 0xfe Stop 0xff
DESCRIPTION
Barcode::Code128 generates bar codes using the CODE 128 symbology. The typical use this is for generating a PNG file with the png()
method which uses the GD package by Lincoln Stein. When this PNG file is printed, it can be scanned by most modern hand-held bar code readers. The application which drove the invention of this module places the PNG file on a web page which the user must print out and submit along with supporting documents. The bar code helps the receiving agency record when it has been received.
Since the GD module is required you will need to install it before installing this module. You can obtain it from the CPAN (Comprehensive Perl Archive Network) repository of your choice under the directory authors/id/LDS
. Visit http://www.perl.com/ for more information about CPAN. The GD home page is: http://stein.cshl.org/WWW/software/GD/GD.html
METHODS
- $object = new Barcode::Code128
-
Creates a new barcode object.
- $object->png($text)
- $object->png($text, $x, $y)
-
Generate a PNG file and return it. Typically you will either print the result to standard output or save it to a file. The contents of the return value from this method are a binary file, so if you are working on an operating system that makes a distinction between text and binary files be sure to call binmode(FILEHANDLE) before writing the PNG to it. Example:
open(PNG, ">code128.png") or die "Can't write code128.png: $!\n"; binmode(PNG); print PNG $object->png("CODE 128"); close(PNG);
Note: All of the arguments to this function are optional. If you have previously specified
$text
to thebarcode()
,encode()
, ortext()
methods, you do not need to specify it again. The$x
and$y
variables specify the size of the barcode within PNG file in pixels. The overall image will be an extra 20 pixels taller to accomodate the plaintext rendering of the encoded message (in black on a transparent background). If size(s) are not specified, they will be set to the minimum size, which is the length of the barcode plus 40 pixels horizontally, and 15% of the length of the barcode vertically. - $object->barcode($text)
-
Computes the bar code for the specified text. The result will be a string of '#' and space characters representing the dark and light bands of the bar code. You can use this if you have an alternate printing system besides the
png()
method.Note: The
$text
parameter is optional. If you have previously specified$text
to theencode()
ortext()
methods, you do not need to specify it again.
Housekeeping Functions
The rest of the methods defined here are only for internal use, or if you really know what you are doing. Some of them may be useful to authors of classes that inherit from this one, or may be overridden by subclasses. If you just want to use this module to generate bar codes, you can stop reading here.
- $object->encode
- $object->encode($text)
-
Do the encoding. If
$text
is supplied, will automatically call the text() method to set that as the text value first. - $object->text($text)
- $text = $object->text
-
Set or retrieve the text for this barcode. This will be called automatically by encode() or barcode() so typically this will not be used directly by the user.
- $object->start($code)
-
If the code (see code()) is already defined, then adds the CodeA, CodeB, or CodeC character as appropriate to the encoded message inside the object. Typically for internal use only.
- $object->stop()
-
Computes the check character and appends it along with the Stop character, to the encoded string. Typically for internal use only.
- $object->code($code)
- $code = $object->code
-
Set or retrieve the code for this barcode.
$code
may be 'A', 'B', or 'C'. Typically for internal use only. Not particularly meaningful unless called during the middle of encoding.
CLASS VARIABLES
None.
DIAGNOSTICS
- Image width $x is too small for bar code
-
You have specified an image width that does not allow enough space for the bar code to be displayed. The minimum allowable is the size of the bar code itself plus 40 pixels. If in doubt, just omit the width value when calling
png()
and it will use the minimum. - Image height $y is too small for bar code
-
You have specified an image height that does not allow enough space for the bar code to be displayed. The minimum allowable is 15% of the width of the bar code. If in doubt, just omit the height value when calling
png()
and it will use the minimum. - Unable to create $x x $y PNG image
-
An error occurred when initializing a GD::Image object for the specified size. Perhaps
$x
and$y
are too large for memory? - No encoded text found
-
This message from
barcode()
typically means that there was no text message supplied either during the current method call or in a previous method call on the same object. - No text defined
-
This message from
encode()
typically means that there was no text message supplied either during the current method call or in a previous method call on the same object. - Unable to find encoding for ``$text''
-
Part or all of the message could not be encoded. This may mean that the message contained characters not encodable in the CODE 128 character set, such as a character with an ASCII value higher than 127 (except the special control characters defined in this module).
- Sanity Check Overflow
-
This is a serious error in
encode()
that indicates a serious problem attempting to encode the requested message. This means that an infinite loop was generated. If you get this error please contact the author. - Unable to switch from ``$old_code'' to ``$new_code''
-
This is a serious error in
start()
that indicates a serious problem occurred when switching between the codes (A, B, or C) of CODE 128. If you get this error please contact the author. - Unable to start with ``$new_code''
-
This is a serious error in
start()
that indicates a serious problem occurred when starting encoding in one of the codes (A, B, or C) of CODE 128. If you get this error please contact the author. - Unknown code ``$new_code'' (should be A, B, or C)
-
This is a serious error in
code()
that indicates an invalid argument was supplied. Only the codes (A, B, or C) of CODE 128 may be supplied here. If you get this error please contact the author.
BUGS
At least some Web browsers do not seem to handle PNG files with transparent backgrounds correctly. As a result your barcodes may have a grey background behind the text version of the message.
AUTHOR
William R. Ward, wrw@bayview.com
SEE ALSO
perl(1), GD