zoukankan      html  css  js  c++  java
  • 利用 qrcode 在图片生成二维码

    百度网盘下载:  qrcode  提取码: ubax,详细文档说明:请查看

    对比图

    效果图

    下载下来后我把他引入下面页面--qr.html(路径记得换成你自己的)

    <!DOCTYPE html>
    <html lang="en">

    <head>
      <meta charset="utf-8">
      <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
      <title>利用 qrcode 在图片生成二维码</title>
      <style>
        * {
          margin: 0;
          padding: 0;
        }

        #app {
           100%;
          max- 7.5rem;
          margin: 0 auto;
        }

        #Original,
        #Qr {
          display: none;
        }

        #Poster {
          display: block;
           100%;
        }
      </style>
      <script>
        !(function (doc, win) {
          var docEl = document.documentElement,
            resizeEvt =
              "orientationchange" in window ? "orientationchange" : "resize",
            recalc = function () {
              var clientWidth = docEl.clientWidth;
              if (!clientWidth) return;
              if (clientWidth >= 750) {
                docEl.style.fontSize = "100px";
              } else {
                docEl.style.fontSize = 100 * (clientWidth / 750) + "px";
              }
            };

          if (!doc.addEventListener) return;
          window.addEventListener(resizeEvt, recalc, false);
          document.addEventListener("DOMContentLoaded", recalc, false);
        })(document, window);
      </script>
    </head>

    <body>
      <div id="app">
        <canvas id="Original"></canvas>
        <canvas id="Qr"></canvas>
        <img id="Poster" data-src="http">
      </div>
      <script src="./qrcode.min.js"></script>
      <script>
        let img = new Image();
        img.src = './shenxianjiejie.jpg';
        img.onload = function () {
          let original = document.getElementById('Original');
          let context = original.getContext('2d');
          context.save(); // 保存当前环境
          original.setAttribute('width', this.width);
          original.setAttribute('height', this.height);
          // 向画布上绘制图片 
          context.drawImage(this, 0, 0, this.width, this.height);
          // 进行绘制
          context.restore();
          let qr = document.getElementById('Qr');
          // 二维码的内容
          let qrContent = '这里是文字,可以是链接';
          QRCode.toCanvas(qr, qrContent, (error) => {
            if (error) {
              console.error(error)
            }
            let image = new Image();
            image.src = qr.toDataURL('image?png');
            image.onload = function () {
              // 保存已绘制的图片
              context.save();
              // 绘制二维码的位置和大小
              context.drawImage(this, 40, 40, 200, 200);
              // 进行绘制
              context.restore();
              let poster = document.getElementById('Poster')
              poster.setAttribute('src', original.toDataURL('image/png'));
            }
          })
        }
      </script>
    </body>

    </html>

    由于我这里引用是本地图片,所以需要搭建本地服务,我这里在 node 环境下搭建了简单的 express 服务

    const express = require('express')
    const server = express();
    const port = 8496;
    
    server.use(express.static('./'));
    
    server.listen(port, _ => {
      console.log(`http://localhost:${port}`);
    })

    现在运行服务后直接访问 http://localhost:8496/qr.html

  • 相关阅读:
    c++文件对齐
    笔试题——C++开发简单记录错误模块
    dp算法之有代价的最短路径
    Linux虚拟机安装教程
    C++判断回文
    干货 | 10分钟带你掌握branch and price(分支定价)算法超详细原理解析
    干货 | 10分钟教你用column generation求解vehicle routing problems
    干货 | 10分钟带你彻底了解column generation(列生成)算法的原理附java代码
    干货 | 10分钟搞懂branch and bound(分支定界)算法的代码实现附带java代码
    干货 | 10分钟带你全面掌握branch and bound(分支定界)算法-概念篇
  • 原文地址:https://www.cnblogs.com/webBlog-gqs/p/12357323.html
Copyright © 2011-2022 走看看