NOTE! THIS MODULE HAVE BEEN DEPRECATED ABOVE NATIVE VERSIONS 5.0.0 AND ABOVE! PLEASE USE THE NATIVE COUNTERPART!
Smartface Barcode Extension can be installed via npm easily from our public npm repository. Execute this command on your scripts directory:
yarn add @smartface/extension-barcode
- Import extension with
import { BarcodeScanner } from "@smartface/extension-barcode";
- Create an instance of
BarcodeScanner
. Result will be handled inonResult
callback.
const barcodeScanner = new BarcodeScanner({
layout: myFlexLayout, // Required
width: 200, // Required
height: 200, // Required
});
barcodeScanner.on(BarcodeScanner.Events.Result, ({ barcode }) => {
let { text, format } = barcode;
alert(text);
barcodeScanner.stopCamera();
barcodeScanner.hide();
})
- Finally call
show
method with no parameters. Camera permissions must be granted before runningshow
method.
barcodeScanner.show();
Supported Formats:
Barcode.FormatType.AZTEC
Barcode.FormatType.CODABAR
Barcode.FormatType.CODE_39
Barcode.FormatType.CODE_93
Barcode.FormatType.CODE_128
Barcode.FormatType.DATA_MATRIX
Barcode.FormatType.EAN_8
Barcode.FormatType.EAN_13
Barcode.FormatType.ITF
Barcode.FormatType.MAXICODE
Barcode.FormatType.PDF_417
Barcode.FormatType.QR_CODE
Barcode.FormatType.RSS_14
Barcode.FormatType.RSS_EXPANDED
Barcode.FormatType.UPC_A
Barcode.FormatType.UPC_E
Barcode.FormatType.UPC_EAN_EXTENSION
Barcode format can be retrieved like this.
import { BarcodeScanner } from "@smartface/extension-barcode";
barcodeScanner.onResult = ({ barcode }) => {
if (barcode.format === BarcodeScanner.Format.QR_CODE) {
console.log("This is a qr code");
}
};
barcodeScanner.on(BarcodeScanner.Events.Result, ({ barcode }) => {
if (barcode.format === BarcodeScanner.Format.QR_CODE) {
console.log("This is a qr code");
}
})
- If there is a need for closing the scanner, it needs to be implemented by the developer. For Android onBackButtonPressed needs to be implemented.
- Scanner does not hide automatically when scanned
- A scanner instance can be used only for once per image scan. For each scan action, a new
BarcodeScanner
instance should be created and used - For Android, if there is an active textbox (keyboard is visible), developer needs to close the keyboard before showing the scanner.
- It is advised to call
show
method with a timeout value for rendering performance.
For iOS, you have to add camera permission to Info.plist.
<key>NSCameraUsageDescription</key>
<string>${PRODUCT_NAME} Camera Usage</string>
For Android, you have to add camera permission to AndroidManifest.xml.
<uses-permission android:name="android.permission.CAMERA" />
<uses-feature android:name="android.hardware.camera" />
<uses-feature android:name="android.hardware.camera.autofocus" />
There are some examples in sample folder. You can use them.
This barcode library is based on:
Please submit an issue on GitHub and provide information about your problem.
We are committed to making participation in this project a harassment-free experience for everyone, regardless of the level of experience, gender, gender identity and expression, sexual orientation, disability, personal appearance, body size, race, ethnicity, age, religion, or nationality. Please read and follow our Code of Conduct.
This project is licensed under the terms of the MIT license. See the LICENSE file. Within the scope of this license, all modifications to the source code, regardless of the fact that it is used commercially or not, shall be committed as a contribution back to this repository.