Giter Site home page Giter Site logo

zxing-js / library Goto Github PK

View Code? Open in Web Editor NEW
2.4K 2.4K 535.0 69.7 MB

Multi-format 1D/2D barcode image processing library, usable in JavaScript ecosystem.

Home Page: https://zxing-js.github.io/library/

License: Apache License 2.0

TypeScript 93.59% JavaScript 0.16% Java 6.25%
barcode decoding-images encoding-library hacktoberfest qrcode typescript zxing

library's People

Contributors

0ndorio avatar aleris avatar aryahz avatar dalferth avatar dependabot[bot] avatar frank-dspeed avatar greenkeeper[bot] avatar hithomasmorelli avatar ilinkmat avatar jeroenv avatar jojastahl avatar mikedabrowski avatar mpodlasin avatar nathany avatar neasit avatar nightapes avatar odahcam avatar pimuzzo avatar rikmms avatar rikmms-challenge avatar rybon avatar sam2332 avatar sillyfrog avatar slokhorst avatar suniahk avatar tjieco avatar uppajung avatar vheemstra avatar werthdavid avatar zetoken avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

library's Issues

Bug: Not working with inline image URL

Hey,

I am trying to use this library to decode a QR code rendered on canvas. To achieve that, I use canvas.toDataURL() to encode the QR code in the image URL. This gives us something like this.



We then render the image on page like so.

const img = new Image();
img.height = canvas.height;
img.src = canvas.toDataURL();
img.width = canvas.width;
document.body.appendChild(img);

Finally, we try to decode our QR code.

const reader = new ZXing.BrowserQRCodeReader();
reader.decodeFromImage(img);

Unfortunately, this operation fails with the following error message.

Error
    at FinderPatternFinder.webpackJsonp../node_modules/@zxing/library/esm5/core/qrcode/detector/FinderPatternFinder.js.FinderPatternFinder.selectBestPatterns (FinderPatternFinder.js:546)
    at FinderPatternFinder.webpackJsonp../node_modules/@zxing/library/esm5/core/qrcode/detector/FinderPatternFinder.js.FinderPatternFinder.find (FinderPatternFinder.js:165)
    at Detector.webpackJsonp../node_modules/@zxing/library/esm5/core/qrcode/detector/Detector.js.Detector.detect (Detector.js:66)
    at QRCodeReader.webpackJsonp../node_modules/@zxing/library/esm5/core/qrcode/QRCodeReader.js.QRCodeReader.decode (QRCodeReader.js:63)
    at BrowserQRCodeReader.webpackJsonp../node_modules/@zxing/library/esm5/browser/BrowserCodeReader.js.BrowserCodeReader.readerDecode (BrowserCodeReader.js:254)
    at BrowserQRCodeReader.webpackJsonp../node_modules/@zxing/library/esm5/browser/BrowserCodeReader.js.BrowserCodeReader.decodeOnce (BrowserCodeReader.js:229)
    at BrowserCodeReader.js:180
    at new Promise (<anonymous>)
    at BrowserQRCodeReader.webpackJsonp../node_modules/@zxing/library/esm5/browser/BrowserCodeReader.js.BrowserCodeReader.decodeFromImage (BrowserCodeReader.js:171)
    at index.js:100

If I try to screenshot the rendered <img />, save it to my computer as screenshot.jpg and modify my code as follows...

img.src = 'C:\fakepath\screenshot.jpg'

...we get back this.

{
    format: 11,
    numBits: 288,
    rawBytes: Uint8Array(36) [65, 183, 55, 87, 6, 87, 39, 54, 86, 55, 87, 38, 86, 182, 87, 151, 7, 38, 247, 
70, 86, 55, 70, 86, 70, 86, 70, 151, 64, 236, 17, 236, 17, 236, 17, 236],
    resultMetadata: Map(2) {2 => Array(1), 3 => "H"},
    resultPoints: (4) [FinderPattern, FinderPattern, FinderPattern, AlignmentPattern],
    text: "supersecurekeyprotectededit",
    timestamp: 1533052481452
}

Yay, it works! However, this is not a desired behaviour as we cannot expect the user to download a picture of the canvas on their computer and then upload it again.

Any suggestions how to fix this? I am sure there is a way to achieve what I am trying to do since scanning input from device camera is essentially doing the same thing. Thanks!

