HTML5获取摄像头和视频控制接口进行扫描二维码

前言:以下是在vue环境实现调用摄像头进行扫描二维码并且返回二维码链接的一个操作,在html文件也是可以调用的,只不过修改进行相应的修改。


完整示例及jsQR.js下载地址:https://download.csdn.net/download/qq_34227291/12687965


代码:

<template>
  <div>
    <div class="demo-wrapper">
      <video id="video" width="640" height="480" autoplay="" playsinline muted></video>
      <canvas id="mycanvas" width="640" height="480"></canvas>
    </div>
  </div>
</template>

<script>
  import jsQR from "@/assets/js/jsQR.js"
  export default {
    data() {
      return {
        state: ''
      }
    },
    mounted() {
      this.setVideo();
    },
    methods: {
      setVideo() {
        let c = '';
        let stop = false;
        let oid = new URL(window.location.href).searchParams.get('oid');
        let did = '';
        let wix = '';
        let second = false;
        let video = document.querySelector('video');
        let canvas = document.createElement('canvas');
        let ctx = canvas.getContext('2d');
        console.log(video)

        video.addEventListener('loadedmetadata', function() {
          canvas.width = video.videoWidth;
          canvas.height = video.videoHeight;
        });
        video.addEventListener('play', function() {
          let setTime = setInterval(function() {
            if (stop) {
              return;
            }
            ctx.drawImage(video, 0, 0);
            let imgData = ctx.getImageData(0, 0, canvas.width, canvas.height);
            const code = jsQR(imgData.data, imgData.width, imgData.height);
            console.log(code)
            if (code) {
              this.state = code.data;
              console.log(this.state)
              console.log('停止扫描')
              clearInterval(setTime)
            }
          }, 0);
        }, );

        navigator.mediaDevices.getUserMedia({
            audio: false,
            video: {
              facingMode: ("environment")
            }
          })
          .then(stream => {
            console.log(stream)
            video.srcObject = stream;
          })
          .catch(e => {
            alert('加载相机失败:\n' + e);
          });
        // console.log(navigator.mediaDevices.getUserMedia)
      }
    }
  }
</script>
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值