Html Instascan选择camara以扫描qr
我的网站使用手机读取二维码。我用过那个图书馆 然后,我想启动扫描仪到用户选择的卡马拉,因为我想获得二维码:Html Instascan选择camara以扫描qr,html,qr-code,Html,Qr Code,我的网站使用手机读取二维码。我用过那个图书馆 然后,我想启动扫描仪到用户选择的卡马拉,因为我想获得二维码: <script type="text/javascript"> let scanner = new Instascan.Scanner({ video: document.getElementById('preview'),mirror: false }); scanner.addListener('scan', function (
<script type="text/javascript">
let scanner = new Instascan.Scanner({ video: document.getElementById('preview'),mirror: false });
scanner.addListener('scan', function (content) {
alert("qr result " + content);
});
Instascan.Camera.getCameras().then(function (cameras) {
if (cameras.length > 0) {
scanner.start(cameras[0]); //I want to scanner.start the camara that the user has selected.
} else {
console.error('No cameras found.');
}
}).catch(function (e) {
console.error(e);
});
</script>
let scanner=new Instascan.scanner({video:document.getElementById('preview'),mirror:false});
scanner.addListener('scan',函数(内容){
警报(“qr结果”+内容);
});
Instascan.Camera.getCameras().then(函数(摄像头){
如果(摄影机长度>0){
scanner.start(cameras[0]);//我想要scanner.start启动用户选择的camara。
}否则{
控制台。错误('未找到摄像头');
}
}).catch(函数(e){
控制台错误(e);
});
那么,有什么问题吗?我不知道如何将用户选择的camara传递到:scanner.start(cameras[0]);
'use strict';
var videoElement = document.querySelector('video');
var videoSelect = document.querySelector('select#videoSource');
videoSelect.onchange = getStream;
getStream().then(getDevices).then(gotDevices);
function getDevices() {
// AFAICT in Safari this only gets default devices until gUM is called :/
return navigator.mediaDevices.enumerateDevices();
}
function gotDevices(deviceInfos) {
window.deviceInfos = deviceInfos; // make available to console
console.log('Available input and output devices:', deviceInfos);
for (const deviceInfo of deviceInfos) {
const option = document.createElement('option');
option.value = deviceInfo.deviceId;
if (deviceInfo.kind === 'videoinput') {
option.text = deviceInfo.label || `Camera ${videoSelect.length + 1}`;
videoSelect.appendChild(option);
}
}
}
function getStream() {
if (window.stream) {
window.stream.getTracks().forEach(track => {
track.stop();
});
}
const videoSource = videoSelect.value;
const constraints = {
video: {deviceId: videoSource ? {exact: videoSource} : undefined}
};
return navigator.mediaDevices.getUserMedia(constraints).
then(gotStream).catch(handleError);
}
function gotStream(stream) {
window.stream = stream; // make stream available to console
videoSelect.selectedIndex = [...videoSelect.options].
findIndex(option => option.text === stream.getVideoTracks()[0].label);
videoElement.srcObject = stream;
}
function handleError(error) {
console.error('Error: ', error);
}
<script type="text/javascript">
let scanner = new Instascan.Scanner({ video: document.getElementById('preview'),mirror: false });
scanner.addListener('scan', function (content) {
alert("qr result " + content);
});
Instascan.Camera.getCameras().then(function (cameras) {
if (cameras.length > 0) {
scanner.start(cameras[0]); //I want to scanner.start the camara that the user has selected.
} else {
console.error('No cameras found.');
}
}).catch(function (e) {
console.error(e);
});
</script>