Demo: 前端生成条形码并打印

前端生成条形码并打印

在这里插入图片描述

安装依赖:
npm i print-js // 打印
npm i jsbarcode // 生成条形码

<template>
    <div id="printContent" style="display: none;">
        <div id="elTable">
            <div class="name">名称:{{ printInfo.name }}</div>
            <div class="name">品牌:{{ printInfo.brand }}</div>
            <div class="name">型号:{{ printInfo.model }}</div>
            <!-- 显示条形码 -->
            <canvas class="barcode" ref="barcodeRef"></canvas>
        </div>
    </div>
    <el-button type="success" @click="pdfPrint">打印pdf文件</el-button>
</template>
  
<script setup lang="ts">
import { ref, onMounted } from 'vue'
import printJS from "print-js";
import JsBarcode from 'jsbarcode'; // 导入JsBarcode库

const barcodeRef = ref(null) // 条形码实例
// 打印信息
const printInfo = ref({
    name: '大疆无人机',
    brand: '南方',
    model: 'model'
})

// 生成条形码
const generateBarcode = () => {
    const canvas = barcodeRef.value; // 获取到canvas元素
    // 传递参数生成条形码
    JsBarcode(canvas, "No.202401250212118948", {
        format: "CODE128",//条形码的格式
        width: 2, //线宽
        height: 48, //条码高度
        lineColor: "#000", //线条颜色
        displayValue: true, //是否显示文字
        margin: 2, //设置条形码周围的空白区域
    })
}

// 打印
const pdfPrint = () => {
    printJS({
        printable: 'elTable', // HTML内容
        type: "html", // 打印类型
        header: "", // '表单名称',
        targetStyles: ["*"],
        style: "@page {margin:1mm 1mm};", // 可选-打印时去掉眉页眉尾
        ignoreElements: ["no-print"], // 接受打印父 html 元素时应忽略的 html id 数组。
        properties: null,
    })
}

onMounted(() => {
    generateBarcode()
})
</script>
  
<style lang="scss">
#elTable {
    width: 200px;

    .barcode {
        width: 192px;
    }
}
</style>
  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,这个问题涉及到两个方面,分别是生成条码图片和使用标签机打印,我会分别给出代码示例。 首先是生成条码图片的示例代码,我们可以使用 ZXing 这个开源库来实现: ```java import com.google.zxing.BarcodeFormat; import com.google.zxing.EncodeHintType; import com.google.zxing.WriterException; import com.google.zxing.common.BitMatrix; import com.google.zxing.qrcode.QRCodeWriter; import java.util.HashMap; import java.util.Map; import android.graphics.Bitmap; import android.graphics.Color; public class BarcodeUtils { public static Bitmap generateBarcode(String contents, int width, int height) throws WriterException { Map<EncodeHintType, Object> hints = new HashMap<>(); hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); BitMatrix matrix = new QRCodeWriter().encode(contents, BarcodeFormat.CODE_128, width, height, hints); Bitmap bitmap = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888); for (int x = 0; x < width; x++) { for (int y = 0; y < height; y++) { bitmap.setPixel(x, y, matrix.get(x, y) ? Color.BLACK : Color.WHITE); } } return bitmap; } } ``` 上述代码中,我们使用 `QRCodeWriter` 类来生成条码图片,其中 `BarcodeFormat.CODE_128` 表示生成的是 Code 128 类型的条码生成的图片大小由 `width` 和 `height` 参数指定。 接下来是使用标签机打印的示例代码,我们可以使用 ZPL 语言来编写标签模板,然后通过网络发送指令给标签机来打印: ```java import java.io.IOException; import java.io.OutputStream; import java.net.Socket; public class LabelPrinter { private static final String LABEL_TEMPLATE = "^XA^FO50,50^BY3^B3N,N,200,Y^FD${barcode}^FS^XZ"; private String ipAddress; private int port; public LabelPrinter(String ipAddress, int port) { this.ipAddress = ipAddress; this.port = port; } public void printBarcode(String contents) throws IOException { String zpl = LABEL_TEMPLATE.replace("${barcode}", contents); Socket socket = new Socket(ipAddress, port); OutputStream out = socket.getOutputStream(); out.write(zpl.getBytes()); out.flush(); out.close(); socket.close(); } } ``` 上述代码中,我们定义了一个标签模板,其中 `${barcode}` 是一个占位符,表示条码内容将在打印时替换为真实的条码内容。在 `printBarcode` 方法中,我们将条码内容替换到标签模板中,然后通过网络发送 ZPL 指令给标签机来打印。 使用时,你需要将生成条码图片转换为 Base64 编码的字符串,然后调用 `printBarcode` 方法进行打印: ```java String barcodeContents = "1234567890"; Bitmap barcodeBitmap = BarcodeUtils.generateBarcode(barcodeContents, 400, 200); ByteArrayOutputStream outputStream = new ByteArrayOutputStream(); barcodeBitmap.compress(Bitmap.CompressFormat.PNG, 100, outputStream); String barcodeBase64 = Base64.encodeToString(outputStream.toByteArray(), Base64.DEFAULT); LabelPrinter printer = new LabelPrinter("192.168.0.100", 9100); printer.printBarcode(barcodeBase64); ``` 上述代码中,我们生成了一个宽度为 400、高度为 200 的 Code 128 条码图片,并将其转换为 Base64 编码的字符串。然后,我们创建了一个 `LabelPrinter` 对象,传入了标签机的 IP 地址和端口号,并调用 `printBarcode` 方法将条码打印出来。 希望这个示例能帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

goto_w

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值