Barcode scanner Monaca Plugin.
This plugin provides a scanning barcode feature. Detect barcode or QR Code1 by device's camera and returns extracted strings.
Normalmode
The detected code is displayed on screen and selected by tapping(clicking).One Shotmode
The first detected code is selected and screen closed automatically.
A Specified message can be displayed if no code is detected for a certain period.
- Cordova 11.0.0 or later
- cordova-android@10.1.2 or later
- cordova-ios@6.2.0 or later
- Android 5.1 or later (9 or later recommended)
- iOS 11 or later (13 or later recommended)
- QR_CODE
- EAN_8
- EAN_13
- ITF
- CODE_128
- CODE_39 and more...
Notes:
- As of ver.1.4.0, we have expanded supported barcode types.
This plugin now scans almost all formats supported by the iOS or Android MKKit. - In additional to the types mentioned above, following types will be scanned.
- CODE_93, AZTEC, DATA_MATRIX, UPC_E, and others.
- Some formats are exclusively supported on iOS.
See here for the caution of detection.
Some devices may fail to detect barcodes. See here for details.
monaca.BarcodeScanner.scan(successCallback, failCallback[, options])
- Calling
scan ()will transition to the scanner screen. - When the barcode is detected, the extracted character string is displayed below the frame.(
Normal mode) - Tap the string to return to the original screen and the string and barcode type will be returned to
successCallback. - In the case of
One Shotmode, the first detected code is returned and screen is closed automatically. - When returned to the original screen without selecting the string, the detection will be cancelled. In order to return to the original screen, click the "Close" (X on the screen) button for iOS and the "Back" button for Android.
successCallback(result)
result: following data
{
data: {
"text": "xxxxxxxx" // detected string
"format": "QR_CODE" // barcode type
},
cancelled: false // detection cancelled(true) or not(false)
}
failCallback(error)
error: error message(string)
| message | description |
|---|---|
| "permission denied" | camera permission is not granted. |
{
"oneShot" : true,
"detectionArea" : {
"width" : 300,
"height" : 200
},
"timeoutPrompt" : {
"show" : true,
"timeout" : 5,
"prompt" : "Not detected"
},
"torch" : {
"enable" : true,
"defaultOn" : false
},
"debug" : {
"preview" : 0
}
}
| parameter | type | default value | description |
|---|---|---|---|
| oneShot | boolean | false | Enable or disable One Shot mode. |
| detectionArea.width | number | Android: 220 / iOS: 240 (iPhone), 320 (iPad) | Detection area width in dp/pt. Minimum 50; no explicit maximum. Android uses dp; iOS uses pt. |
| detectionArea.height | number | Android: 220 / iOS: 240 (iPhone), 320 (iPad) | Detection area height in dp/pt. Minimum 50; no explicit maximum. Android uses dp; iOS uses pt. |
| timeoutPrompt.show | boolean | false | Show or hide detection timeout message. |
| timeoutPrompt.timeout | int | - | Period(in seconds) from when the barcode not detected until the message is displayed. |
| timeoutPrompt.prompt | string | "Barcode not detected" | Timeout message. |
| torch.enable | boolean | false | Enable or disable the torch light. |
| torch.defaultOn | boolean | false | Launch with the torch turned on. |
| debug.preview (android only) |
int | 0 | Displays camera preview bitmap(before sending to MLKit) on screen. 0: OFF(default) 1: Inside detection area 2: Whole camera image |
Note on units and defaults:
- Units: Values are density-independent lengths. Android uses dp; iOS uses pt.
- Bounds: Minimum is 50 (enforced on both iOS/Android). There is no explicit maximum in implementation; avoid specifying values that exceed the visible screen area.
- Defaults: Android uses 220dp; iOS uses 240pt on iPhone and 320pt on iPad.
monaca.BarcodeScanner.scan((result) => {
if (result.cancelled) {
// scan cancelled
} else {
// scan
const detected_text = result.data.text;
const detected_format = result.data.format;
}
}, (error) => {
// permission error
const error_message = error;
}, {
"oneShot" : true,
"timeoutPrompt" : {
"show" : true,
"timeout" : 5,
"prompt" : "Not detected"
},
"torch" : {
"enable" : true,
"defaultOn" : false
}
}); // Large square detection area
monaca.BarcodeScanner.scan((result) => {
console.log("Barcode detected:", result.data.text);
}, (error) => {
console.error("Scan error:", error);
}, {
"detectionArea": {
"width": 300,
"height": 300
}
});
// Rectangle detection area for wide barcodes
monaca.BarcodeScanner.scan((result) => {
console.log("Barcode detected:", result.data.text);
}, (error) => {
console.error("Scan error:", error);
}, {
"detectionArea": {
"width": 350,
"height": 200
},
"oneShot": true
});Since iOS 10, it's mandatory to provide a usage description in the info.plist.
The description string is displayed in the permission dialog box.
This plugin requires the following usage descriptions:
NSCameraUsageDescriptionspecifies the reason for your app to access the device's camera.
To add these entries ito the info.plist, you can use the <edit-config> tag in the config.xml file like this:
<platform name="ios">
<edit-config target="NSCameraUsageDescription" file="*-Info.plist" mode="merge">
<string>need camera access to scan barcode</string>
</edit-config>
</platform>
The library androidx.camera:camera-view used internally requires compileSDKVersion>=31.
To specify the compileSdkVersion in Cordova, you should set android-targetSdkVersion by using the <preference> tag in the config.xml file like this:
<preference name="android-targetSdkVersion" value="31" />
This plugin detects barcodes by processing the image captured by the camera (ImageProxy) and passing it to the barcode detection library (MLKit).
ImageProxy can store images in a variety of formats, and it depends on the device what format the camera captures.
Some devices may fail to detect barcodes because they are captured in a format not supported by the plugin.
| version | supported format |
|---|---|
| before ver.1.2.1 | - Support JPEG or YUV_420_888- Support only when plane buffer's rowStride is same as ImageWidth |
| ver.1.3.0 | - Support when plane buffer's rowStride is different from ImageWidth |
You can check the device compatibility by using the debug preview feature added in ver.1.3.0.
- Enable
debug previewin config
monaca.BarcodeScanner.scan((result) => {
if (result.cancelled) {
// scan cancelled
} else {
// scan
}
}, (error) => {
// permission error
const error_message = error;
}, {
"debug" : {
"preview" : 1
}
});- Thumbnail of the image before barcode detection are displayed on the scan screen.
If this thumbnail image is displayed distorted, it will be a device that does not support.
Ver.1.2.0:
- For iOS, only ITF-14 (14 digits ITF) is supported.
- For Android, various digits ITF is supported.
Ver.1.4.0
- Various digits ITF is supported on iOS.
Caution:
- Because some barcode standard is prone to cause misdetection, requiring the barcode to be exactly positioned within the detection area.
As of May 1, 2024, Apple requires a privacy manifest file to be created for apps and third-party SDKs. The purpose of the privacy manifest file is to explain the data being collected and the reasons for the required APIs it uses. Starting with cordova-ios@7.1.0, APIs are available for configuring the privacy manifest file from config.xml.
As an app developer, it will be your responsibility to identify additional information explaining what your app does with that data.
In this case, you will need to review the "Describing data use in privacy manifests" to understand the list of known NSPrivacyCollectedDataTypes and NSPrivacyCollectedDataTypePurposes.
Also, ensure all four keys—NSPrivacyTracking, NSPrivacyTrackingDomains, NSPrivacyAccessedAPITypes, and NSPrivacyCollectedDataTypes—are defined, even if you are not making an addition to the other items. Apple requires all to be defined.
Additional Resources:
see LICENSE
Footnotes
-
QR Code is a registered trademark of DENSO WAVE INCORPORATED in Japan and in other countries. ↩
