fix: try to use rear camera by default

pull/23/head
yugasun 3 years ago
parent 8c80e312b3
commit 7d77236fc0

2
.gitignore vendored

@ -9,3 +9,5 @@ tsconfig.tsbuildinfo
coverage coverage
yarn.lock yarn.lock
.rpt2_cache .rpt2_cache
demo/lib/index.min.js

@ -1,45 +1,48 @@
<!DOCTYPE html> <!DOCTYPE html>
<html> <html>
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
<title>QrcodeDecoder - Camera</title>
</head>
<body>
<button id="start">Start</button> <button id="stop">Stop</button><br />
<span id="result">Click start to scan qrcode.</span><br />
<hr />
<video id="video" autoplay></video>
<script src="./lib/vconsole.min.js"></script> <head>
<script src="./index.min.js"></script> <meta charset="UTF-8" />
<script type="text/javascript"> <meta name="viewport" content="width=device-width, initial-scale=1.0" />
var vConsole = new VConsole(); <meta http-equiv="X-UA-Compatible" content="ie=edge" />
console.log('Hello world'); <title>QrcodeDecoder - Camera</title>
function main() { </head>
var qr = new QrcodeDecoder();
var video = document.querySelector('#video');
var start = document.querySelector('#start');
var stop = document.querySelector('#stop');
var result = document.querySelector('#result');
async function startScan() {
if (!qr.isCanvasSupported()) {
alert("Your browser doesn't match the required specs.");
throw new Error('Canvas and getUserMedia are required');
}
let code = await qr.decodeFromCamera(video); <body>
console.log('code', code); <button id="start">Start</button> <button id="stop">Stop</button><br />
result.innerText = 'Result: ' + code.data; <span id="result">Click start to scan qrcode.</span><br />
<hr />
<video id="video" autoplay></video>
<script src="./lib/vconsole.min.js"></script>
<script src="./lib/index.min.js"></script>
<script type="text/javascript">
var vConsole = new VConsole();
console.log('Hello world');
function main() {
var qr = new QrcodeDecoder();
var video = document.querySelector('#video');
var start = document.querySelector('#start');
var stop = document.querySelector('#stop');
var result = document.querySelector('#result');
async function startScan() {
if (!qr.isCanvasSupported()) {
alert("Your browser doesn't match the required specs.");
throw new Error('Canvas and getUserMedia are required');
} }
start.onclick = startScan;
stop.onclick = function() { let code = await qr.decodeFromCamera(video);
qr.stop(); console.log('code', code);
}; result.innerText = 'Result: ' + code.data;
} }
main(); start.onclick = startScan;
</script>
</body> stop.onclick = function () {
qr.stop();
};
}
main();
</script>
</body>
</html> </html>

@ -1,64 +1,66 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en"> <html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
<title>QrcodeDecoder - Image</title>
</head>
<body>
<section>
<h3>Same domain image</h3>
<img id="img1" src="./assets/qrcode.png" alt="qr code" /><br />
<button id="decode1">Decode!</button><br />
<span id="result1"></span><br />
</section>
<hr />
<section>
<h3>Different domain image</h3>
<input
id="img2"
value="https://yugasun.com/static/wechat.jpg"
style="width: 400px"
/><br />
<button id="decode2">Decode!</button><br />
<span id="result2"></span><br />
</section>
<script src="./lib/vconsole.min.js"></script>
<script src="./index.min.js"></script>
<script type="module">
var vConsole = new VConsole();
function main() {
var qr = new QrcodeDecoder();
var btn1 = document.querySelector('button#decode1'); <head>
var btn2 = document.querySelector('button#decode2'); <meta charset="UTF-8" />
var result1 = document.querySelector('#result1'); <meta name="viewport" content="width=device-width, initial-scale=1.0" />
var result2 = document.querySelector('#result2'); <meta http-equiv="X-UA-Compatible" content="ie=edge" />
var img1 = document.querySelector('#img1'); <title>QrcodeDecoder - Image</title>
var img2 = document.querySelector('#img2'); </head>
btn1.onclick = async () => { <body>
// you can also decode from image path <section>
// const code = await qr.decodeFromImage('./assets/qrcode.png'); <h3>Same domain image</h3>
const code = await qr.decodeFromImage(img1); <img id="img1" src="./assets/qrcode.png" alt="qr code" /><br />
console.log(code); <button id="decode1">Decode!</button><br />
result1.innerText = code.data; <span id="result1"></span><br />
}; </section>
<hr />
<section>
<h3>Different domain image</h3>
<input
id="img2"
value="https://yugasun.com/static/wechat.jpg"
style="width: 400px" /><br />
<button id="decode2">Decode!</button><br />
<span id="result2"></span><br />
</section>
<script src="./lib/vconsole.min.js"></script>
<script src="./lib/index.min.js"></script>
<script type="module">
var vConsole = new VConsole();
function main() {
var qr = new QrcodeDecoder();
btn2.onclick = async () => { var btn1 = document.querySelector('button#decode1');
// you can also decode from image path var btn2 = document.querySelector('button#decode2');
// const code = await qr.decodeFromImage('./assets/qrcode.png'); var result1 = document.querySelector('#result1');
const code = await qr.decodeFromImage(img2.value, { var result2 = document.querySelector('#result2');
crossOrigin: 'anonymous', var img1 = document.querySelector('#img1');
}); var img2 = document.querySelector('#img2');
console.log(code);
result2.innerText = code.data; btn1.onclick = async () => {
}; // you can also decode from image path
} // const code = await qr.decodeFromImage('./assets/qrcode.png');
window.onload = () => { const code = await qr.decodeFromImage(img1);
main(); console.log(code);
result1.innerText = code.data;
};
btn2.onclick = async () => {
// you can also decode from image path
// const code = await qr.decodeFromImage('./assets/qrcode.png');
const code = await qr.decodeFromImage(img2.value, {
crossOrigin: 'anonymous',
});
console.log(code);
result2.innerText = code.data;
}; };
</script> }
</body> window.onload = () => {
main();
};
</script>
</body>
</html> </html>

1
demo/index.min.js vendored

File diff suppressed because one or more lines are too long

@ -1,43 +1,45 @@
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en"> <html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatible" content="ie=edge" />
<title>QrcodeDecoder - Video</title>
</head>
<body>
<button id="start">Start</button> <button id="stop">Stop</button><br />
<span id="result">Click start to scan qrcode.</span><br />
<video src="./assets/qrcode-video.mp4"></video> <head>
<script src="./lib/vconsole.min.js"></script> <meta charset="UTF-8" />
<script src="./index.min.js"></script> <meta name="viewport" content="width=device-width, initial-scale=1.0" />
<script type="text/javascript"> <meta http-equiv="X-UA-Compatible" content="ie=edge" />
var vConsole = new VConsole(); <title>QrcodeDecoder - Video</title>
console.log('Hello world'); </head>
function main() {
var video = document.querySelector('video');
var result = document.querySelector('#result');
var start = document.querySelector('#start');
var stop = document.querySelector('#stop');
var qr = new QrcodeDecoder();
start.onclick = startScan; <body>
<button id="start">Start</button> <button id="stop">Stop</button><br />
<span id="result">Click start to scan qrcode.</span><br />
stop.onclick = function() { <video src="./assets/qrcode-video.mp4"></video>
qr.stop(); <script src="./lib/vconsole.min.js"></script>
video.pause(); <script src="./lib/index.min.js"></script>
}; <script type="text/javascript">
var vConsole = new VConsole();
function main() {
var video = document.querySelector('video');
var result = document.querySelector('#result');
var start = document.querySelector('#start');
var stop = document.querySelector('#stop');
var qr = new QrcodeDecoder();
async function startScan() { start.onclick = startScan;
video.play();
const code = await qr.decodeFromVideo(video); stop.onclick = function () {
console.log('code', code); qr.stop();
result.innerText = 'Result: ' + code.data; video.pause();
} };
async function startScan() {
video.play();
const code = await qr.decodeFromVideo(video);
console.log('code', code);
result.innerText = 'Result: ' + code.data;
} }
main(); }
</script> main();
</body> </script>
</body>
</html> </html>

