Как сделать так, чтобы сканер qrcode сканировал только qr-код? - PullRequest
0 голосов
/ 31 мая 2018

Я создаю сканер QR-кода для браузера с помощью этого плагина

https://github.com/cozmo/jsQR

, и он работает нормально, за исключением ошибки, которая делает все ужасным, сканирование клавиш клавиатуры или мой домашний ковриктакже и показывает некоторые китайские иероглифы, почему я выбрал этот плагин, он работает почти во всех браузерах, кроме IOS Chrome, Firefox

Вот мой код

      var video = document.createElement("video");
        var canvasElement = document.getElementById("canvas");
        var canvas = canvasElement.getContext("2d");
        var loadingMessage = document.getElementById("loadingMessage");
        var outputContainer = document.getElementById("output");
        var outputMessage = document.getElementById("outputMessage");
        //var outputData = document.getElementById("outputData");
        //var outputData = document.getElementById("outputData");

        function drawLine(begin, end, color) {
          canvas.beginPath();
          canvas.moveTo(begin.x, begin.y);
          canvas.lineTo(end.x, end.y);
          canvas.lineWidth = 4;
          canvas.strokeStyle = color;
          canvas.stroke();
        }

        // Use facingMode: environment to attemt to get the front camera on phones
        navigator.mediaDevices.getUserMedia({ video: { facingMode: { exact: "environment" } } }).then(function(stream) {
          video.srcObject = stream;
          video.setAttribute("playsinline", true); // required to tell iOS safari we don't want fullscreen
          video.play();
          requestAnimationFrame(tick);
          localStream = stream;
        })
        .catch(function(err) {
            console.log(err);
              /* handle the error */
            loader(false)

        });

        function tick() {
              loadingMessage.innerText = "⌛ Loading video..."
              if (video.readyState === video.HAVE_ENOUGH_DATA) {
                loadingMessage.hidden = true;
                canvasElement.hidden = false;
                outputContainer.hidden = false;

                canvasElement.height = video.videoHeight;
                canvasElement.width = video.videoWidth;
                canvas.drawImage(video, 0, 0, canvasElement.width, canvasElement.height);
                var imageData = canvas.getImageData(0, 0, canvasElement.width, canvasElement.height);
                var code = jsQR(imageData.data, imageData.width, imageData.height);
                if (code) {
                  drawLine(code.location.topLeftCorner, code.location.topRightCorner, "#FF3B58");
                  drawLine(code.location.topRightCorner, code.location.bottomRightCorner, "#FF3B58");
                  drawLine(code.location.bottomRightCorner, code.location.bottomLeftCorner, "#FF3B58");
                  drawLine(code.location.bottomLeftCorner, code.location.topLeftCorner, "#FF3B58");
                  outputMessage.hidden = true;
                  if(code.data != "" && code.data != undefined){
                      var dataQR = "qrData=" + code.data;
                      document.cookie = dataQR;

                      frmAction('serviceid',true,false);
                dataQR)
                      alert(code.data);
                      vidOff();

                  } else {
                      var dataQR = "qrData=";
                      document.cookie = dataQR;
                      document.cookie = "toastMsg=Yes";
                     frmAction('serviceid',true,false);
                      vidOff();

                  }

                } else {    
                  outputMessage.hidden = false;
                }
              }
              requestAnimationFrame(tick);
              function vidOff() {
                    video.pause();
                    video.src = "";
                    video.srcObject.getVideoTracks().forEach(track => track.stop());
                    console.log("camera off");
                }
            }
...