Decoding not consistent

Hi,
I have a problem with the decoding of a Qr code image, that i'm passing as a base64 string to the decodeFromImage function, as following

 const codeReader = new BrowserQRCodeReader();
    codeReader.decodeFromImage(undefined, this.state.qrImage)
      .then(
        (result) => { this.showSuccessMessage('The QR is valid!'); console.log(result.getResultMetadata()); }
      )
      .catch(
        () => this.showErrorMessage('The QR is unreadable.')
      );

When I execute this code multiple times on the same image, the result is not consistent. Sometimes the decoding works and it return the correct result, but other times it throws an exception, and prints in the console the following errors

checksum or format error, trying again... Error
    at Decoder.correctErrors (Decoder.js?958e:154)
    at Decoder.decodeBitMatrixParser (Decoder.js?958e:125)
    at Decoder.decodeBitMatrix (Decoder.js?958e:70)
    at QRCodeReader.decode (QRCodeReader.js?680d:64)
    at BrowserQRCodeReader.BrowserCodeReader.readerDecode (BrowserCodeReader.js?0615:254)
    at BrowserQRCodeReader.BrowserCodeReader.decodeOnce (BrowserCodeReader.js?0615:229)

BrowserCodeReader.js?0615:233 true Error
    at Decoder.correctErrors (Decoder.js?958e:154)
    at Decoder.decodeBitMatrixParser (Decoder.js?958e:125)
    at Decoder.decodeBitMatrix (Decoder.js?958e:70)
    at QRCodeReader.decode (QRCodeReader.js?680d:64)
    at BrowserQRCodeReader.BrowserCodeReader.readerDecode (BrowserCodeReader.js?0615:254)
    at BrowserQRCodeReader.BrowserCodeReader.decodeOnce (BrowserCodeReader.js?0615:229)

I wait for an answer. Thank you

ArgumentException: element with id 'video' not found

hello, I encountered a mistake when I set the camera back by default.it is "element with id 'video' not found"ใ€‚Could you help me to see what might be wrong?

html:

component.ts:
getBackVideo() {
const codeReader = new BrowserQRCodeReader();
codeReader.decodeFromInputVideoDevice(undefined, 'video')
.then(result => console.log(result))
.catch(err => console.error(err));
}

Which package to use for production?

Hi Guys,

This is the best scanner in JavaScript i have come across after a long search.
I do have one question, i was using @zxing-js/library the CDN and switched to the npm package.
However i get the message: Deprecated symbol used, consult docs for better alternative.

I presume that i should use the @zxing-js/browser, but because there are no docs yet and it's new i thought that this is more stable.

What do you advise? I am using the BrowserQRCodeReader and the BrowserBarcodeReader from the library. Will the support stay in the library?

Rename repo

Rename repo to <language>-zxing to match common used names by community.

Creating datamatrix module

My company needs in-browser datamatrix scanning asap.

Thus I am starting now to port zxing datamatrix module to ts, based on this project.

Will you be willing to code review it, test and merge it once its ready? Can I expect some help in case I am stuck?

Thanks in advance and have a great day. :)

Drop text-encoding dependency (at least at Browser)

text-encoding is a too heavy dependency, there's no way to support it in browser, server environments are good to go, but it destroys page load times.

Webpack externals option should be used as a first step to achieve that.

Make tests faster

Travis-CI gives a fake positive for build: error because tests time out. Tests need to be faster so any CI can properly test the entire code.

Barcodes of Type UPC-A gets decoded incorrectly

While decoding a barcode of type UPCA, the library adds a extra 0 to the decoded results. So the decoded result has 13 digits instead of 12
Please find the decoded results

{ format:7 numBits:0 rawBytes:null resultMetadata:null resultPoints: [ResultPoint, ResultPoint] text:"0885909934096" timestamp:1536309792565 ... }
screen shot 2018-09-07 at 2 14 15 pm

Add code coverage status

Code is already tested, we just need to integrate Codacy or CodeClimate with TravisCI build pipeline.

1D Scan Barcode from Video Camera demo is broken

Demo on URL https://zxing-js.github.io/library/examples/barcode-camera/ can't find (404) linked script file (index.min.js), therefore i just get additional error ZXing is not defined and nothing works.

Multiple scan Reader

