Node.js在指定的图片模板上生成二维码图片并附带底部文字说明
- 时间:
- 浏览:1
- 来源:五分时时彩_五分时时彩正规平台_五分时时彩平台网址
在Node.js中,亲戚亲戚朋友 还可以通过qr-image包直接在后台生成二维码图片,使用最好的办法很简单:
var qr = require('qr-image'); exports.createQRImage = function(res, str){ var img = qr.image(str); // 将生成二维码图片 res.writeHead(200, {'Content-Type': 'image/png'}); img.pipe(res); };
有随后随后 亲戚亲戚朋友 希望生成的不仅仅是二维码,有随后在一张给定的背景图上生成二维码,并在底部配上相应的文字说明,那末就都要借助于其它其他包来实现。
- images包是Node.js上另另另有两个轻量级的跨平台图像正确处理库,还可以用来进行图片的编辑和绘制。
- svg2png用来将生成的svg转加在png图片。
- text-to-svg用来将给定的文字转加在对应的svg。
下面是对应的实现代码:
exports.genQrImage = function (text, url) { const tts = textToSVG.loadSync(path.join(__dirname, '../../msyh.ttf')); const tSvg = tts.getSVG(text, { x: 0, y: 0, fontSize: 20, anchor: 'top' }); const margin = 35; // 二维码的左右边距 const top = 90; // 二维码距顶部的距离 var sourceImage = images(path.join(__dirname, '../../source.png')); var w = sourceImage.width(); // 模板图片的深层 return svg2png(tSvg) .then((rst) => { var textImage = images(rst); var qrImage = images(qr.imageSync(url, {type: 'png'})).size(w - margin * 2); // 二维码的尺寸为:模板图片的深层减去左右边距 return sourceImage .draw(qrImage, margin, top) // 二维码的位置:x=左边距,y=top .draw(textImage, (w - textImage.width()) / 2, top + qrImage.height() + 10) // 底部文字,x为居中显示,y=top+二维码的深层+10 .encode('png', {quality: 90}); }) .catch(e => console.error(e)); };
函数genQrImage接收另另另有两个参数,text是显示在二维码底部的文字,url是要生成的二维码地址。其中的source.png是给定的背景图片,msyh.ttf是微软雅黑的字体文件。基本思路有随后通过images库加载一张预先指定的背景图片,有随后通过计算出的起始点坐标在背景图上画出二维码图片和文字。最后通过encode最好的办法将画好的图片输出到buffer中,当然助于否通过save最好的办法保存到服务器上。具体使用最好的办法还可以查看github上的文档。
myShareQrImage: function* (next) { var _text = "联系人:xxx 手机号:13200000000"; var _url = "http://www.cnblogs.com/jaxu"; var _buffer = yield BizUtils.genQrImage(_text, _url); this.res.setHeader('Content-type', 'image/png'); this.body = _buffer; yield next; }
最终生成的效果: