A Vue.js component, accessing the device camera and allowing users to read barcodes, within the browser
npm install vue-cc-quaggajsquaggajs 's wrapper for Vue.js
`` bash`
npm i vue-cc-quaggajs
`vue
`Usage
`js
function () {
Quagga.init(this.quaggaState, function (err) {
if (err) {
return console.log(err);
}
Quagga.start();
});
Quagga.onDetected(this.onDetected ? this.onDetected : this._onDetected);
Quagga.onProcessed(this.onProcessed ? this.onProcessed : this._onProcessed);
}
`
`js
function () {
Quagga.stop();
this.init();
}
`
`js
function () {
const canvas = Quagga.canvas.dom.image;
return canvas.toDataURL();
}
`
Reference: Quagga.onDetected(callback)
default function:
`js`
function (result) {
console.log('detected: ', result);
}
Reference: Quagga.onProcessed(callback)
default function:
`js
function (result) {
let 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});
}
}
},
`
Set reading barcode type.
Reference: https://github.com/serratus/quaggaJS#decoder
default: [{
format: 'code_128_reader',
config: {}
}]
Set reader size. it affects
default:
`js`
{
width: 640,
height: 480,
}
`
``