Hi
How i can read barcode and qrcode in at same time?
I must istantiate 2 object or exist a mixed class? Have you an example or a docs page?

No Rear Camera Use in Browser

Device: Pixel 2 XL
Browser: Chrome 67.0.3396.68
OS: Android 8.1.0

Tried both Scan QR Code from Video Camera and Scan Barcode from Image options, toggled dropdown menu that did indicate Camera 0 Front and Camera 1 Rear, Start, Reset, and the rear facing camera would never display in the window to scan from.

I also tried the same thing on a different fork that had the same issue and did not work correctly.

My objective is to scan UPC barcodes with my rear-facing camera.

can't decode image with content beside qrcode

Hi there,

I am trying to implement a function with decode from image. For pics with only pure qrcode, it works great. However when I tried to decode images with other content, it gives me no result.

Unable to import the library in requirejs

I am trying to import this library using require js. But i am unable to do it. At the same location I have other libraries. I am able to import them, but not his library. Is is not possible to load this using requirejs ?

I am using the index.min.js. Please help me to import your library using requirejs

Add yarn.lock

Yarn users are fighting some trouble with dependency versions.

Add special thanks section in README

The porters are the freaking awesome guys that helped us by porting an entire feature from ZXing's source. Some of them are:

Also a contributors link should be added, because they obviously deserve.

continuous scan

hi
following your example
I've succeded in scan a qrcode in html5 webpage.
after the scan successful result, the video camera scan process stops.

how can I make the scan process continuous?

thanks

Add crop functionality to BrowserCodeReader

You often don't want to scan whole picture. In our case datamatrix is really small, so we want to crop and scan only the center of the picture.

I propose to add additional configuration option to BrowserCodeReader allowing to pass crop options to drawImage method: what should be the size of cropped picture and what would be its position in larger picture

Unable to import the library

Hi,

I have installed the library through npm, and now I am trying to import the library in a typescript project by importing the ES6 module:
import { BrowserQRCodeReader, Result } from "@zxing/library";

Typescript compiles my code correctly, but apparently the library doesn't get imported.
At runtime I get a console error in the browser that the module is not found:
Uncaught Error: Cannot find module '@zxing/library'.

Not working with IE 11

The problem seems to be that IE 11 doesn't support Uint8ClampedArray, which is needed in GlobalHistogramBinarizer.ts (and others).

IE 11 not working

I know, the Browser is a pain in the ass but it should work with IE 11 as well

video constraint

hi

is it possible to set the video constraints of the video tag before initialize the camera?
I cannot find any idea about it

thanks

Cannot create a EAN13 barcode reader

I am trying to create a EAN13 barcode reader.
But when i use onst codeReader = new BrowserCodeReader(), the constructor asks for a Reader. But there are no readers for EAN13

Run decoding algorithm in a web worker?

First of all, thank you for this nice module!

I used it in my mobile PWA to show the video stream from the camera in fullscreen and decode a QR code. I also overlay some controls (such as a "Cancel" button) on top of the fullscreen video.

I noticed that while the video is streaming/the library is trying to decode the QR code, the UI becomes a little janky. In order to leave the main thread free, I was thinking of running the decoding algorithm in a web worker. Since I don't know how CPU intensive the QR code decoding algorithm really is, I was looking for some feedback on the idea. Would it improve the overall performance of the library to give such a possibility?

Constant Console Logs

I'm getting constant console logs in both my application, and on the demo site listed in your documentation. Would it be possible to have a verbose mode configuration parameter of some sort to turn these off?

true Error
    at t.selectBestPatterns (FinderPatternFinder.ts:595)
    at t.find (FinderPatternFinder.ts:181)
    at t.detect (Detector.ts:84)
    at t.decode (QRCodeReader.ts:75)
    at e.t.readerDecode (BrowserCodeReader.ts:278)
    at e.t.decodeOnce (BrowserCodeReader.ts:254)

BrowserCodeReader.ts:259 not found, trying again...

Not working in WKWebView/iOS 11 (e.g. Chrome)

Since this library relies on navigator.mediaDevices.getUserMedia and mediaDevices is null in WKWebView browsers, things break.

Notably, Safari is working fine.

It seems to be an Apple Issue and probably nothing can be done here. But I think it should be logged anyhow.

Regards,
Drew

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.