Node.js在圖片模板上如何生成二維碼圖片并附帶底部文字說明

小編給大家分享一下Node.js在圖片模板上如何生成二維碼圖片并附帶底部文字說明,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

10年積累的網站設計制作、成都網站設計經驗,可以快速應對客戶對網站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網絡服務。我雖然不認識你,你也不認識我。但先建設網站后付款的網站建設流程,更有赤峰免費網站建設讓你可以放心的選擇與我們合作。

在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;
}

最終生成的效果:

Node.js在圖片模板上如何生成二維碼圖片并附帶底部文字說明

以上是“Node.js在圖片模板上如何生成二維碼圖片并附帶底部文字說明”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創新互聯行業資訊頻道!

網站題目:Node.js在圖片模板上如何生成二維碼圖片并附帶底部文字說明
網頁鏈接:http://m.kartarina.com/article14/pihoge.html

成都網站建設公司_創新互聯,為您提供云服務器響應式網站網站收錄營銷型網站建設電子商務軟件開發

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

網站托管運營
主站蜘蛛池模板: 国产强被迫伦姧在线观看无码| 无码人妻少妇久久中文字幕| 国产AV无码专区亚洲AV男同 | 少妇无码太爽了在线播放| 国产精品一级毛片无码视频| 亚洲av福利无码无一区二区| 韩国无码AV片在线观看网站| 国产AV无码专区亚洲A∨毛片| 色欲aⅴ亚洲情无码AV| 久久午夜无码免费| 精品一区二区无码AV| 亚洲精品久久久久无码AV片软件| 人妻无码人妻有码中文字幕| 久久久无码精品午夜| 久久亚洲精品无码VA大香大香| 亚洲人成人无码网www电影首页| 蜜臀AV无码精品人妻色欲| 人妻中文字系列无码专区| 国产精品无码素人福利不卡| 西西444www无码大胆| 久久久久亚洲av无码专区喷水 | yy111111少妇影院无码| 亚洲一本到无码av中文字幕| 亚洲国产精品无码一线岛国| 亚洲一级特黄无码片| 日韩AV片无码一区二区不卡| 亚洲a∨无码精品色午夜| 中文字幕av无码一二三区电影| 无码国产福利av私拍 | 无码中文在线二区免费| 日木av无码专区亚洲av毛片| 亚洲av永久无码制服河南实里| 黑人无码精品又粗又大又长| 人妻丰满熟妇A v无码区不卡| 中文字幕精品三区无码亚洲| 日日摸夜夜添无码AVA片| 亚洲视频无码高清在线| 亚洲日韩精品A∨片无码加勒比| 久久精品无码一区二区无码| 亚洲AV无码AV男人的天堂| 无码人妻视频一区二区三区 |