Professional Documents
Culture Documents
Foxbarcode
Foxbarcode
CodePlex Project Hosting for Open Source Software Register Sign In Search all projects
HOME S OURCE CODE DOWNLOADS DOCUMENTATION DIS CUS S IONS IS S UES PEOPLE LICENS E
FoxBarcode downloads
FoxBarcode is a 100% Visual FoxPro class that provides a tool for generating images with different bar code
A CT IV IT Y
symbologies to be used in VFP forms and reports, or exported to other applications.
(*) VFPEncoding are Guillermo Carrero (RIP) (Barcelona, Spain) and Luis Maria Guayan (Tucuman, 6983 2505 1039
Argentina)
Days: 7 30 All Details
FoxBarcode FAQs
Features
FoxBarcode supports the following barcode symbologies: Code 128 (Auto, A, B and C), Code 39, Code 39
Extended (Full ASCII), Code 93, Code 93 Extended (Full ASCII), Standard 2 of 5, Interleaved 2 of 5, EAN-8, EAN-
13, UPC-A, UPC-E (EAN and UPC with 2/5 digits supplements), ITF-14, GS1/UCC/EAN-128, Codabar, Code 11,
MSI / Plessey, PostNet, MS4SCC, KIX-Code, Telepen, One Track Pharmacode and Two Track
Pharmacode. Now supports QR Code with its supplement FoxBarcodeQR.
FoxBarcode supports the following image types: JPG, BMP, GIF, PNG and TIFF
FoxBarcode is compatible with all versions of Visual FoxPro from version 6.0
Properties
FoxBarcode allows greater control over the generation of bar code image to be able to customize the following
properties:
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 1/12
5/19/2014 VFPX - Home
nImageWidth: Width in pixels of the image. Now can set the property
nAlignBarcode: Allows to align the barcode on the left, center or right of the image.
nResolution: Image resolution in DPI.
nRotation: Rotate the image. (0 = 0°, 1 = 90°, 2 = 180°, 3 = 270°)
cImageType: Type of the generated image ("JPG", "GIF" "PNG", "BMP", "TIF")
cImageFile: Name the image file generated. If not specified, it generates a random file name in the
folder Windows temporary files.
cText: Text encoding.
nAlignText: Alignment of human-readable text. (0 = Left, 1 = center, 2 = Right)
lShowHumanReadableText: .T. whether to display the human-readable.
lShowCheckDigit: .T. whether to display the check digit on the human-readable.
lShowStartStopChars: .T. if it shows the start and end characters in human-readable.
cFontName: Name of the source of human-readable.
lFontBold: .T. if the source of human-readable is Bold.
lFontItalic: .T. if the source of human-readable is Italic.
nFontSize: Font size of the human-readable. (Recommended = 8 or 9)
nFontColor: Color of the human-readable source. (Recommended = Black = RGB (0,0,0)).
nBackColor: The background color of the image (Recommended = White = RGB (255,255,255)).
nBarsColor: Color of the bars (Recommended = Black = RGB (0,0,0)).
nBarcodeType: Type bar code symbology. See the list of supported barcodes and ID
cSet128: Set of Code 128. ("A", "B", "C" and AUTO with "*" chararacter)
cSupplementalText: Supplementary Text EAN and UPC codes.
lAddCheckDigit: .T. if you calculate the check digit. In symbols, where the check digit is mandatory,
not taking into account this property.
nBearerBar: supporting frame type, only in the ITF-14 symbology. (0 = None, 1 = Rectangle, 2 = Top
& Bottom)
lUseAppId: .T. FoxBarcode interpreter to code to GS1/UCC/EAN-128 Application Identifiers (enclosed
in parentheses)
nFactor: Magnification factor of the bar code. (1 .. 9)
nMargin: Margin around the barcode
nRatio: Relationship between the narrow bars and wide bars in the symbols that allow it.
lDeleteTempFiles: Lets choose if delete or not the temporary folder and image files.
Methods
For the generation of the image, only one method should be called that generates the bar code image and
returns the path and file name generated:
Now with the BarcodeTest() method we can validate the text to be encoded without the need to generate the
image of the barcode:
All parameters are optional, and are the same as the BarcodeImage() method.
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 2/12
5/19/2014 VFPX - Home
cFileNameImage: As an image is not generated, this parameter is an empty string.
cPropertyList: The third parameter to set all the properties in a single line, separated by
commas.
Languages
With the help of the Community VFP translated FoxBarcode messages the following languages:
ENGLISH
SPANISH by VFPEncoding
CZECH by Martin Krivka
DUTCH by Koen Piller
GERMAN by Stefan Wuebbe
INDONESIAN by Samir H.
PORTUGUESE by Cesar Ch.
TURKISH by Ugur Yilmaz
FILIPINO by Glenn Gevero
FRENCH by Samir H.
SERBIAN by Michael Kopljan
ITALIAN by Roberto Saccomanno
You just have to define compiler directive FBC_LANGUAGE with the desired language in the file FoxBarcode.prg.
You can add more languages translating messages in their native language and send email to:
vfpencoding@gmail.com
Examples
The following is an example of code to generate an image type PNG barcode Code 128 C with a height of 100
pixels and a magnification factor 2
The new third parameter to the BarcodeImage() method, which allows you to configure the various properties,
separated by commas. The same example as above, with this new way.
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 3/12
5/19/2014 VFPX - Home
To include a barcode on a form, you must insert an Image object. As the bar code image does not exist at design
time, the Picture property takes the name of the image when calling the BarcodeImage() method, for example
from the Refresh method of form, as shown in the figure below:
To include a barcode on a report, you must insert an Image object and set the property with a call ControlSource
BarcodeImage() method and is recommended to set "contents Scale, Retain shape" if the image size differs from
the frame.
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 4/12
5/19/2014 VFPX - Home
Important: Before you run the report and create the object FoxBarcode, you must declare the variable as
PRIVATE so that it has scope in the report, as follows:
PRIVATE poFbc
poFbc = CREATEOBJECT("FoxBarcode)
...
REPORT FORM MyReport
Distribution
The only files needed to be distributed to FoxBarcode function properly are:
FoxBarcode.prg
gpImage2.prg
These files are located in the Source folder included in the download file.
Before instantiating the class FoxBarcode, you must run the following statements:
Demo Form
With the download of FoxBarcode is a sample form, from which we can generate bar codes to our needs, and a
builder of code, from which we can copy the generated code to the clipboard ready for pasting into your
application.
At the top of the form there are three tabs from which all properties are configured class FoxBarcode.
From the tab "Barcode properties" you enter the text to encode, the kind of symbolism and if FoxBarcode
calculates the check digit. The dimensions of the image of the bar code to configure: the magnification factor, the
around margin barcode, the height of the image, and the ratio of narrow and wide bar (in the symbols that allow
for such variation) . The rotation of the bar code is also set from this tab, as well as some special properties of
certain symbols.
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 5/12
5/19/2014 VFPX - Home
When we go through the list of symbols, is a brief description of the selected symbols, valid characters and their
more common.
On the tab "Human-readable properties" to configure the human-readable text, whether it will be shown,
whether to display the check digit and if it shows the characters of Start and End of the symbols. The font,
justification, the size and color are set in this tab.
The tab "Image and colors" shows us the full name of the image file, this property can be passed as parameter
or FoxBarcode class generates a random file name. Here we set the image type, resolution (DPI), the background
color and the color of the bars.
Once you've set the properties, you can click on the button "Script Builder" and FoxBarcode automatically
generates the necessary code to cut and paste in your application.
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 6/12
5/19/2014 VFPX - Home
Acknowledgements
To our families.
To Cesar Ch. for your continued ideas and collaborations with their classes gpImage2 and
FoxyPreviewer.
CO MME NT S
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 7/12
5/19/2014 VFPX - Home
Reakal, in the next version of FoxBarcode (v.1.12) will be released in September, you can select the Code 128
"Auto", which automatically decreases the number of bars. I'm just missing some tests and upload it to VFPX.
The EAN-128 is formed over shrinking automatically. No Code 128 standard so it only has the types A, B and C.
The EAN-128 is "shrinking" including the FNC1 character which is not accepted in the Code 128 standard.
The nImageWidth property is set once generated the pattern according to the magnification factor and margin.
Can not set in advance.
Luis Maria
THIS.loFBC = CREATEOBJECT("FoxBarcode")
WITH THIS.loFBC
.nBarCodeType = 159
.cSet128 = "B"
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 8/12
5/19/2014 VFPX - Home
.nFactor = 2
.nImageHeight = 220
.nImageWidth = 500
.lShowHumanReadableText = .T.
ENDWITH
Unfortunately not in the near future, as Guillermo is working on another project and I am overworked.
Luis Maria
Ex:
goFbc.BarcodeImage("1234567890",,[cSet128 = "C", nBarcodeType = 110, nImageHeight = 34, nFactor = 1,
lShowHumanReadableText = .F.])
Thanks.
A suggestion: you could let the user specify the width of the generated image so we could get, for exemple,
200 pixel width barcode image no matther the actual length of the barcode.
Thanks.
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 9/12
5/19/2014 VFPX - Home
The online scan readers show the barcode in upper case. It must be my scanner. Thank you very much.
Fred Krampe
PRIVATE poFbc
poFbc = CREATEOBJECT("FoxBarCode")
poFbc.cImageType = "PNG"
poFbc.nBarcodeType = 110
poFbc.cSet128 = "B"
poFBC.nImageHeight=200
poFbc.nFactor = 3
lcImage = poFbc.BarcodeImage(upper(alltrim(Labels.Part)))
COPY FILE (lcImage) TO (JUSTFNAME(lcImage))
I copy the image file generated in the current directory and scan the image with the following online scanners:
. http://www.onlinebarcodereader.com
. http://zxing.org/w/decode.jspx
In all cases the reading is in uppercase. I think you scanner is configured to return the read string to
lowercase. Please check this.
But, I have a problem with Code 128 B. It only seems to generate lowercase text. That is, my TextToEncode is
in uppercase, and the human readable is in uppercase, but when I actually print and scan it, the result is lower
case. My code is:
===================================================
SET PROCEDURE TO LOCFILE("foxBarcode.PRG"),LOCFILE("gpImage2.prg") additive
PRIVATE poFbc
poFbc = CREATEOBJECT("FoxBarCode")
poFbc.cImageType = "PNG"
poFbc.nBarcodeType = 110
poFbc.cSet128 = "B"
poFBC.nImageHeight=203
poFBC.nResolution = 203
poFbc.nFactor = 3
poFbc.nmargin = 1
Any ideas?
Thanks,
Fred
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 10/12
5/19/2014 VFPX - Home
To you I need to create in your form the oFBC property and the clause where you create the instance of the
FoxBarcode class with CREATEOBJETC()
Ex:
ThisForm.oFBC = CREATEOBJECT("FoxBarcode")
What version of "FoxBarcode" are you using? That error was corrected in version 0.12 and was improved in
version 0.13 (the current version is 0.14)
I'm using FoxBarcode 0.14 with VFP9 SP2 and Windows 7 64 bits without problems.
If even with the 0.14 version the problem continues, find the array "laListFontName" in "FoxBarcode.PRG" file
and try changing some of the 10 names of fonts for the names of fonts you have installed on your Windows.
Ej:
laListFontName(1) = "Calibri" && Old name = "Courier New"
Best Regards
Francis (French MVP VFP)
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 11/12
5/19/2014 VFPX - Home
© 2006-2014 Microsoft Get Help Privacy Statement Terms of Use Code of Conduct Advertise With Us Version 5.6.2014.20907
https://vfpx.codeplex.com/wikipage?title=FoxBarcode 12/12