- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将从 < div > 截取的屏幕截图转换为 NodeJS 中的 ZPL 字符串。很像 http://labelary.com/viewer.html这将拍摄图像并输出 ZPL 代码。
我在做什么:
我正在使用一个名为“domToImage”( https://github.com/tsayen/dom-to-image ) 的包,它会截取我正在说明的 DOM 的屏幕截图。我目前正在使用 domToImage.toBlob() 函数,该函数随后返回 Blob{size: 102776, type: "image/png"}。
为了测试它是否真的有效,我使用“FileSaver”( https://www.npmjs.com/package/file-saver ) 将文件保存为 PNG,它确实有效,而且图片看起来很棒!!
这是我正在做的一个简单的示例代码
domtoimage.toBlob(document.getElementById('labelInfo'))
.then(function (blob)
{
console.log(blob)
saveAs(blob, "test.png");
});
我正在尝试做的是将该“blob”转换为 ZPL 字符串或格式,以便我可以将其发送到网络中的打印机。
A) 我尝试安装 image-to-zpl( https://www.npmjs.com/package/image-to-zpl ) 但我认为我可能做错了什么,因为我无法像我能够安装的任何其他模块一样需要它,我收到一条错误消息: 找不到模块“image-to-zpl”的声明文件。 '/path/to/node_modules/image-to-zpl/index.js' 隐式具有 'any' 类型。我什至尝试使用 import 而不是 require 但没有成功。
B) 我在 Java ( http://www.jcgonzalez.com/java-image-to-zpl-example ) 中找到了一个代码,但我几乎什么都不懂,我不知道如何将数据从我的应用程序发送到 Java 文件,然后将字符串带回应用程序NodeJS(我是菜鸟)。
C) 我研究了 Labelarys API,但不幸的是,它所做的只是将 ZPL 转换为 PDF 或 PNG,但反之则不行。
D) 考虑使用 zbtprinter ( https://github.com/bstmedia/zbtprinter/ ) 因为它实际上具有我需要的功能但不幸的是它会直接使用蓝牙将它发送到打印机而不输出 ZPL,在我的情况下不能使用因为打印机没有蓝牙。它在网络上。我还需要学习如何通过网络将整个字符串直接发送到打印机:/
我急需帮助各位
编辑
这就是我在 HTML 中所做的:
<div style="width: 1000px" class="labelInfo" id="labelInfo">
<img src="images/template.bmp" style="max-width: 100%; max-height: 100%">
<div class="ref"> {{ referenceNumber }} </div>
<div class="serial">{{ serialNumber }}</div>
<div class="date" id="date">{{ yearMonth }}</div>
<canvas class="qr" id="canvas"></canvas>
</div>
描述:我正在使用一个图像模板,其中包含所有 Logo ,标签的空白部分被 3 个 div 填充;我有 3 个 div,根据用户输入,这些字段被放置在图像模板中的指定位置; Canvas 用于根据序列号的内容放置二维码。
当用户点击按钮时,后端代码会获取整个“labelInfo”div 的图像,然后将其转换为 ZPL 以便发送到打印机(这就是我想要实现的目标)
最佳答案
将通用图像转换为 ZPL 可用的图像非常重要,无法用几行伪代码来描述。相反,我已经将这段代码搁置了一段时间,你的问题促使我清理它并使其可用:
https://github.com/metafloor/zpl-image
或
npm 安装 zpl-image
适用于浏览器和 node.js。在浏览器中,您传入 <img>
或 <canvas>
元素并返回 ZPL 使用的 Z64 压缩 GRF 格式的渲染图像。
用于打印图像的 ZPL 和 zebra 打印机的其他任何东西看起来像:
// image is a <img> or <canvas>
let res = imageToZ64(image);
let zpl = `
^XA^LH0,0^FWN^PON^PMN^LRN
^FO10,10^GFA,${res.length},${res.length},${res.rowlen},${res.z64)
^XZ`;
关于javascript - 从类型 : 'image/png' to ZPL in NodeJs 转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57819550/
当我调用 png.Decode(imageFile) 时,它返回类型 image.Image。但我找不到将其转换为 image.NRGBA 或 image.RGBA 的记录方式,我可以在其上调用 At
image/jpeg 和 image/png 包有 Decode 和 Encode 函数,可以读取和写入 jpeg 和 png 图像,但 image/gif 包没有 - 只有 Decode 和 Dec
我正在尝试从一系列任意的非调色板图像创建动画 GIF。为了创建调色板图像,我需要以某种方式想出一个调色板。 // RGBA, etc. images from somewhere else var f
我在今年夏天的空闲时间使用 Go 镜像包进行一些练习。 package main import ( "os" "image" "image/png" "image/co
关闭。这个问题需要debugging details .它目前不接受答案。 想改进这个问题?将问题更新为 on-topic对于堆栈溢出。 1年前关闭。 Improve this question 今天
我正在尝试在 TilePane 中列出图像。当我尝试创建图像 new ImageView("address"); 时出现错误,地址如下: "file:D:/Chrysanthemum.jpeg/" 以
我有一个用于为画廊选择图像的表单,我希望允许用户仅选择 jpg、gif 和 png 图像格式。 现在,为了测试,我将图像的扩展名更改为 .bmp,例如“image1.bmp”,当我在输入文件中单击以选
我有创建图像的代码:(m_img 是 javafx.scene.image.Image) Image m_img = new Image("file:" + p_Fil.getAbsoluteFile
假设我有一个这样的 8 位灰度图像: var pixels []byte = ... width := 100 height := 100 如何将其转换为实现 image.Image 的东西? 最佳答
这段代码是我在localhost:8088 URL上的索引/主页的一部分,如果我想将用户发送到url localhost:8088/image/1,我应该写href='image/{{$image->
我正在尝试对图像进行简单的裁剪。这是代码 from PIL.Image import Image def get_image_half(image, half="upper"): if hal
我在这个问题上花了一整天,但在堆栈溢出中没有看到答案! 我试过了但是没用: >> pil_image = Image.frombytes('RGBA', wand_image.size, wa
所以,我是那些以始终使用最新版本的浏览器而自豪的人之一(当然 Internet Explorer 除外 - 我说的不是那个浏览器)。 我遇到了 this awesome CSS3 website详细介
如果 image_tag 无法从 url 加载图像,我想呈现默认图像: 因此,如果 image_tag 无法从 url 加载图像: 然后呈现默认值: 这将生成结果 HTML: 关于image -
我正在创建一个类似横幅的组件,并将图像设置为组件的背景,但我无法让它工作。我尝试了网上发布的不同建议,但没有成功,目前我不确定我的错误是否在 react 代码中,或者是 webpack 没有正确加载文
如何解决 Dart 中的这种歧义错误。 import 'dart:io'; import 'package:flutter/material.dart'; import 'package:camera
Center( child: CachedNetworkImage( imageUrl: "http:/ sosme link he
设置 www.website.com/sds/(index.htm) 以便鼠标悬停在不同位置时显示图像。 出于某种原因,当您将鼠标悬停在蓝色气球上时,图像 2.jpg 和 3.jpg(在蓝色气球上来回
社交网络在共享 URL 时可以很好地从网站中提取标题和描述,但对于图像,仍然需要创建自定义元标记:property="og:image" name="twitter:image" itemprop="
我正在尝试写一个简短的,它将读取一个 PNG 文件,并将一个 channel 与另一个 channel (R,G,B) 交换作为可能的选择。 但是,我无法找到如何从 image.At(x,y) 返回的
我是一名优秀的程序员,十分优秀!