BarcodeReader for Images
A low-level barcode reader that processes still images and return barcode results. The following code snippet shows its basic usage.
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
let results = await reader.decode(imageSource);
for(let result of results){
console.log(result.barcodeText);
}
API Index
Create and Destroy Instances
API Name | Description |
---|---|
createInstance() | Creates a BarcodeReader instance. |
destroyContext() | Destroies the BarcodeReader instance. |
isContextDestroyed() | Indicates whether the instance has been destroyed. |
Decode Barcodes
API Name | Description |
---|---|
decode() | Decodes barcodes from an image. |
decodeBase64String() | Decodes barcodes from a base64-encoded image (with or without MIME). |
decodeUrl() | Decodes barcodes from an image specified by its URL. |
decodeBuffer() | Decodes barcodes from raw image data. |
Decode Barcodes on multiple images from an Image Source
API Name | Description |
---|---|
setImageSource | Sets an image source for continous scanning. |
onUniqueRead | This event is triggered when a new, unduplicated barcode is found. |
onImageRead | This event is triggered after the library finishes scanning an image. |
startScanning() | Starts continuous scanning of incoming images. |
stopScanning() | Stops continuous scanning. |
pauseScanning() | Pause continuous scanning but keep the video stream. |
resumeScanning() | Resumes continuous scanning. |
getScanSettings() | Returns the current scan settings. |
updateScanSettings() | Changes scan settings with the object passed in. |
Change Settings
API Name | Description |
---|---|
getRuntimeSettings() | Returns the current runtime settings. |
updateRuntimeSettings() | Updates runtime settings with a given struct or a preset template. |
resetRuntimeSettings() | Resets all parameters to default values. |
outputRuntimeSettingsToString() | Return the current RuntimeSettings in the form of a string. |
getModeArgument() | Returns the argument value for the specified mode parameter. |
setModeArgument() | Sets the argument value for the specified mode parameter. |
Auxiliary
API Name | Description |
---|---|
ifSaveOriginalImageInACanvas | Whether to save the original image into a <canvas> element. |
getOriginalImageInACanvas() | Returns an HTMLCanvasElement that holds the original image. |
createInstance
Creates a BarcodeReader
instance.
static createInstance(): Promise<BarcodeReader>
Return Value
A promise resolving to the created BarcodeReader
object.
Code Snippet
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
destroyContext
Destroies the BarcodeReader
instance. If your page needs to create new instances from time to time, don’t forget to destroy unused old instances.
destroyContext(): void
Code Snippet
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
// ... decode ...
reader.destroyContext();
isContextDestroyed
Returns whether the instance has been destroyed.
isContextDestroyed(): boolean
decode
Decodes barcodes from an image.
decode(source: Blob | Buffer | ArrayBuffer | Uint8Array | Uint8ClampedArray | HTMLImageElement | HTMLCanvasElement | HTMLVideoElement | string): Promise<TextResult[]>
Parameters
source
: specifies the image to decode. The supported image formats include png
, jpeg
, bmp
, gif
and a few others (some browsers support webp
, tif
). Also note that the image can be specified in a lot of ways including binary data, base64 string (with MIME), URL, etc.
To speed up the reading, the image will be scaled down when it exceeds a size limit either horizontally or vertically. The limit is 2048 pixels on mobile devices and 4096 on other devices.
If the content in the binary data is raw img data, such as
RGBA
, please refer to decodeBuffer().
Return Value
A promise resolving to a TextResult\[\]
object that contains all the barcode results found in this image.
Code Snippet
let results1 = await reader.decode(blob);
let results2 = await reader.decode(htmlImageElement);
let results3 = await reader.decode(url);
let results4 = await reader.decode(strBase64WithMime); // like `************`
You can even use an HTMLVideoElement
as the source. If the video is playing, the current frame will be decoded.
let results;
try{
// The current frame will be decoded.
results = await reader.decode(htmlVideoElement);
}catch(ex){
// If there is no frame in the video, throw an exception.
}
See Also
- Blob
- Buffer
- ArrayBuffer
- Uint8Array
- Uint8ClampedArray
- HTMLImageElement
- HTMLCanvasElement
- HTMLVideoElement
- TextResult
decodeBase64String
Decodes barcodes from a base64-encoded image (with or without MIME).
decodeBase64String(base64Str: string): Promise<TextResult[]>
Parameters
base64Str
: specifies the image represented by a string.
Return Value
A promise resolving to a TextResult\[\]
object that contains all the barcode results found in this image.
Code Snippet
let results = await reader.decodeBase64String(strBase64); //e.g. `....` or `Xfjshekk...`.
for(let result of results){
console.log(result.barcodeText);
}
See Also
decodeUrl
Decodes barcodes from an image specified by its URL. Note that the image should either be from the same domain or has the ‘Access-Control-Allow-Origin’ header set to allow access from your current domain.
decodeUrl(url: string): Promise<TextResult[]>
Parameters
url
: specifies the image by its URL.
Return Value
A promise resolving to a TextResult\[\]
object that contains all the barcode results found in this image.
Code Snippet
let results = await reader.decodeUrl("https://www.yourdomain.com/imageWithBarcodes.png");
for(let result of results){
console.log(result.barcodeText);
}
See Also
decodeBuffer
Decodes barcodes from raw image data. It is an advanced API, if you don’t know what you are doing, use decode instead.
decodeBuffer(buffer: Blob | Buffer | ArrayBuffer | Uint8Array | Uint8ClampedArray, width: number, height: number, stride: number, format: EnumImagePixelFormat): Promise<TextResult[]>
Parameters
buffer
: specifies the raw image represented by a Uint8Array
, Uint8ClampedArray
, ArrayBuffer
, Blob
or Buffer
object.
width
: image width.
height
: image height.
stride
: image-width * pixel-byte-length
.
format
: pixel format.
Return Value
A promise resolving to a TextResult\[\]
object that contains all the barcode results found in this image.
Code Snippet
let results = await reader.decodeBuffer(u8RawImage, 1280, 720, 1280 * 4, Dynamsoft.DBR.EnumImagePixelFormat.IPF_ABGR_8888);
for(let result of results){
console.log(result.barcodeText);
}
See Also
getRuntimeSettings
Returns the current runtime settings.
getRuntimeSettings(): Promise<RuntimeSettings>
Return Value
A promise resolving to a RuntimeSettings
object that contains the settings for barcode reading.
Code Snippet
let settings = await reader.getRuntimeSettings();
settings.barcodeFormatIds = Dynamsoft.DBR.EnumBarcodeFormat.BF_QR_CODE; // Decodes only QR code.
await reader.updateRuntimeSettings(settings);
See Also
updateRuntimeSettings
Updates runtime settings with a given struct or a preset template represented by one of the following strings
speed
: fast but may miss a few codes;coverage
: slow but try to find all codes, this is the default setting for aBarcodeReader
instance;balance
: betweenspeed
andcoverage
;single
: optimized for scanning one single barcode from a video input, this is supported only by the sub-class BarcodeScanner and is also the default setting for aBarcodeScanner
instance.
NOTE
If the settings
barcodeFormatIds
,barcodeFormatIds_2
andregion
have been changed by the customer, changing the template will preserve the previous settings.
updateRuntimeSettings(settings: RuntimeSettings | string): Promise<void>
Parameters
settings
: a RuntimeSettings
object that contains the new settings for barcode reading.
Return Value
A promise that resolves when the operation succeeds.
Code Snippet
await reader.updateRuntimeSettings('balance');
let settings = await reader.getRuntimeSettings();
settings.barcodeFormatIds = Dynamsoft.DBR.EnumBarcodeFormat.BF_ONED;
await reader.updateRuntimeSettings(settings);
See Also
resetRuntimeSettings
Resets all parameters to default values.
For a BarcodeReader
instance, it is equivalent to setting the coverage
template.
For a BarcodeScanner instance, it is equivalent to setting the speed
template.
resetRuntimeSettings(): Promise<void>
Parameters
None.
Return Value
A promise that resolves when the operation succeeds.
Code Snippet
await reader.resetRuntimeSettings();
outputRuntimeSettingsToString
Return the current RuntimeSettings in the form of a string.
outputRuntimeSettingsToString(): Promise<string>
Return Value
A promise resolving to a string which represents the current RuntimeSettings.
getModeArgument
Returns the argument value for the specified mode parameter.
getModeArgument(modeName: string, index: number, argumentName: string): Promise<string>
Parameters
modeName
: specifies the mode which contains one or multiple elements.
index
: specifies an element of the mode by its index.
argumentName
: specifies the argument.
Return Value
A promise resolving to a string which represents the value of the argument.
Code Snippet
let argumentValue = await reader.getModeArgument("BinarizationModes", 0, "EnableFillBinaryVacancy");
setModeArgument
Sets the argument value for the specified mode parameter.
setModeArgument(modeName: string, index: number, argumentName: string, argumentValue: string): Promise<void>
Parameters
modeName
: specifies the mode which contains one or multiple elements.
index
: specifies an element of the mode by its index.
argumentName
: specifies the argument.
argumentValue
: specifies the value.
Return Value
A promise that resolves when the operation succeeds.
Code Snippet
await reader.setModeArgument("BinarizationModes", 0, "EnableFillBinaryVacancy", "1");
ifSaveOriginalImageInACanvas
Whether to save the original image into a <canvas> element. The original image refers to the actual image the library tried to read barcodes from.
Note that the result is an HTMLCanvasElement
element and you can insert it into the DOM to show the image.
ifSaveOriginalImageInACanvas: boolean;
Default value
false
Code Snippet
reader.ifSaveOriginalImageInACanvas = true;
let results = await reader.decode(source);
document.body.append(reader.getOriginalImageInACanvas());
getOriginalImageInACanvas
An HTMLCanvasElement that holds the original image. The original image refers to the actual image the library tried to read barcodes from.
getOriginalImageInACanvas(): HTMLCanvasElement
Code Snippet
reader.ifSaveOriginalImageInACanvas = true;
let results = await reader.decode(source);
document.body.append(reader.getOriginalImageInACanvas());
See Also
setImageSource
Sets an image source for continous scanning.
setImageSource(imageSource: ImageSource): void;
Arguments
imageSource
: Specifies the image source.
Code Snippet
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
let enhancer = await Dynamsoft.DCE.CameraEnhancer.createInstance();
await enhancer.setUIElement(Dynamsoft.DBR.BarcodeReader.defaultUIElementURL);
reader.setImageSource(enhancer);
reader.onUniqueRead = (txt, result) => {
console.log(txt);
}
await reader.startScanning(true);
onUniqueRead
This event is triggered when a new, unduplicated label is found.
onUniqueRead: (txt: string, result: TextResult) => void
Arguments
txt
: a string that holds the label text (one single line).
result
: a TextResult
object that contains more detailed info about the returned text.
Code Snippet
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
let enhancer = await Dynamsoft.DCE.CameraEnhancer.createInstance();
await enhancer.setUIElement(Dynamsoft.DBR.BarcodeReader.defaultUIElementURL);
reader.setImageSource(enhancer);
reader.onUniqueRead = (txt, result) => {
console.log(txt);
}
reader.startScanning(true);
See Also
onImageRead
This event is triggered after the library finishes scanning a image.
onImageRead: (results: TextResult[]) => void
Arguments
results
: TextResult
objects that contain all the label results in this image.
Code Snippet
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
let enhancer = await Dynamsoft.DCE.CameraEnhancer.createInstance();
await enhancer.setUIElement(Dynamsoft.DBR.BarcodeReader.defaultUIElementURL);
reader.setImageSource(enhancer);
reader.onImageRead = results => {
for (let result of results) {
console.log(result.barcodeText);
}
};
reader.startScanning(true);
See Also
startScanning
Open the camera and starts continuous scanning of incoming images.
startScanning(appendOrShowUI?: boolean): Promise<PlayCallbackInfo>;
Parameters
appendOrShowUI
: this parameter specifies how to handle the UI that comes with the bound CameraEnhancer instance. When set to true, if the UI doesn’t exist in the DOM tree, the CameraEnhancer instance will append it in the DOM and show it; if the UI already exists in the DOM tree but is hidden, it’ll be displayed. When not set or set to false, it means not to change the original state of that UI: if it doesn’t exist in the DOM tree, nothing shows up on the page; if it exists in the DOM tree, it may or may not show up depending on its original state.
Return Value
A promise resolving to a PlayCallbackInfo
object which contains the resolution of the video.
Code Snippet
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
let enhancer = await Dynamsoft.DCE.CameraEnhancer.createInstance();
await enhancer.setUIElement(Dynamsoft.DBR.BarcodeReader.defaultUIElementURL);
reader.setImageSource(enhancer);
reader.onUniqueRead = (txt, result) => {
console.log(txt);
}
reader.startScanning(true);
See Also
pauseScanning
Pause continuous scanning but keep the video stream.
pauseScanning(): void;
resumeScanning
Resumes continuous scanning.
resumeScanning(): void;
stopScanning
Stops continuous scanning and closes the video stream.
stopScanning(hideUI?: boolean): void;
Parameters
hideUI
: this parameter specifies how to handle the UI that comes with the bound CameraEnhancer instance. When set to true, if the UI doesn’t exist in the DOM tree or it exists but is hidden, nothing is done; if the UI already exists in the DOM tree and is shown, it’ll be hidden. When not set or set to false, it means not to change the original state of that UI: if it doesn’t exist in the DOM tree, nothing happens; if it exists in the DOM tree, it may or may not be hidden depending on its original state.
Code Snippet
let reader = await Dynamsoft.DBR.BarcodeReader.createInstance();
let enhancer = await Dynamsoft.DCE.CameraEnhancer.createInstance();
await enhancer.setUIElement(Dynamsoft.DBR.BarcodeReader.defaultUIElementURL);
reader.setImageSource(enhancer);
reader.onUniqueRead = (txt, result) => {
console.log(txt);
reader.stopScanning(true);
}
await reader.startScanning(true);
See Also
getScanSettings
Returns the current scan settings.
getScanSettings(): Promise<ScanSettings>
Return Value
A promise resolving to a ScanSettings
.
Code Snippet
let scanSettings = await reader.getScanSettings();
scanSettings.intervalTime = 50;
scanSettings.duplicateForgetTime = 1000;
await reader.updateScanSettings(scanSettings);
See Also
updateScanSettings
Changes scan settings with the object passed in.
updateScanSettings(settings: ScanSettings): Promise<void>
Parameters
settings
: specifies the new scan settings.
Return Value
A promise that resolves when the operation succeeds.
Code Snippet
let scanSettings = await reader.getScanSettings();
scanSettings.intervalTime = 50;
scanSettings.duplicateForgetTime = 1000;
await reader.updateScanSettings(scanSettings);