Releases: Sec-ant/zxing-wasm
v2.0.0
This release introduces a major refactoring of the underlying Embind APIs and read / write functions. Key changes include a new set of default reader options, enhanced writer capabilities backed by zint
, and updated APIs for reading and writing barcodes. These changes break backward compatibility, so we are upgrading to the next major version.
Breaking Changes
Consolidated Reader Function
readBarcodes(...)
replaces both readBarcodesFromImageFile(...)
and readBarcodesFromImageData(...)
. The new function can accept either a Blob
or an ImageData
as its input.
Note
The v1 reader functions readBarcodesFromImageFile
and readBarcodesFromImageData
are still kept for a smooth migration experience, but marked as deprecated.
Updated Reader Options
A few reader options have changed their default values. This change is to align with the latest ZXing C++ library and provide a more consistent experience across different platforms:
tryCode39ExtendedMode
is nowtrue
by default. It was previouslyfalse
.eanAddOnSymbol
is now"Ignore"
by default. It was previously"Read"
.textMode
is now"HRI"
by default. It was previously"Plain"
.
Some deprecated options have been removed, see zxing-cpp#704 for more details:
validateCode39CheckSum
is now removed. The Code39 symbol has a valid checksum if the third character of thesymbologyIdentifier
is an odd digit.validateITFCheckSum
is now removed. The ITF symbol has a valid checksum if the third character of thesymbologyIdentifier
is a'1'
.returnCodabarStartEnd
is now removed. The detected results of Codabar symbols now always include the start and end characters.
eccLevel
in Read Result Renamed to ecLevel
In ReadResult
, the eccLevel
field has been renamed to ecLevel
. It now holds strings like "L"
, "M"
, "Q"
, or "H"
or stringified numeric percentage values for error correction levels. An empty string indicates that the error correction level is not applicable.
Note
The eccLevel
field is still kept for a smooth migration experience, but marked as deprecated.
Renamed & Enhanced Writer Function
writeBarcode(...)
replaces writeBarcodeToImageFile(...)
. This function is now powered by the new zint
backend which supports all available formats that are currently supported by the reader. It accepts either a string
text or an Uint8Array
binary data as its input for barcode generation, and provides new output formats (e.g. SVG, UTF-8) in addition to an image file blob.
The WriterOptions
object has also been updated completely.
Note
The final shape of the writeBarcode
function is still in review. The current implementation is subject to change.
.wasm
Module Initialization / Caching Overhaul
prepareZXingModule(...)
replaces both setZXingModuleOverrides(...)
and getZXingModuleOverrides(...)
. The new function provides a more flexible way to initialize the ZXing module with custom options.
Note
The v1 module initialization functions setZXingModuleOverrides
and getZXingModuleOverrides
are still kept for a smooth migration experience, but marked as deprecated.
purgeZXingModule
now only clears the relevant module cache from where it is imported. It no longer resets the global module cache.
Redefined BarcodeFormat
-Family Types
None
is removed from the BarcodeFormat
union type. New types like LinearBarcodeFormat
, MatrixBarcodeFormat
and LooseBarcodeFormat
are introduced. See barcodeFormat.ts
for more details.
New Features & Enhancements
More Barcode Formats Supported in Writer
The new writeBarcode
function supports more barcode formats than the previous writeBarcodeToImageFile
. All barcode formats supported by the reader are now supported by the writer.
New tryDenoise
Option for Reading Barcodes
The new tryDenoise
option in ReaderOptions
allows you to enable or disable the denoising algorithm when reading barcodes. This is an experimental feature. By default, it is set to false
.
Bug Fixes
Fix TS moduleResolution: node
Subpath Exports Resolution
The subpath export types are now compatible with TypeScript's moduleResolution: node
strategy by using the types-versions-wildcards strategy. This package now passes all the arethetypeswrong
checks.
v2.0.0-beta.4
v2.0.0-beta.3
v2.0.0-beta.2
Patch Changes
- b856d58: Add
typesVersions
field formoduleResolution: node
v2.0.0-beta.1
Patch Changes
- a10ffcc: Bump
zxing-cpp
to0dfa36b
to fix DataBarExpanded decoder error and ITF quiet zone detection heuristic
v2.0.0-beta.0
Major Changes
-
1a77296: V2: Breaking Release - Next Major Version
This release introduces a major refactoring of the underlying Embind APIs and read / write functions. Key changes include transitioning away from Embind Enums toward numeric encoding and decoding, a new set of default reader options, enhanced writer capabilities backed by
zint
, and updated APIs for reading and writing barcodes. These changes break backward compatibility, so we are upgrading to the next major version.Breaking Changes
Renamed & Consolidated Reader Function
readBarcodes(...)
replaces bothreadBarcodesFromImageFile(...)
andreadBarcodesFromImageData(...)
. The new function unifies code paths forBlob
andImageData
inputs.[!NOTE]
The v1 reader functions
readBarcodesFromImageFile
andreadBarcodesFromImageData
are still kept for a smooth migration experience, but marked as deprecated.Updated Reader Options
A few reader options have changed their default values. This change is to align with the latest ZXing C++ library and provide a more consistent experience across different platforms:
tryCode39ExtendedMode
is nowtrue
by default. It was previouslyfalse
.eanAddOnSymbol
is now"Ignore"
by default. It was previously"Read"
.textMode
is now"HRI"
by default. It was previously"Plain"
.
Some deprecated options have been removed, see zxing-cpp#704 for more details:
validateCode39CheckSum
is now removed. The Code39 symbol has a valid checksum if the third character of thesymbologyIdentifier
is an odd digit.validateITFCheckSum
is now removed. The ITF symbol has a valid checksum if the third character of thesymbologyIdentifier
is a'1'
.returnCodabarStartEnd
is now removed. The detected results of Codabar symbols now always include the start and end characters.
eccLevel
in Read Result Renamed toecLevel
In
ReadResult
, theeccLevel
field has been renamed toecLevel
. It now holds strings like"L"
,"M"
,"Q"
, or"H"
or stringified numeric values for error correction levels. An empty string indicates that the error correction level is not applicable.[!NOTE]
The
eccLevel
field is still kept for a smooth migration experience, but marked as deprecated.Renamed & Enhanced Writer Function
writeBarcode(...)
replaceswriteBarcodeToImageFile(...)
. The new function is powered by the newzint
writer, which supports more barcode formats, supports bothstring
andUint8Array
inputs for generating barcodes from text or binary data, and provides new output formats (e.g. SVG, UTF-8) in addition to the binary image file output.The
WriterOptions
object has also been updated completely.[!NOTE]
The final shape of the
writeBarcode
function is still under discussion. The current implementation is subject to change.Module Initialization / Caching Overhaul
prepareZXingModule(...)
replaces bothsetZXingModuleOverrides(...)
andgetZXingModuleOverrides(...)
. The new function provides a more flexible way to initialize the ZXing module with custom options.[!NOTE]
The v1 module initialization functions
setZXingModuleOverrides
andgetZXingModuleOverrides
are still kept for a smooth migration experience, but marked as deprecated.purgeZXingModule
now only clears the relevant module cache from where it is imported. It no longer resets the global module cache.New Features & Enhancements
More Barcode Formats Supported in Writer
The new
writeBarcode
function supports more barcode formats than the previouswriteBarcodeToImageFile
. All barcode formats supported by the reader except forDXFilmEdge
are now supported by the writer.New
tryDenoise
Option for Reading BarcodesThe new
tryDenoise
option inReaderOptions
allows you to enable or disable the denoising algorithm when reading barcodes. This is an experimental feature and by default, it is set tofalse
.