我有一个Ionic 2应用程序使用QuaggaJS Github将相机流式传输到我的View(Div容器),如Snapchat扫描QR码。在浏览器中,它都像魅力一样,但是当它被构建为APK或IPA文件的那一刻我得到了错误:
chromium: [INFO:CONSOLE(76955)] "Error: getUserMedia is not defined"
我使用ADB和Virutal Android设备来获取logcat输出。 重要信息:是的我有相机权限!
这是我的Typescript代码:
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();
}
}
答案 0 :(得分: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
} 以上条件 评估为:浏览器结果
边缘真实 Chrome真实的 Firefox真实的 IE 11假
Safari iOS错误
你也可以:
答案 1 :(得分:0)
这可能是我写过的最直接的答案,但我自己解决了问题。 有时最简单的事情就是出现奇怪错误的原因。
因为它表明here getUserMedia()在Android 5.0 + 上可用, 但我一直在Android 4.4.2设备上工作。更新后一切正常。
此版本引入了PermissionRequest类,允许您的应用授予WebView 权限,以访问受保护的资源,例如摄像头和麦克风, 通过web API,例如getUserMedia()。您的应用必须拥有这些资源的相应Android权限才能授予WebView权限。
我从来没有浪费过3天这个错误。 干杯