【问题标题】:Typescript/Angular2 getUserMedia is not definedTypescript/Angular2 getUserMedia 未定义
【发布时间】:2017-12-29 18:34:06
【问题描述】:

我有一个 Ionic 2 应用程序,它使用 QuaggaJS Github 将相机流式传输到我的视图(Div 容器),如 Snapchat 以扫描 QR 码。在浏览器中,这一切都像一个魅力,但是,当它被构建为 APK 或 IPA 文件时,我得到了错误:

chromium: [INFO:CONSOLE(76955)] "Error: getUserMedia is not defined"

我使用 ADB 和一个虚拟 Android 设备来获取 logcat 输出。 重要信息:是的,我有相机权限!

以防你无法想象我在说什么,这是我的页面视图的屏幕截图:

这是我的打字稿代码:

import { Component, OnInit } from '@angular/core';
import { IonicPage, NavController, NavParams, MenuController } from 'ionic-angular';
import Quagga from 'quagga';
declare var Quagga:any;

@Component({
  selector: 'page-scanner',
  templateUrl: 'scanner.html',
})
export class Scanner implements OnInit {

  constructor(public navCtrl: NavController,
    public navParams: NavParams,
    public menu: MenuController) {
  }
   ngOnInit() {
     //WARNING:
     //Error: Types of property 'lift' are incompatible -> means
     //that the used typescript version is too high. Works with: 2.3.4 atm

     Quagga.init({
         inputStream : {
             name : "Live",
             type : "LiveStream",
             constraints: {
               width:  window.innerWidth,
               height: window.innerHeight,
               facingMode: "environment"
             },
             area: {
                top: "0%",
                right: "0%",
                left: "0%",
                bottom: "0%"
            },
            // Or '#yourElement' (optional)
           target: document.querySelector('#scanner')
         },
         locator: {
           patchSize: "medium",
           halfSample: true
         },
         numOfWorkers: (navigator.hardwareConcurrency ? navigator.hardwareConcurrency : 4),
         decoder : {
          //Change Reader for the right Codes
          readers: [ "code_128_reader",
                     "ean_reader",
                     "ean_8_reader",
                     "code_39_reader",
                     "code_39_vin_reader",
                     "codabar_reader",
                     "upc_reader",
                     "upc_e_reader",
                     "i2of5_reader" ],
         },
         locate: true
       }, function(err) {
           if (err) {
               console.log(err);
               return
           }
           console.log("Initialization finished. Ready to start");
           Quagga.start();
       });
       // Make sure, QuaggaJS draws frames an lines around possible
        // barcodes on the live stream
        Quagga.onProcessed(function(result) {
            var drawingCtx = Quagga.canvas.ctx.overlay,
                drawingCanvas = Quagga.canvas.dom.overlay;

            if (result) {
                if (result.boxes) {
                    drawingCtx.clearRect(0, 0, parseInt(drawingCanvas.getAttribute("width")), parseInt(drawingCanvas.getAttribute("height")));
                    result.boxes.filter(function (box) {
                        return box !== result.box;
                    }).forEach(function (box) {
                        Quagga.ImageDebug.drawPath(box, {x: 0, y: 1}, drawingCtx, {color: "green", lineWidth: 2});
                    });
                }

                if (result.box) {
                    Quagga.ImageDebug.drawPath(result.box, {x: 0, y: 1}, drawingCtx, {color: "#00F", lineWidth: 2});
                }

                if (result.codeResult && result.codeResult.code) {
                    Quagga.ImageDebug.drawPath(result.line, {x: 'x', y: 'y'}, drawingCtx, {color: 'red', lineWidth: 3});
                }
            }
        });
      // Once a barcode had been read successfully, stop quagga and
      // close the modal after a second to let the user notice where
      // the barcode had actually been found.
      Quagga.onDetected(function(result) {
        if (result.codeResult.code){
        // Was passieren soll wenn ein Code gescannt wurde
        //  $('#scanner_input').val(result.codeResult.code);
        }
      });
   }
   ionViewWillLeave(){
     Quagga.stop();
   }
}

【问题讨论】:

    标签: javascript angular typescript ionic-framework quaggajs


    【解决方案1】:

    来自here 声明:

    1) 重要提示:在大多数情况下,访问 getUserMedia 需要一个安全的来源 浏览器,这意味着 http:// 只能在 localhost 上使用。全部 其他主机名需要通过 https:// 提供。你可以找到更多 信息在Chrome M47 WebRTC Release Notes

    getUserMedia 的特征检测

    2) 每个浏览器似乎都以不同的方式实现 mediaDevices.getUserMedia API。因此强烈推荐 在您的项目中包含 webrtc-adapter。

    以下是测试浏览器功能的方法:

    3) if (navigator.mediaDevices && typeof navigator.mediaDevices.getUserMedia === 'function') { // 安全 访问navigator.mediaDevices.getUserMedia } 以上条件 评估为:

    浏览器结果
    边缘真
    铬真正
    真正的火狐
    IE 11 错误
    Safari iOS 错误

    你也可以:

    1. 确认您是否使用https
    2. 你已加入webrtc-adapter
    3. Android 是否通过条件检查。

    MediaDevices.getUserMedia from MDN上为其他人提供链接

    【讨论】:

    • 我按照你说的做了,但我总是收到错误:TypeError: Cannot call method 'enumerateDevices' of undefined。未定义的手段 = mediaDevices。因为这是触发错误的代码行:navigator.mediaDevices.enumerateDevices();。所以在包含 webrtc 之后,我的 Ionic 2 项目仍然找不到 mediaDevices 或 getUserMedia。
    • 信息:向离子论坛添加问题:forum.ionicframework.com/t/…
    • 那个 webrtc 项目应该创建 shims .. 您问题中的 Chrome 消息.. 是来自 Android 设备,还是通过您的开发机器上的 Chrome?只有这是应该启用功能供您使用的代码。 github.com/webrtc/adapter/blob/master/src/js/chrome/…
    • 我自己解决了我的问题。看看答案。
    【解决方案2】:

    嗯,这可能是我写过的最垃圾的答案,但我自己解决了我的问题。 有时最简单的事情是奇怪错误的原因。

    正如它所说的 here getUserMedia() 在 Android 5.0+ 上可用, 但我一直在 Android 4.4.2 设备上工作。更新后一切正常。

    此版本引入了 PermissionRequest 类,该类允许您的应用授予 WebView 访问受保护资源(如相机和麦克风)的权限, 通过网络 API,例如 getUserMedia()。您的应用必须对这些资源具有适当的 Android 权限才能将权限授予 WebView。

    我从来没有像这个错误那样浪费了 3 天的时间。 干杯

    【讨论】:

    • @JGFMK 不管怎样,我要感谢你的帮助,并以 50 个代表为荣。干杯
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-09-24
    • 2016-08-21
    • 2016-09-12
    • 1970-01-01
    相关资源
    最近更新 更多