decode method
Locates and decodes a barcode in some format within an image
. This method also accepts
hints
, each possibly associated to some data, which may help the implementation decode.
@param image image of barcode to decode @param hints passed as a Map from DecodeHintType to arbitrary data. The meaning of the data depends upon the hint type. The implementation may or may not do anything with these hints. @return String which the barcode encodes @throws NotFoundException if no potential barcode is found @throws ChecksumException if a potential barcode is found but does not pass its checksum @throws FormatException if a potential barcode is found but format is invalid
Implementation
@override
Result decode(BinaryBitmap image, [DecodeHint? hints]) {
DecoderResult decoderResult;
List<ResultPoint> points;
if (hints?.pureBarcode ?? false) {
final bits = _extractPureBits(image.blackMatrix);
decoderResult = _decoder.decodeMatrix(bits);
points = _noPoints;
} else {
final detectorResult = Detector(image.blackMatrix).detect();
decoderResult = _decoder.decodeMatrix(detectorResult.bits);
points = detectorResult.points;
}
final result = Result(
decoderResult.text,
decoderResult.rawBytes,
points,
BarcodeFormat.dataMatrix,
);
final byteSegments = decoderResult.byteSegments;
if (byteSegments != null) {
result.putMetadata(ResultMetadataType.byteSegments, byteSegments);
}
final ecLevel = decoderResult.ecLevel;
if (ecLevel != null) {
result.putMetadata(ResultMetadataType.errorCorrectionLevel, ecLevel);
}
result.putMetadata(
ResultMetadataType.errorsCorrected,
decoderResult.errorsCorrected ?? 0,
);
result.putMetadata(
ResultMetadataType.symbologyIdentifier,
']d${decoderResult.symbologyModifier}',
);
return result;
}