|
|
|
@ -1,11 +1,34 @@ |
|
|
|
import QRCode from 'qrcode'; |
|
|
|
|
|
|
|
/** |
|
|
|
* 标签打印模板 Mixin |
|
|
|
* 提供 A001、A002、A003 三种标签打印模板的通用方法 |
|
|
|
*/ |
|
|
|
export default { |
|
|
|
methods: { |
|
|
|
/** |
|
|
|
* 生成二维码图片的Base64字符串 |
|
|
|
* @param {string} text - 二维码内容 |
|
|
|
* @param {number} size - 二维码尺寸(像素) |
|
|
|
* @returns {Promise<string>} - Base64图片字符串 |
|
|
|
*/ |
|
|
|
async generateQRCodeImage(text, size = 150) { |
|
|
|
try { |
|
|
|
const dataUrl = await QRCode.toDataURL(text, { |
|
|
|
width: size, |
|
|
|
margin: 0, |
|
|
|
errorCorrectionLevel: 'M' |
|
|
|
}); |
|
|
|
return dataUrl; |
|
|
|
} catch (err) { |
|
|
|
console.error('生成二维码失败:', err); |
|
|
|
return ''; |
|
|
|
} |
|
|
|
}, |
|
|
|
|
|
|
|
// A001 标签打印(70mm x 30mm)- 左边二维码,右边文字信息
|
|
|
|
printLabelA001(LODOP, printData, isNewPage){ |
|
|
|
// 布局:2mm边距,左侧二维码区20mm,右侧文字区,底部两行物料名称
|
|
|
|
async printLabelA001(LODOP, printData, isNewPage){ |
|
|
|
if(isNewPage){ |
|
|
|
LODOP.NEWPAGE(); |
|
|
|
} |
|
|
|
@ -13,91 +36,98 @@ export default { |
|
|
|
// ============================================================
|
|
|
|
// 1. 纸张设置
|
|
|
|
// ============================================================
|
|
|
|
// SET_PRINT_PAGESIZE(方向, 宽度, 高度, 纸张名称)
|
|
|
|
// 方向: 0=纵向, 1=横向
|
|
|
|
// 宽度/高度: 单位为 1/10 毫米,如 700 = 70mm
|
|
|
|
// 纸张大小 70mm x 30mm,留2mm边距,实际打印区域 66mm x 26mm
|
|
|
|
LODOP.SET_PRINT_PAGESIZE(0, 700, 300, ''); |
|
|
|
|
|
|
|
// ============================================================
|
|
|
|
// 2. 绘制边框和分隔线
|
|
|
|
// ============================================================
|
|
|
|
// ADD_PRINT_RECT(上边距, 左边距, 宽度, 高度, 边框样式, 边框粗细)
|
|
|
|
// 边框样式: 0=实线
|
|
|
|
// 边框粗细: 单位为像素
|
|
|
|
// 外边框(2mm边距,66mm宽 x 26mm高)
|
|
|
|
LODOP.ADD_PRINT_RECT('2mm', '2mm', '66mm', '26mm', 0, 1); |
|
|
|
|
|
|
|
// 外边框(1mm边距,68mm宽 x 28mm高)
|
|
|
|
LODOP.ADD_PRINT_RECT('1mm', '1mm', '68mm', '28mm', 0, 1); |
|
|
|
|
|
|
|
// ADD_PRINT_LINE(起点Y, 起点X, 终点Y, 终点X, 线条样式, 线条粗细)
|
|
|
|
// 线条样式: 0=实线
|
|
|
|
|
|
|
|
// 垂直分隔线:左右分隔(从上到下)
|
|
|
|
// 参数说明:起点(1mm, 22mm) -> 终点(29mm, 22mm)
|
|
|
|
LODOP.ADD_PRINT_LINE('1mm', '22mm', '29mm', '22mm', 0, 1); |
|
|
|
// 垂直分隔线:左右分隔(二维码区18mm,文字区48mm)
|
|
|
|
LODOP.ADD_PRINT_LINE('2mm', '20mm', '19mm', '20mm', 0, 1); |
|
|
|
|
|
|
|
// 水平分隔线1:编码下方
|
|
|
|
// 参数说明:起点(8mm, 22mm) -> 终点(8mm, 69mm)
|
|
|
|
LODOP.ADD_PRINT_LINE('8mm', '22mm', '8mm', '69mm', 0, 1); |
|
|
|
LODOP.ADD_PRINT_LINE('7mm', '20mm', '7mm', '68mm', 0, 1); |
|
|
|
|
|
|
|
// 水平分隔线2:型号下方
|
|
|
|
// 参数说明:起点(13mm, 22mm) -> 终点(13mm, 69mm)
|
|
|
|
LODOP.ADD_PRINT_LINE('13mm', '22mm', '13mm', '69mm', 0, 1); |
|
|
|
LODOP.ADD_PRINT_LINE('11mm', '20mm', '11mm', '68mm', 0, 1); |
|
|
|
|
|
|
|
// 水平分隔线3:数量下方
|
|
|
|
// 参数说明:起点(18mm, 22mm) -> 终点(18mm, 69mm)
|
|
|
|
LODOP.ADD_PRINT_LINE('18mm', '22mm', '18mm', '69mm', 0, 1); |
|
|
|
LODOP.ADD_PRINT_LINE('15mm', '20mm', '15mm', '68mm', 0, 1); |
|
|
|
|
|
|
|
// 水平分隔线4:批号下方
|
|
|
|
// 参数说明:起点(23mm, 22mm) -> 终点(23mm, 69mm)
|
|
|
|
LODOP.ADD_PRINT_LINE('23mm', '22mm', '23mm', '69mm', 0, 1); |
|
|
|
// 水平分隔线4:批号下方,同时是物料描述区上边界(横跨整个宽度)
|
|
|
|
LODOP.ADD_PRINT_LINE('19mm', '2mm', '19mm', '68mm', 0, 1); |
|
|
|
|
|
|
|
// ============================================================
|
|
|
|
// 3. 左侧二维码
|
|
|
|
// 3. 左侧二维码(使用LODOP自带二维码)
|
|
|
|
// ============================================================
|
|
|
|
// ADD_PRINT_BARCODE(上边距, 左边距, 宽度, 高度, 条码类型, 条码内容)
|
|
|
|
// 二维码位置:距上7mm,距左3mm,尺寸20mm x 20mm
|
|
|
|
const qrIndex = LODOP.ADD_PRINT_BARCODE('7mm', '3mm', '20mm', '20mm', 'QRCode', printData.rollNo || ''); |
|
|
|
LODOP.SET_PRINT_STYLEA(qrIndex, "QRCodeVersion", 4); |
|
|
|
LODOP.SET_PRINT_STYLEA(qrIndex, "QRCodeErrorLevel", "M"); |
|
|
|
// 可见区域:18mm(宽) x 17mm(高)
|
|
|
|
// 二维码有默认白边(静区),需放大约20%让白边溢出到框外
|
|
|
|
const qrContent = printData.rollNo || ''; |
|
|
|
if (qrContent) { |
|
|
|
const qrIndex = LODOP.ADD_PRINT_BARCODE('1.5mm', '1.5mm', '21mm', '20mm', 'QRCode', qrContent); |
|
|
|
LODOP.SET_PRINT_STYLEA(qrIndex, "QRCodeVersion", 0); // 自动选择版本
|
|
|
|
LODOP.SET_PRINT_STYLEA(qrIndex, "QRCodeErrorLevel", "M"); |
|
|
|
} |
|
|
|
|
|
|
|
// ============================================================
|
|
|
|
// 4. 右侧文字信息(5行)
|
|
|
|
// 4. 右侧文字信息(4行)- 字体6号
|
|
|
|
// ============================================================
|
|
|
|
// ADD_PRINT_TEXT(上边距, 左边距, 宽度, 高度, 文字内容)
|
|
|
|
|
|
|
|
// 文字起始X位置(左边距)和宽度
|
|
|
|
const startX = '23mm'; // 可调整:文字左边距,增大向右移,减小向左移
|
|
|
|
const textWidth = '43mm'; // 可调整:文字区域宽度
|
|
|
|
const labelX = '21mm'; // 标签列起始位置(从23mm改为21mm)
|
|
|
|
const valueX = '30mm'; // 值列起始位置(从32mm改为30mm)
|
|
|
|
const labelWidth = '9mm'; // 标签列宽度
|
|
|
|
const valueWidth = '37mm'; // 值列宽度(从35mm改为37mm)
|
|
|
|
const fontSize = 6; // 字体大小(从8号改为6号)
|
|
|
|
|
|
|
|
// 编码(第1行)
|
|
|
|
// 上边距4mm:可调整,增大向下移,减小向上移
|
|
|
|
const text1 = LODOP.ADD_PRINT_TEXT('4mm', startX, textWidth, '4mm', `编码:${printData.partNo || ''}`); |
|
|
|
LODOP.SET_PRINT_STYLEA(text1, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(text1, "FontSize", 8); // 可调整:字体大小
|
|
|
|
const label1 = LODOP.ADD_PRINT_TEXT('3.5mm', labelX, labelWidth, '3mm', '编码:'); |
|
|
|
LODOP.SET_PRINT_STYLEA(label1, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(label1, "FontSize", fontSize); |
|
|
|
|
|
|
|
const value1 = LODOP.ADD_PRINT_TEXT('3.5mm', valueX, valueWidth, '3mm', printData.partNo || ''); |
|
|
|
LODOP.SET_PRINT_STYLEA(value1, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(value1, "FontSize", fontSize); |
|
|
|
LODOP.SET_PRINT_STYLEA(value1, "Bold", 1); |
|
|
|
|
|
|
|
// 型号(第2行)
|
|
|
|
// 上边距9mm:可调整
|
|
|
|
const text2 = LODOP.ADD_PRINT_TEXT('9mm', startX, textWidth, '4mm', `型号:${printData.spec || ''}`); |
|
|
|
LODOP.SET_PRINT_STYLEA(text2, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(text2, "FontSize", 8); |
|
|
|
const label2 = LODOP.ADD_PRINT_TEXT('7.5mm', labelX, labelWidth, '3mm', '型号:'); |
|
|
|
LODOP.SET_PRINT_STYLEA(label2, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(label2, "FontSize", fontSize); |
|
|
|
|
|
|
|
const value2 = LODOP.ADD_PRINT_TEXT('7.5mm', valueX, valueWidth, '3mm', printData.spec || ''); |
|
|
|
LODOP.SET_PRINT_STYLEA(value2, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(value2, "FontSize", fontSize); |
|
|
|
|
|
|
|
// 数量(第3行)
|
|
|
|
// 上边距14mm:可调整
|
|
|
|
const text3 = LODOP.ADD_PRINT_TEXT('14mm', startX, textWidth, '4mm', `数量:${printData.quantity || ''}`); |
|
|
|
LODOP.SET_PRINT_STYLEA(text3, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(text3, "FontSize", 8); |
|
|
|
const label3 = LODOP.ADD_PRINT_TEXT('11.5mm', labelX, labelWidth, '3mm', '数量:'); |
|
|
|
LODOP.SET_PRINT_STYLEA(label3, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(label3, "FontSize", fontSize); |
|
|
|
|
|
|
|
const value3 = LODOP.ADD_PRINT_TEXT('11.5mm', valueX, valueWidth, '3mm', printData.quantity || ''); |
|
|
|
LODOP.SET_PRINT_STYLEA(value3, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(value3, "FontSize", fontSize); |
|
|
|
|
|
|
|
// 批号(第4行)
|
|
|
|
// 上边距19mm:可调整
|
|
|
|
const text4 = LODOP.ADD_PRINT_TEXT('19mm', startX, textWidth, '4mm', `批号:${printData.batchNo || ''}`); |
|
|
|
LODOP.SET_PRINT_STYLEA(text4, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(text4, "FontSize", 8); |
|
|
|
const label4 = LODOP.ADD_PRINT_TEXT('15.5mm', labelX, labelWidth, '3mm', '批号:'); |
|
|
|
LODOP.SET_PRINT_STYLEA(label4, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(label4, "FontSize", fontSize); |
|
|
|
|
|
|
|
// 日期(第5行)
|
|
|
|
// 上边距24mm:可调整
|
|
|
|
const text5 = LODOP.ADD_PRINT_TEXT('24mm', startX, textWidth, '4mm', `日期:${printData.documentDate || ''}`); |
|
|
|
LODOP.SET_PRINT_STYLEA(text5, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(text5, "FontSize", 8); |
|
|
|
const value4 = LODOP.ADD_PRINT_TEXT('15.5mm', valueX, valueWidth, '3mm', printData.batchNo || ''); |
|
|
|
LODOP.SET_PRINT_STYLEA(value4, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(value4, "FontSize", fontSize); |
|
|
|
|
|
|
|
// ============================================================
|
|
|
|
// 5. 底部物料名称(2行)- 横跨整个宽度
|
|
|
|
// ============================================================
|
|
|
|
const partDesc = printData.partDesc || ''; |
|
|
|
// 底部区域:从19mm分隔线下方开始,高度约8mm,可显示两行文字
|
|
|
|
const descText = LODOP.ADD_PRINT_TEXT('19.5mm', '3mm', '63mm', '8mm', partDesc); |
|
|
|
LODOP.SET_PRINT_STYLEA(descText, "FontName", "Microsoft YaHei"); |
|
|
|
LODOP.SET_PRINT_STYLEA(descText, "FontSize", fontSize); |
|
|
|
LODOP.SET_PRINT_STYLEA(descText, "LineSpacing", 0); // 行间距
|
|
|
|
LODOP.SET_PRINT_STYLEA(descText, "Multiline", true); // 允许多行
|
|
|
|
}, |
|
|
|
|
|
|
|
// A002 标签打印(70mm x 20mm)- 其他工序用
|
|
|
|
|