最全zpl语⾔指令解析(含乱码)缩放/点阵字体
^A(可缩放/点阵字体)命令⽤于内置的True Type字体。可缩放字体(也可以认为是平
纵向进⾏扩展。点阵字体由点阵象素组成,通常⾼
内置的的缩放字体(A0=CG Triumvirate Bold Condensed)默认为不旋转,15点⾼,12
^A命令得到字体的旋转⽅向、宽度、⾼度等参数。
命令的格式:
^Af,o,h,w
= 缩放/点阵字体
= 字体名
默认值:0(CG Triumvirate Bold Condensed)
其他值:A-Z,0-9(打印机的任何字体,包括下载字体,EPROM中储存
^CW来定义为A-Z,0-9)
= 字体⽅向
默认值:^FW默认值或上⼀个^FW的值。
其他
N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 字符⾼度
曲线字体:
默认
:
15点或上⼀次^CF的值。
可接受
10-1500点
点阵字体:
默认
指定点阵字体的标准⾼度
其他
标准⾼度⾼度的整数倍,2-10。
= 字符宽度
曲线字体:
默认
:
12点或上⼀次^CV的值,也可以显⽰为0
可接受
10-1500点
点阵字体:
默认
指定点阵字体的标准宽度
其他标准⾼度⾼度的整数倍,2-10。
使⽤字体名来调⽤字体
^A@(使⽤字体名来调⽤字体)命令使⽤字体的全名,来调⽤字体
第⼀⾏命令将查字体卡/后备电池RAM(B:)中的“Cyrillic.FNT”字体,当字体到后,
“This is a test.”
⼀旦^A@定义了“Cyrillic.FNT”,它的作⽤将⼀直保持到下⼀个^A@命令定义⼀个新字
在本例中第⼆个^A@命令中,字符的⼤⼩增加了,设置了新的旋转⽅向,打印机⽤同
“This string use the B:Cyrillic.FNT.”
@ = 缩放/点阵字体
= 使⽤字体名来调⽤字体
默认值:0(CG Triumvirate Bold Condensed)
其他值:A-Z,0-9(打印机的任何字体,包括下载字体,EPROM中储存
^CW来字定义为A-Z,0-9)
= 字体⽅向
默认值:上⼀个^FW值,如省略则为N。
其他
N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 字符⾼度(以点为单位)
缩放字体:整个字符⾼度的点数,放⼤倍数不是必须的,因为字符是可缩放的。
然后再除以基本
= 字符宽度(以点为单位)
缩放字体:整个字符宽度的点数,放⼤倍数不是必须的,因为字符是可缩放的。
然后再除以基本
= 字体名(按照ZPL命名惯例)
如果没有指定设备号的字母,默认的设备是RAM,或R:。如果不指定字
^A@指定的字体仍将发⽣作⽤。
条码
^B1(Code 11)也就是USD-8码。在Code 11条码中,每个字符由三个条的两个空组
10个数字和破折号。
打印⽐例调整:2.0到3.0
^FD(Field Data:数据字段)限制:100+字符。实际总数据由^BY的⽐例与标签的宽度(如^B1命令的格式:
^B1o,e,h,f,g
= Code 11条码
= 字体⽅向
默认值:^FW默认值或上⼀个^FW的值。
其他
N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 校验位
默认值:N(No) = 2位校验位
其他值: Y(Yes) = 1位校验位
= 条码⾼度
默认值:由^BY设置
:1到9999点
= 打印注释⾏
默认值: Y = 打印(Yes)
:N = 不打印(No)
= 将注释⾏打印在条码上⽅
默认值: N = 不打印在条码上⽅
: Y = 打印在条码上⽅
交叉⼆五码
^B2(交叉⼆五码)是⾼密度的、⾃校验的、连续的、数字的符号。它的每个字符由五个五个条或五个空。这五个元素中,两个是宽的三个是窄的。条码由条和空交叉组
条码中,每个字符由三个条的两个空组成,字符集为10个数字和破折号。
打印⽐例调整:2.0到3.0
^FD(Field Data:数据字段)限制:100+字符。实际总数据由^BY的⽐例与标签的宽度(如由定义可知,交叉⼆五码的位数必须是偶数。如果是奇数,则打印机⾃动在接收到的数0。
交叉⼆五码使⽤模10校验法。字符集:数字0-10
命令的格式:
^B2o,h,f,g,e
= 交叉⼆五码
= 字体⽅向
默认值:^FW默认值或上⼀个^FW的值。
其他
乱码文字生成N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 条码⾼度
默认值:由^BY设置
:1到9999点
= 打印注释⾏
默认值: Y = 打印(Yes)
:N = 不打印(No)
= 将注释⾏打印在条码上⽅
默认值: N = 不打印在条码上⽅
: Y = 打印在条码上⽅
= 校验位
默认值:N(No) = 2位校验位
其他值: Y(Yes) = 1位校验位
^B3(Code 39码)是很多⾏业的标准,为美国国防部(DOD)所采⽤,是美国国家标准协(ANSI)MH10.8-1983的三种识别符号之⼀。也叫作USD-3码或39码。
39码的每个字符由九个元素组成:五个条,四个空和字符间隙,这九个元素中,三个
打印⽐例调整:2.0到3.0
^FD(Field Data:数据字段)限制:100+字符。实际总数据由^BY的⽐例与标签的宽度(如字符集为10个数字和破折号。
Code 39码可以兼容128位ASCII字符集,参看表A和表B
字符集:数字0-10,A-Z,space,-,。,$,/,+,%
命令的格式:
^B3o,e,h,f,g
= Code 39条码
= 字体⽅向
默认值:^FW默认值或上⼀个^FW的值。
其他
N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 模43校验位
默认值:N(No) = 不打印校验位
其他值: Y(Yes) = 打印校验位
= 条码⾼度
默认值:由^BY设置
:1到9999点
= 打印注释⾏
默认值: Y = 打印(Yes)
:N = 不打印(No)
= 将注释⾏打印在条码上⽅
默认值: N = 不打印在条码上⽅
: Y = 打印在条码上⽅
Code 39码的起始位和终⽌位是⾃动⽣成的。
注意:模43校验位计算⽅法可参考附录D
^B4(Code 49码)是⼀种多⾏、连续、可变长的兼容128位全ASCII字符集的条码。128码⼀般2到8层,每层由左空⽩区、层起始符、4个符号字符、层终⽌符及右空⽩Code 49码的每个符号字符可表⽰2个
可以参考 Uniform Symbology Specification USS-9 可得到更多的信息。
打印⽐例是固定的。
命令的格式:
^B4o,h,f,m
= Code 49条码
= 字体⽅向
默认值:^FW默认值或上⼀个^FW的值。
其他
N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 每层⾼度
定义:默认值:由^BY值确认。
:1到标签⾼度
= 打印注释⾏
默认值:
N = 不打印(No) A = 打印在条码的上⽅(Above) B = 打印在条码的下⽅(Below)
注意:当条码超过2层,注释⾏将越过右边缘。
= 开始模式
默认
A =⾃动模式。打印机分析数据字段并决定起始模式。
其他
0 = 规范字母数字模式 1 = 多种可读字母数字 2 = 规则数字模式 3 = 数字字母组
规则数字字母变化1
规则数字字母变化2
字段数据字符集
当采⽤起始模式为0到5时,^FD送往打印机的数据是基于Code49码的内部字符集Code 49码的控制字符。
使⽤模式0-5时,有效的字段数据都将被⽀持。变化字符由⼀个转换字符和⼀个⾮转a,先送⼀个“SHIFT2”,接着再送
如果打印注释⾏,注释⾏上将出现⼩写的a。
注意:Code49码只使⽤⼤写字母。
如果检测到⼀个⽆效的字串,Code49格式化器将停⽌解释,并打印⼀个符号来代替这
⽤除了0到9或空格的任意字符结束数字模式
⽤了第四种模式但数据字段起始字符并不是SHIFT 1 字符集。
⽤了第五种模式但数据字段起始字符并不是SHIFT 2 字符集。
送了⼀个SHIFT 1字符但下⼀个字符不在SHIFT 1 字符集中。
送了⼀个SHIFT 2字符但下⼀个字符不在SHIFT 2 字符集中。
送了两个SHIFT 1 或SHIFT 2 控制字符。
Code 49 ⾃动模式的优势
使⽤⾃动模式(默认值)可完全不⽤⼈⼯选择起始模式和⼈⼯控制字符变化。⾃动模式ASCII字符串,选择适当的模式,处理字符变化,以最⼤密度压缩数据。
注意:当⼤于等于5位数字时,只能选择数字模式,数字模式在数字字符串长度⼩于8 B7 PDF417条码
^B7(PDF417)条码命令是⼀个⼆维、多层、连续、堆栈的符号码。这种条码可以在1000个字节。它完美地适⽤于那些需要在读条码时读⼊⼤量信息的应
代码由3到90个堆栈层组成,每⼀层由开始、停⽌和符号字符构成的码词组成,每个
3个码词。
打印⽐例固定。
下⾯是⼀个PDF417条码的⽰例,这个⽰例显⽰⼀个如下所⽰的条码,^FD 和^FS 间命令的格式:
^B7o,h,s,c,r,t
= PDF417条码
= 字体⽅向
默认值:^FW默认值或上⼀个^FW的值。
其他
N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 每层⾼度
默认值:由^BY值确认。其他值:1到标签⾼度
这个数字表⽰错误检查和纠错级别,默认值是只检测错误(不纠错),
0 =只检测错误。
1到8。纠错能⼒从⼩到⼤。
注意:当条码超过2层,注释⾏将越过右边缘。
= 编码的数据的列数⽤户可以指定每列的codeword来控制符号的宽度。
1:2 层/列
1到30
= 编码的层数
⽤户可以指定层数来控制符号的⾼度。默认值:1:2 层/列其他值:3-90
72个码字,共6列12层(随着码
= 截去层指⽰和停⽌区
默认值:N = 不截去(No),打印层指⽰和终⽌符
:Y = 截去(No),不打印层指⽰和终⽌符
如果层和列都是⽤户⾃定义的,它们的乘积必须⼩于928。
如果层 × 列>928将什么都不打印。
如果码字总数>层 × 列将不打印。
条码不能连续变化。
截短功能⽤在标签不会损坏的场合,右连的层指⽰和终⽌符可以减少⼀个单独的模
下图。
PDF417时特殊的^BY命令
使⽤PDF417时^Byw,r,h的参数意义如下:
模块宽度(默认值=2),上限为10。
⽐例(默认值=3)固定。在PDF417中没作⽤。
条码⾼度。整个条码的⾼度。如果PDF417在^B7中没有指定⾼度时,将
PDF417时特殊的^FD字符集
除了对打印机有特殊意义的那些字符外,所有ASCII字符都可送往打印机。在所有^FD CR/LF已成为合法字符。⽤下列办法替换。
= 回车/换⾏
= 软连字号(单词断开时使⽤),如果连字符放在⼀⾏的最后,它会被
如果它不是在在⼀⾏的最后,将会被忽略。(在^B7中忽略)
= 字符\,(注意必须选择^CI13 ,使它能打印 /)
= 任意字母/数字
条码
^B8(EAN-8)条码命令是EAN-13的缩短版,参见EAN-13可以得到更多的关于EAN的EAN是国际物品编码协会(European Article Number Association)的字母的⾸位。每个EAN-8的条码符号由四个元素组成:两个条,两个空。
打印⽐例固定。
^FD(Field data,字段数据)限制:必须7位,ZPLII⾃动在⼤于7位时截去超过的部分,7位于在前⾯加上0。
注意:JAN-8(⽇本物品编码)系统是EAN-8中的特殊应⽤。在这种情况下,送给打49。
EAN-8字符集:0到9。
命令的格式:
^B8o,h,f,g
= EAN-8条码
= 字体⽅向
默认值:^FW默认值或上⼀个^FW的值。
其他
N = 正常(Normal)
R = 顺时针旋转90度(Roated)
I = 顺时针旋转180度(Inverted)
B = 顺时针旋转270度 (Bottom)
= 条码⾼度
默认值:由^BY设置
:1到9999点
= 打印注释⾏
默认值: Y = 打印(Yes)
:N = 不打印(No)
= 将注释⾏打印在条码上⽅
默认值: N = 不打印在条码上⽅
: Y = 打印在条码上⽅
条码
^B9(UPC-E)条码命令是UPC系统的⼀种变化⽤于数字系统0,UPC是美国统⼀代码Universal Product C
ode)的缩写。它是UPC-A带有压缩0的缩短版,这样打印空间就注意:使⽤带压缩0的UPC码,⽤户必须输⼊满10位的字符串,ZPLII将计算并打UPC。
每个UPC-E的条码符号由四个元素组成:两个条,两个空。