Skip to main content

bx:barcode

Mit dem Tag barcode können verschiedene 1D und 2D-Codes erzeugt werden (Beispiele siehe unten). Ein Check auf Fehler ist mit bx:if möglich. Die Größe ist frei wählbar. Das erzeugte Format ist PNG (ggf. mit Transparenz)

Allgemeine Syntax

<bx:barcode.qr width="250" height="250" [type="path"] [rotate="90"]> Inhalt </bx:barcode.qr>

Parameter für alle Typen

width und height gebenGeben die Größe des Barcodes aneinan.
Ein weißer Rand ist teilweise automatisch enthalten und kann bei manchen Typen auch beeinflusst werdenwerden.
type image: (Standard) es wird ein img-Tag erzeugt, Parameter wie style oder class im Barcode-Tag werden in das img-Tag übernommenbernommen.
path: es wird nur der Pfad zum Bild ab "/" zurückgegeben (ohne Host, falls Haupthost-Haken im Projekt nicht gesetzt wurde).
url: es wird eine komplette URL zum Bild zurückgegeben (aufgerufener Host oder Projekt-Haupthost).
rotate positivePositive Werte drehen das erzeugte Bild im Uhrzeigersinn, negative Werte entgegen (in Grad, z.B. 90)die.
Die Größe des erzeugten Bildes wird neu berechnet, um den rotierten Barcode unterzubringen (Hintergrund ggf. transparent).

Es ist generell empfehlenswert einen minimalen Kontrast-Rand (z.B. in weiß) zu setzen, damit Barcodeleser den Code einfacher identifizieren können.

Es kann weitere Einschränkungen, je nach offizieller Spezifikation des jeweiligen Barcode-Types, geben, die hier nicht extra aufgeführt sind.Die Ausgabegröße des Barcode-Bilds musst nicht exakt der angegebenen `width` / `height` entsprechen (liegt aber zumindest nicht darüber). Falls eine pixelgenaue Ausgabe benötigt wird, sollte ein Container um das Bild gepackt werden.

Typ-spezifische Informationen

Die gezeigten Beispiele müssen nicht unbedingt den Anforderungen des jeweiligen Standards entsprechen! Es können also auch potentiell invalide Barcodes entstehen. Es ist die Spezifikation des jeweiligen Types zu Rate zu ziehen!

1-Dimensionale Codes

Bei allen 1-dimensionalen Codes kann der parameter margin verwendet werden. Dieser legt die Größe des Randes links und rechts fest (0 für keinen Rand, Standard ist 10).

Typ
Ausgabe
Einschränkungen
<bx:barcode.codabar> image2015-11-27 9:48:1.png"12345" beginntBeginnt und endet mit einem Guard-Zeichen aus: ABCD.
ODER beginnt und endet mit einem Guard-Zeichen aus: TN*Efalls.
Falls keine Guards gesetzt sind, wird automatisch A genommenenthägenommen.
Enthält nur Zeichen aus: 0123456789-$:/.+
<bx:barcode.code_39> image2015-11-27 9:54:42.png"BATIX" maximal 80 Zeichen aus: 0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. *$/+%
<bx:barcode.code_93> image2015-11-27 10:23:18.png"BATIX" maximal 80 Zeichen aus: 0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ-. $/+%abcd*
<bx:barcode.code_128> image2015-11-27 10:26:21.png"BATIX" maximal 80 Zeichen
<bx:barcode.itf>
(Interleaved Two of Five)
image2015-11-27 10:32:32.png"123456" wenigerWeniger als 80 Ziffern, gerade AnzahlamAnzahl
Am besten 6, 10, 12, 14, 16, 24, oder 44 Ziffern
<bx:barcode.ean_8> image2015-11-27 10:34:44.png"12345678" genau 8 Ziffern
<bx:barcode.ean_13> image2015-11-27 10:36:37.png"1234567891118" genau 13 ZiffernPrüZiffern
Prüfziffer muss stimmen
<bx:barcode.upc_a> image2015-11-27 10:40:2.png"12345678910" genau 11 Ziffern (ohne Prüfziffer, wird automatisch berechnet)
ODER genau 12 Ziffern (mit Prüfziffer)
<bx:barcode.upc_e> image2015-11-27 10:43:3.png"12345678" genau 8 Ziffern

2-Dimensionale Codes

<bx:barcode.qr>

Ausgabe

image2015-11-27 9:45:35.png
"http://batix.de"

Parameter

ecl
gibt das ErrorCorrectionLevel an:

  • L ~7% (Standard)
  • M ~15%
  • Q ~25%
  • H ~30%
Einschränkungen

Die Länge des verschlüsselten Strings kann die Ausgabe beeinflussen.


<bx:barcode.datamatrix>

Ausgabe

image2015-11-27 11:45:10.png image2015-11-27 11:50:45.png "http:/batix.de" (rechts mit shape=square)
image2015-11-27 11:47:0.png image2015-11-27 11:50:0.png "Lorem ipsum dolor sit amet" (rechts mit shape=rectangle)

Parameter

shape

  • none (Standard, wird automatisch je nach Inhalt gewählt)
  • square (Quadrat erzwingen)
  • rectangle (Rechteck erzwingen)

<bx:barcode.aztec>

Ausgabe

image2015-11-27 12:35:47.png
"http://batix.de"

Parameter

ecl
gibt das ErrorCorrectionLevel an (in %, (0 - 100)), 25 sollte Minimum sein.

layers
gibt die Anzahl der Aztec-Layer an

  • 0 (Standard): Minimum benutzen
  • -1, -2, -3, -4: kompakter Modus
  • 1 - 32: selbst angeben (nicht-kompakter Modus)

charset
gibt den Zeichensatz an, der zur Codierung des Inhaltes verwendet werden soll.
Standard ist utf-8.


<bx:barcode.pdf_417>

Ausgabe

image2015-11-27 12:50:36.png
"BATIX"

Parameter

margin
legt die Größe des Randes rundherum fest

ecl
gibt das ErrorCorrectionLevel an.
0 - 8, Standard ist 2.

charset
gibt den Zeichensatz an, der zur Codierung des Inhaltes verwendet werden soll.
Standard ist utf-8.

compact
kompakten Modus benutzen? true oder false.
Standard ist false.

compaction
welcher Verdichtungsmodus benutzt werden soll.

  • auto (Standard)
  • text
  • byte
  • numeric

dimensions

  • minimale und maximale Spalten- (Cols) und Zeilenanzahl (Rows)
  • kommagetrennte Zahlen
  • Reihenfolge: minCols,maxCols,minRows,maxRows
  • Standard: 2,30,2,30

Fehlerabfrage

<bx:if><bx:barcode.ean_8>1234</bx:barcode.ean_8><bx:if.else>Es konnte leider kein Barcode erzeugt werden!</bx:if.else></bx:if>

Da bx:barcode im Fehlerfall nichts ausgibt, kann ein alternativer Text mittels bx:if ausgegeben werden.

Beispiele

Beispiel Titel

<bx:barcode.qr>Hallo</bx:barcode.qr>
 
<bx:barcode.datamatrix shape="rectangle">Hallo</bx:barcode.datamatrix>