开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 2548|回复: 20
收起左侧

[Web源码] 调用摄像头实时识别二维码

[复制链接]

结帖率:92% (49/53)
发表于 2023-7-29 10:44:49 | 显示全部楼层 |阅读模式   吉林省长春市
分享源码
界面截图: -
是否带模块: -
备注说明: -
[HTML] 纯文本查看 复制代码
<!DOCTYPE html>
<html>
<head>
  <title>QR Code Detection</title>
  <style>
    #video {
      width: 100%;
      max-width: 600px;
    }
  </style>
</head>
<body>
  <h1>QR Code Detection</h1>
  <video id="video" playsinline></video>
  <button>点击扫码</button>

  <script src="jsQR.js"></script>
  <script>
    const video = document.getElementById('video');
    const resultInput = document.createElement('input');
    document.body.appendChild(resultInput);

    let frameCount = 0;
    let timer;

    // 浏览器支持检查
    if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {
      navigator.mediaDevices.getUserMedia({ video: true })
        .then(function(stream) {
          video.srcObject = stream;
          video.play();
        })
        .catch(function(error) {
          console.error('操作用户媒体设备时出错:', error);
        });
    } else {
      console.error('不支持访问用户媒体设备');
    }

    function startQRCodeDetection() {
      timer = setInterval(function() {
        captureFrame();
        frameCount++;
        if (frameCount >= 10) { // 捕获了指定数量的帧后进行二维码识别
          clearInterval(timer);
          detectQRCode();
          frameCount = 0;
        }
      }, 100);
    }

    function captureFrame() {
      const canvas = document.createElement('canvas');
      const context = canvas.getContext('2d');
      canvas.width = video.videoWidth;
      canvas.height = video.videoHeight;
      context.drawImage(video, 0, 0, canvas.width, canvas.height);
      const imageData = context.getImageData(0, 0, canvas.width, canvas.height);
      detectQRCode(imageData);
    }

    function detectQRCode(imageData) {
      const code = jsQR(imageData.data, imageData.width, imageData.height);
      if (code) {
        clearInterval(timer);
        resultInput.value = code.data;
        // 在这里执行二维码识别成功后的操作
        resetTimer();
        showSuccessMessage();
      }
      // else {
      //   resultInput.value = '未能识别二维码';
      // }
    }

    function resetTimer() {
      frameCount = 0;
      timer = setInterval(function() {
        captureFrame();
        frameCount++;
        if (frameCount >= 10) { // 捕获了指定数量的帧后重新开始识别
          clearInterval(timer);
          detectQRCode();
          frameCount = 0;
        }
      }, 100);
    }

    function showSuccessMessage() {
      // 在这里显示识别成功的提示消息
      alert('成功识别二维码!');
    }
  </script>
</body>
</html>



补充内容 (2023-12-4 12:46):
https://github.com/cozmo/jsQR

评分

参与人数 1精币 +1 收起 理由
wa690602724 + 1 感谢分享,很给力!~

查看全部评分


结帖率:92% (49/53)

签到天数: 24 天

 楼主| 发表于 2023-7-29 11:25:02 | 显示全部楼层   吉林省长春市
本帖最后由 空竹 于 2023-7-29 11:36 编辑

<!DOCTYPE html>
<html>
<head>
  <title>QR码识别</title>
  <style>
    #video {
      width: 100%;
      max-width: 600px;
    }
  </style>
</head>
<body>
  <h1>QR码识别</h1>
  <video id="video" playsinline></video>
  <button onclick="startQRCodeDetection()">点击扫码</button>

  <script src="jsQR.js"></script>
  <script>
    const video = document.getElementById('video');
    const resultInput = document.createElement('input');
    document.body.appendChild(resultInput);

    let timer;

    function startQRCodeDetection() {
      if (navigator.mediaDevices && navigator.mediaDevices.getUserMedia) {
        navigator.mediaDevices.getUserMedia({ video: true })
          .then(function (stream) {
            video.srcObject = stream;
            video.play();
            timer = setInterval(function () {
              captureFrame();
            }, 1000);
          })
          .catch(function (error) {
            console.error('操作用户媒体设备时出错:', error);
          });
      } else {
        console.error('不支持访问用户媒体设备');
      }
    }

    function captureFrame() {
      const canvas = document.createElement('canvas');
      const context = canvas.getContext('2d');
      canvas.width = video.videoWidth;
      canvas.height = video.videoHeight;
      context.drawImage(video, 0, 0, canvas.width, canvas.height);
      const imageData = context.getImageData(0, 0, canvas.width, canvas.height);
      detectQRCode(imageData);
    }

    function detectQRCode(imageData) {
      const code = jsQR(imageData.data, imageData.width, imageData.height);
      if (code) {
        resultInput.value = code.data;
        // 在这里执行二维码识别成功后的操作
        clearInterval(timer); // 停止定时器
        showSuccessMessage();
        video.srcObject.getTracks()[0].stop(); // 关闭摄像头
      }
      // else {
      //   resultInput.value = '未能识别二维码';
      // }
    }

    function showSuccessMessage() {
      // 在这里显示识别成功的提示消息
      alert('成功识别二维码!');
    }
  </script>
</body>
</html>

回复 支持 反对

使用道具 举报

结帖率:100% (1/1)

签到天数: 27 天

发表于 2023-12-4 12:11:28 | 显示全部楼层   浙江省宁波市
JS哪里有下啊

点评

Github   吉林省长春市  发表于 2023-12-4 12:44
回复 支持 反对

使用道具 举报

结帖率:92% (49/53)

签到天数: 24 天

 楼主| 发表于 2023-11-26 11:22:40 | 显示全部楼层   吉林省长春市
啊鑫 发表于 2023-11-26 02:28
QRjs 可能是重点代码 没放出来啊啊

这个是Github有的一个库,贴出来就太长了!!!
回复 支持 反对

使用道具 举报

结帖率:0% (0/4)

签到天数: 2 天

发表于 2023-11-26 02:28:39 | 显示全部楼层   浙江省台州市
QRjs 可能是重点代码 没放出来啊啊
回复 支持 反对

使用道具 举报

签到天数: 21 天

发表于 2023-10-31 09:04:36 | 显示全部楼层   山东省临沂市
        感谢分享,很给力!~
回复 支持 反对

使用道具 举报

结帖率:100% (1/1)

签到天数: 1 天

发表于 2023-8-26 16:44:27 | 显示全部楼层   江苏省扬州市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 1 天

发表于 2023-8-9 17:11:11 | 显示全部楼层   湖北省武汉市
学习一下
回复 支持 反对

使用道具 举报

结帖率:99% (68/69)

签到天数: 6 天

发表于 2023-8-1 15:18:32 | 显示全部楼层   福建省宁德市
回复 支持 反对

使用道具 举报

发表于 2023-8-1 09:24:09 | 显示全部楼层   江苏省南京市
虽然用不到,但是分享是传统美德,谢谢分享,大功大德!
回复 支持 反对

使用道具 举报

结帖率:67% (6/9)

签到天数: 17 天

发表于 2023-7-31 23:30:54 | 显示全部楼层   山西省大同市
        支持开源~!感谢分享
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表