如何使用nodejs在二维码中间添加logo
how to add logo in the middle of the qr code using nodejs
我正在尝试创建一个徽标并尝试在二维码中间添加一个徽标,我能够生成二维码但无法获得中间带有徽标的二维码我试过这个代码但无法获得出现此错误的结果
Error: You need to specify a canvas element
我正在使用这个库https://github.com/soldair/node-qrcode
这里是试过的代码
const QRCode = require("qrcode");
const getQRcodeImage = async () => {
try {
let canvas = await QRCode.toCanvas(`my sample text`);
//adding a log at center
const imgDim = { width: 30, height: 30 }; //logo dimention
var context = canvas.getContext("2d");
var imageObj = new Image();
imageObj.src = "./Capture.png";
imageObj.onload = function () {
context.drawImage(
imageObj,
canvas.width / 2 - imgDim.width / 2,
canvas.height / 2 - imgDim.height / 2,
imgDim.width,
imgDim.height
);
};
return canvas;
} catch (e) {
console.error(e);
return "";
}
};
getQRcodeImage();
在浏览器中,您需要在 DOM 中添加特殊的 canvas 元素,或者在回调函数中获取新的 canvas return:
<html>
<body>
<canvas id="canvas"></canvas>
<div id="container"></div>
<script>
const canvas = document.getElementById('canvas');
QRCode.toCanvas(canvas, 'One')
// Or.
QRCode.toCanvas('Two', { errorCorrectionLevel: 'H' }, function (err, canvas) {
if (err) throw err
const container = document.getElementById('container')
container.appendChild(canvas)
})
</script>
</body>
</html>
在服务器中需要使用with node-canvas来绘制二维码。
const QRCode = require("qrcode");
const { createCanvas, loadImage } = require("canvas");
async function create(dataForQRcode, center_image, width, cwidth) {
const canvas = createCanvas(width, width);
QRCode.toCanvas(
canvas,
dataForQRcode,
{
errorCorrectionLevel: "H",
margin: 1,
color: {
dark: "#000000",
light: "#ffffff",
},
}
);
const ctx = canvas.getContext("2d");
const img = await loadImage(center_image);
const center = (width - cwidth) / 2;
ctx.drawImage(img, center, center, cwidth, cwidth);
return canvas.toDataURL("image/png");
}
async function main() {
const qrCode = await create(
"http://shauryamuttreja.com/qr/",
"",
150,
50
);
console.log(qrCode);
}
main();
我正在尝试创建一个徽标并尝试在二维码中间添加一个徽标,我能够生成二维码但无法获得中间带有徽标的二维码我试过这个代码但无法获得出现此错误的结果
Error: You need to specify a canvas element
我正在使用这个库https://github.com/soldair/node-qrcode
这里是试过的代码
const QRCode = require("qrcode");
const getQRcodeImage = async () => {
try {
let canvas = await QRCode.toCanvas(`my sample text`);
//adding a log at center
const imgDim = { width: 30, height: 30 }; //logo dimention
var context = canvas.getContext("2d");
var imageObj = new Image();
imageObj.src = "./Capture.png";
imageObj.onload = function () {
context.drawImage(
imageObj,
canvas.width / 2 - imgDim.width / 2,
canvas.height / 2 - imgDim.height / 2,
imgDim.width,
imgDim.height
);
};
return canvas;
} catch (e) {
console.error(e);
return "";
}
};
getQRcodeImage();
在浏览器中,您需要在 DOM 中添加特殊的 canvas 元素,或者在回调函数中获取新的 canvas return:
<html>
<body>
<canvas id="canvas"></canvas>
<div id="container"></div>
<script>
const canvas = document.getElementById('canvas');
QRCode.toCanvas(canvas, 'One')
// Or.
QRCode.toCanvas('Two', { errorCorrectionLevel: 'H' }, function (err, canvas) {
if (err) throw err
const container = document.getElementById('container')
container.appendChild(canvas)
})
</script>
</body>
</html>
在服务器中需要使用with node-canvas来绘制二维码。
const QRCode = require("qrcode");
const { createCanvas, loadImage } = require("canvas");
async function create(dataForQRcode, center_image, width, cwidth) {
const canvas = createCanvas(width, width);
QRCode.toCanvas(
canvas,
dataForQRcode,
{
errorCorrectionLevel: "H",
margin: 1,
color: {
dark: "#000000",
light: "#ffffff",
},
}
);
const ctx = canvas.getContext("2d");
const img = await loadImage(center_image);
const center = (width - cwidth) / 2;
ctx.drawImage(img, center, center, cwidth, cwidth);
return canvas.toDataURL("image/png");
}
async function main() {
const qrCode = await create(
"http://shauryamuttreja.com/qr/",
"",
150,
50
);
console.log(qrCode);
}
main();