@ -11,9 +11,10 @@
"prettier:fix": "prettier --write '**/*.{ts,tsx,md}' --config .prettierrc", "prettier:fix": "prettier --write '**/*.{ts,tsx,md}' --config .prettierrc",
"test": "jest", "test": "jest",
"codecov": "jest --coverage && codecov", "codecov": "jest --coverage && codecov",
"copy-file": "cp dist/index.min.js demo/", "copy-file": "cp dist/index.min.js demo/lib",
"release": "git commit -am $npm_package_version && git tag $npm_package_version && git push && git push --tags", "release": "git commit -am $npm_package_version && git tag $npm_package_version && git push && git push --tags",
"pages": "gh-pages -d demo --remote origin" "pages": "gh-pages -d demo --remote origin",
"demo": "http-server demo -c-1"
}, },
"husky": { "husky": {
"hooks": { "hooks": {
@ -56,6 +57,7 @@
"cross-env": "^6.0.3", "cross-env": "^6.0.3",
"fancy-log": "^1.3.3", "fancy-log": "^1.3.3",
"gh-pages": "^3.1.0", "gh-pages": "^3.1.0",
"http-server": "^14.1.0",
"husky": "^3.0.9", "husky": "^3.0.9",
"jest": "^24.9.0", "jest": "^24.9.0",
"lint-staged": "^9.5.0", "lint-staged": "^9.5.0",

@ -20,16 +20,6 @@ const plugins: rollup.Plugin[] = [
commonjs(), commonjs(),
typescript2({ typescript2({
tsconfig: path.join(__dirname, '..', 'tsconfig.json'), tsconfig: path.join(__dirname, '..', 'tsconfig.json'),
typescript: ts, // ensure we're using the same typescript (3.x) for rollup as for regular builds etc
tsconfigOverride: {
module: 'esnext',
stripInternal: true,
emitDeclarationOnly: false,
composite: false,
declaration: false,
declarationMap: false,
sourceMap: false,
},
}), }),
]; ];
@ -77,7 +67,7 @@ async function bundleAio() {
uglify({ uglify({
compress: { compress: {
drop_debugger: true, drop_debugger: true,
drop_console: true, drop_console: false,
}, },
}), }),
], ],
@ -86,7 +76,7 @@ async function bundleAio() {
file: 'dist/index.min.js', file: 'dist/index.min.js',
name: 'QrcodeDecoder', name: 'QrcodeDecoder',
format: 'iife', format: 'iife',
sourcemap: false, sourcemap: true,
}); });
} }

@ -19,7 +19,8 @@ class QrcodeDecoder {
this.videoElem = null; this.videoElem = null;
this.getUserMediaHandler = null; this.getUserMediaHandler = null;
this.videoConstraints = { this.videoConstraints = {
video: true, // default use rear camera
video: { facingMode: { exact: 'environment' } },
audio: false, audio: false,
}; };
@ -160,10 +161,23 @@ class QrcodeDecoder {
throw new Error("Couldn't get video from camera"); throw new Error("Couldn't get video from camera");
} }
let stream: MediaStream;
try { try {
const stream = await navigator.mediaDevices.getUserMedia( stream = await navigator.mediaDevices.getUserMedia(this.videoConstraints);
this.videoConstraints, } catch (e) {
); if ((e as OverconstrainedError).name === 'OverconstrainedError') {
console.log('[OverconstrainedError] Can not use rear camera.');
stream = await navigator.mediaDevices.getUserMedia({
video: true,
audio: false,
});
} else {
throw e;
}
}
if (stream) {
videoElem.srcObject = stream; videoElem.srcObject = stream;
// videoElem.src = window.URL.createObjectURL(stream); // videoElem.src = window.URL.createObjectURL(stream);
this.videoElem = videoElem; this.videoElem = videoElem;
@ -171,8 +185,6 @@ class QrcodeDecoder {
const code = await this.decodeFromVideo(videoElem, opts); const code = await this.decodeFromVideo(videoElem, opts);
return code; return code;
} catch (e) {
throw e;
} }
} }

Loading…
Cancel
Save