ClassesClasses | | Operators

get_bar_code_resultget_bar_code_resultGetBarCodeResultGetBarCodeResult (Operator)

Name

get_bar_code_resultget_bar_code_resultGetBarCodeResultGetBarCodeResult — Get the alphanumerical results that were accumulated during the decoding of bar code symbols.

Signature

get_bar_code_result( : : BarCodeHandle, CandidateHandle, ResultName : BarCodeResults)

Herror get_bar_code_result(const Hlong BarCodeHandle, const char* CandidateHandle, const char* ResultName, char* BarCodeResults)

Herror T_get_bar_code_result(const Htuple BarCodeHandle, const Htuple CandidateHandle, const Htuple ResultName, Htuple* BarCodeResults)

void GetBarCodeResult(const HTuple& BarCodeHandle, const HTuple& CandidateHandle, const HTuple& ResultName, HTuple* BarCodeResults)

HTuple HBarCode::GetBarCodeResult(const HTuple& CandidateHandle, const HString& ResultName) const

HTuple HBarCode::GetBarCodeResult(const HString& CandidateHandle, const HString& ResultName) const

HTuple HBarCode::GetBarCodeResult(const char* CandidateHandle, const char* ResultName) const

static void HOperatorSet.GetBarCodeResult(HTuple barCodeHandle, HTuple candidateHandle, HTuple resultName, out HTuple barCodeResults)

HTuple HBarCode.GetBarCodeResult(HTuple candidateHandle, string resultName)

HTuple HBarCode.GetBarCodeResult(string candidateHandle, string resultName)

Description

The operator get_bar_code_resultget_bar_code_resultGetBarCodeResultGetBarCodeResultGetBarCodeResult allows to access alphanumeric results of the find and decode process. To access a result, first the handle of the bar code model (BarCodeHandleBarCodeHandleBarCodeHandleBarCodeHandlebarCodeHandle) and the index of the resulting symbol or candidate (CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle) must be passed. CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle refers to the results in the same order that is returned by the operator find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode. CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle can take at least numbers from 0 to (n-1), where n is the total number of successfully decoded symbols, for all queries and can take numbers from 0 to (m-1), where m is the total number of candidates, if stated in the description of ResultNameResultNameResultNameResultNameresultName below. Alternatively, CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle can be set to 'all'"all""all""all""all" if all results are desired. The option 'all'"all""all""all""all" can be chosen only in cases where the return value of a single result is single valued.

The result returned in BarCodeResultsBarCodeResultsBarCodeResultsBarCodeResultsbarCodeResults can be selected by setting ResultNameResultNameResultNameResultNameresultName to:

'decoded_strings'"decoded_strings""decoded_strings""decoded_strings""decoded_strings":

returns the decoded result as a string in a human readable format. This decoded string can be returned for a single result, e.g., for CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle 0, or for all results simultaneously when CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle is set to 'all'"all""all""all""all". Note that only data characters are contained in the decoded string. Start, stop, and check characters are excluded. For optional check characters the behavior depends on the value of the 'check_char'"check_char""check_char""check_char""check_char" parameter.

'decoded_types'"decoded_types""decoded_types""decoded_types""decoded_types":

returns the bar code type of the decoded result as a string. This is especially important in the context of autodiscrimination (see find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode). CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle specifies the results for which the type should be returned: The code type can be returned for a single result, e.g., for CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle 0 when requesting the type of the first result, or for all results simultaneously if CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle is set to 'all'"all""all""all""all".

'decoded_data'"decoded_data""decoded_data""decoded_data""decoded_data":

returns the decoded result as a tuple of byte values. In contrast to 'decoded_reference'"decoded_reference""decoded_reference""decoded_reference""decoded_reference", this contains the same high level processed data that is also returned for 'decoded_strings'"decoded_strings""decoded_strings""decoded_strings""decoded_strings". However, if the data contains binary non-printable characters, this parameter is more convenient. Also, for Code 128 or Code 93, the decoded data may contain NULL characters. In this case, the data can only be fully retrieved using this parameter, as the NULL character will otherwise terminate the string.

'decoded_reference'"decoded_reference""decoded_reference""decoded_reference""decoded_reference":

returns the underlying decoded reference data. It comprises all original characters of the symbol, i.e., data characters, potential start or stop characters and check characters if present. For codes taking only numeric data, like, e.g., the EAN/UPC codes, the GS1 DataBar codes (except the GS1 DataBar Expanded variants), or the 2/5 codes, the decoded reference data takes the same values as the decoded string data including check characters. For codes with alphanumeric data, like for example Code 128 or Code 39 the decoded reference data are the indices of the respective decoding table. For GS1-128, the reference values are the ASCII codes of the decoded data (see also Tuple / String Operations), where the special character FNC1 appears with value 102. For GS1 DataBar Expanded and GS1 DataBar Expanded Stacked, the reference values are the ASCII codes of the decoded data, where the special character FNC1 appears with value 29. Furthermore, for all codes from the GS1 DataBar family the first reference value represents a linkage flag with value of 1 if the flag is set and 0 otherwise. As the decoded reference is a tuple of whole numbers it can only be called for a single result, meaning that CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle has to be the handle number of the corresponding decoded symbol.

'composite_strings'"composite_strings""composite_strings""composite_strings""composite_strings":

returns the decoded string of a GS1 Composite component. For further details see the description of the parameter 'composite_code'"composite_code""composite_code""composite_code""composite_code" of set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam.

'composite_reference'"composite_reference""composite_reference""composite_reference""composite_reference":

returns the decoded string of a GS1 Composite component as a tuple of byte values. If the data contains binary non-printable characters, this parameter is more convenient than 'composite_strings'"composite_strings""composite_strings""composite_strings""composite_strings".

'orientation'"orientation""orientation""orientation""orientation":

returns the orientation for the specified result. The 'orientation'"orientation""orientation""orientation""orientation" of a bar code is defined as the angle between its reading direction and the horizontal image axis. The angle is positive in counter clockwise direction and is given in degrees. It can be in the range of [-180.0 ... 180.0] degrees. Note that the reading direction is perpendicular to the bars of the bar code. A single angle is returned when only one result is specified, e.g., by entering 0 for CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle. Otherwise, when CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle is set to 'all'"all""all""all""all", a tuple containing the angles of all results is returned.

'element_size'"element_size""element_size""element_size""element_size":

returns the size of barcode elements for the specified result.

'aborted'"aborted""aborted""aborted""aborted":

returns whether find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode was aborted. This might be caused by a timeout (see 'timeout' in set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam) or an explicit abort (see 'abort' in set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam).

Value Description
0 find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode completed
1 find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode was aborted by a timeout
2 find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode was aborted using set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam with 'abort'

'quality_isoiec15416'"quality_isoiec15416""quality_isoiec15416""quality_isoiec15416""quality_isoiec15416":

returns a tuple with the assessment of print quality in compliance with the international standard ISO/IEC 15416. The first element always contains the overall print quality of the symbol. The length of the tuple and the interpretation of the remaining elements depend on whether a simple 1D bar code is evaluated (such as EAN-13, Code 128, GS1 DataBar etc.) or a composite bar code (such as GS1 DataBar Omnidirectional CC-A, GS1 DataBar Limited CC-B).

For the print quality assessment a set of scan reflectance profiles (scan lines) is generated across the symbol. For each scan line a grade for each of the evaluated parameters is allocated. According to the standard these grades are whole numbers from 0 to 4, where 0 is the lowest and 4 the highest grade. The lowest grade of all parameter grades of a scan line is defined as the scan reflectance profile grade. Thus, each scan line has an own grade representing the respective minimal grade of all parameter grades of this scan line. The arithmetic mean of all those scan line grades is then returned as the overall symbol grade.

It is important to note that, even though the implementation is strictly based on the standard, the computation of the print quality grades depends on the decoding algorithm used. Thus, different bar code readers (of different vendors) can potentially produce slightly different results in the print quality assessment.

For simple 1D bar codes the print quality is described in a tuple with nine elements:

1. Overall

The overall quality is the minimum of all individual grades.

2. Decode

The decode grade is set to 4 when the reflectance profile of the symbol could be decoded according to the reference decode algorithm for the symbology and 0, otherwise. Note that HALCON's decode algorithm differs from the reference decode algorithm. Thus, in many cases HALCON can decode the symbol although the decode grade according to the standard is 0.

3. Symbol Contrast

The symbol contrast is the range between the minimal and the maximal value in the reflectance profile. A strong contrast results in a good grading.

4. Minimal Reflectance

The minimal reflectance grade is set to 4 if the lowest reflectance value in the scan reflectance profile is lower or equal to 0.5 of the maximal reflectance value. Otherwise a value of 0 is assigned.

5. Minimal Edge contrast

Edge contrast is the contrast between any two adjacent elements, both bar-to-space or space-to-bar. The minimal edge contrast grades the minimum of the edge contrast values measured in the reflectance profile.

6. Modulation

The modulation indicates how strong the amplitudes of the bar code elements are. Big amplitudes make the assignment of the elements to bars or spaces more certain, resulting in a high modulation grade.

7. Defects

Defects is a grading of reflectance irregularities found within elements and quiet zones.

8. Decodability

The decodability grade reflects deviations of the element widths from the nominal widths defined for the corresponding symbology.

9. Additional Requirements

The additional requirements are bar code symbology specific requirements: mostly regarding the required quiet zones, but sometimes it can be also related to wide/narrow ratio, inter character gaps, guarding patterns or further symbology specific characteristics. For some code types the conformity to the corresponding ISO/IEC standard cannot be guaranteed. This is mainly because the computation of the additional requirements requires the availability of metrical information.

Code 39

For Code 39 symbols the grade of the inter character gap is dependent on the measured narrow element width given in millimeters. Since in find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode neither metric information is available nor can be calculated, get_bar_code_resultget_bar_code_resultGetBarCodeResultGetBarCodeResultGetBarCodeResult will only return the grade for the inter character gap assuming that the measured narrow element width is less than 0.287mm.

EAN-13, EAN-8, UPC-A, UPC-E (including all Add-On variants)

ISO/IEC 15420:2009 specifies the magnification factors as an additional criterion . A computation of this criterion is not possible since this would require knowledge of the metrical size of the bar code.

While overall quality is the final symbol grade to be reported, the rest of the grades give information for possible causes for poor quality of a symbol. A detailed list of frequently appearing defects and their effect on the individual grades can be found with the ISO/IEC 15416 standard. Note that the names and the order of the grades can be queried with the convenience option 'quality_isoiec15416_labels'"quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels".

For composite bar codes the print quality is described in a tuple with 24 elements, which we organize for better clarity in three groups and one sub group:

              OVERALL:                            COMPOSITE:
         0.     Overall                     11.     Decode
         1.     Overall Linear              12.     Rap Overall
         2.     Overall Composite                 COMPOSITE RAP:
                                            13.         Contrast
              LINEAR:                       14.         Minimal Reflectance
         3.     Decode                      15.         Minimal Edge Contrast
         4.     Symbol Contrast             16.         Modulation
         5.     Minimal Reflectance         17.         Defects
         6.     Minimal Edge contrast       18.         Decodability
         7.     Modulation                  19.     Codeword Yield
         8.     Defects                     20.     Unused Error Correction
         9.     Decodability                21.     Modulation
        10.     Additional Requirements     22.     Decodability
                                            23.     Defects
    

For composite bar codes the first entries of the returned tuple are the overall grades that are listed in the group OVERALL. They represent the respective minimum of all individual grades of each group. The following entries of the tuple consist of the grades for the sub symbols listed in the groups LINEAR and COMPOSITE. They give information of possible causes for poor quality of the symbol.

The interpretation of the grades in the LINEAR group correspond to those for simple 1D bar codes. In contrast, the grades in the COMPOSITE group are directly equivalent to the one for a PDF 417 data code 2D symbol (see get_data_code_2d_resultsget_data_code_2d_resultsGetDataCode2dResultsGetDataCode2dResultsGetDataCode2dResults). However, for PDF 417 data code 2D symbols a start/stop pattern is used for the evaluation concerning the quality of the reflectance profile whereas for composite bar codes so-called Raw Address Patterns (RAP) are used instead of a start/stop pattern. The grades of the respective RAP sub symbols are organized in the sub group COMPOSITE RAP and are consistent with the grades for simple 1D bar codes.

The definition of the individual elements is as follows:

1. Overall

The overall grade in OVERALL is the final symbol grade to be reported. It is the minimum of the overall grades of the LINEAR and the COMPOSITE sub symbols overall linear and overall composite.

2. Overall Linear

The overall linear grade is the overall grade for the LINEAR sub symbols.

3. Overall Composite

The overall composite grade is the overall grade for the COMPOSITE sub symbols.

4.-11. LINEAR Sub Symbols

The grades in the LINEAR group correspond to those for simple 1D bar codes as described above.

12. Decode

The decode grade corresponds to the one for simple 1D bar codes as described above.

13. Rap Overall

The rap overall grade is the minimum of all individual grades of the sub group COMPOSITE RAP.

14.-19. COMPOSITE RAP sub symbols

The grades for the RAP sub symbols are consistent with the grades for simple 1D bar codes as described above.

20. Codeword Yield

The codeword yield grade counts and evaluates the relative number of correct decoded words acquired by the set of scan profiles.

21. Unused Error Correction

The unused error correction grade counts the relative number of false decoded words within the error correction blocks.

22. Modulation

The modulation grade indicates how strong the amplitudes, i.e., the extremal intensities, of the bars and spaces are.

23. Decodability

The decodability grade measures the deviation of the nominal length of bars and spaces with respect to their reference length.

24. Defects

And finally, the defects grade refers to a measurement of how perfect the reflectance profiles of bars and spaces are.

Note that the names and the order of the grades can be queried with the convenience option 'quality_isoiec15416_labels'"quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels". Also note that the print quality of a bar code can be evaluated only if the bar code was decoded by find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode in 'persistence'"persistence""persistence""persistence""persistence" mode (see set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam for further details).

'quality_isoiec15416_values'"quality_isoiec15416_values""quality_isoiec15416_values""quality_isoiec15416_values""quality_isoiec15416_values":

returns a tuple with the raw values for all 'directly measurable' grades (returned by 'quality_isoiec15416'"quality_isoiec15416""quality_isoiec15416""quality_isoiec15416""quality_isoiec15416"). These are the grades, whose definition in the ISO/IEC 15416 standard is a 'direct derivative' of the reflectance (i.e., the gray values) properties of the symbol or grades that are the result of a 'direct counting'.

For simple 1D bar codes the grades are:

  1. Symbol Contrast

  2. Modulation

  3. Minimal Reflectance

  4. Defects

  5. Minimal Edge contrast

  6. Decodability

For composite bar codes the grades are:

  1. Symbol Contrast

  2. Rap Contrast

  3. Minimal Reflectance

  4. Minimal Edge contrast

  5. Modulation

  6. Defects

  7. Decodability

  8. Rap Minimal Reflectance

  9. Rap Minimal Edge Contrast

  10. Rap Modulation

  11. Rap Defects

  12. Rap Decodability

  13. Codeword Yield

  14. Unused Error Correction

The returned tuple has the same order of elements as the corresponding result by 'quality_isoiec15416'"quality_isoiec15416""quality_isoiec15416""quality_isoiec15416""quality_isoiec15416". For the grades, which are excluded from these lists the operator reports 'N/A'"N/A""N/A""N/A""N/A". In the case of simple 1D bar codes Decode, Overall, Additional Requirements do not have any interpretation in the reflectance profile and the respectively returned value is 'N/A'"N/A""N/A""N/A""N/A". For composite bar codes this is the case with all Overall and Decode grades. Note that although the grades Composite Modulation, Composite Decodability, Composite Defects are grading the gray value reflectance profile of a composite symbol, 'quality_isoiec15416_values'"quality_isoiec15416_values""quality_isoiec15416_values""quality_isoiec15416_values""quality_isoiec15416_values" reports 'N/A'"N/A""N/A""N/A""N/A" for them as well. Since they are computed in a complicated scheme involving the symbology decoding routine and the error correction mechanism, they do not have a direct raw measurement interpretation.

All values are normalized between 0.0 and 1.0. Hence, for example, a Symbol Contrast value of 0.75 will correspond to a gray value of 191.25 (for BYTE images).

'quality_isoiec15416_labels'"quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels":

returns convenience grade labels of the elements of the tuple returned when calling get_bar_code_resultget_bar_code_resultGetBarCodeResultGetBarCodeResultGetBarCodeResult with 'quality_isoiec15416'"quality_isoiec15416""quality_isoiec15416""quality_isoiec15416""quality_isoiec15416". Note, that in order to be able to discriminate the composite from the linear grading case, the operator needs a handle of a valid result to be passed in CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle.

'status'"status""status""status""status":

determines and returns additional information about scanlines of a given candidate region in a human-readable format. Here, CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle can take numbers from 0 to (m-1), where m is the total number of candidates. Note that the status of the scanlines of a bar code can be evaluated only if the operator find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode or decode_bar_code_rectangle2decode_bar_code_rectangle2DecodeBarCodeRectangle2DecodeBarCodeRectangle2DecodeBarCodeRectangle2 was called before while in 'persistence'"persistence""persistence""persistence""persistence" mode (see set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam for further details). No changes in any parameters of the bar code reader must occur between the last call of find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode and this status query. Determining the status is computationally expensive and should be queried only if additional debugging information is needed.

Each candidate region contains a certain number of scanlines which depends on the type of bar code and could be changed with set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam with the parameter 'num_scanlines'"num_scanlines""num_scanlines""num_scanlines""num_scanlines". Normally, the bar code scanner exits as soon as it has found enough scanlines that could be decoded - the default is one successfully decoded scanline, but this can be changed with set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam with the parameter 'min_identical_scanlines'"min_identical_scanlines""min_identical_scanlines""min_identical_scanlines""min_identical_scanlines". When using 'status'"status""status""status""status" in get_bar_code_resultget_bar_code_resultGetBarCodeResultGetBarCodeResultGetBarCodeResult, the given candidate region is scanned again but this time all scanlines of the specified candidate region are being evaluated. Then the operator returns status information for every scanline of the candidate region in the same order as the scanlines themselves are returned by get_bar_code_objectget_bar_code_objectGetBarCodeObjectGetBarCodeObjectGetBarCodeObject with the parameter 'scanlines_all'"scanlines_all""scanlines_all""scanlines_all""scanlines_all".

The following list shows the possible status messages grouped into stages in which the message can appear. The numbers in parentheses are the corresponding status codes returned by 'status_id'"status_id""status_id""status_id""status_id" (see below).

'unknown status.'"unknown status.""unknown status.""unknown status.""unknown status." (0)

The status of this scanline is unknown. The scanline will be ignored.

'success.'"success.""success.""success.""success." (1)

The scanline could be decoded successfully.

'edges: not enough edges detected.'"edges: not enough edges detected.""edges: not enough edges detected.""edges: not enough edges detected.""edges: not enough edges detected." (2):

The number of edges in this scanline is too low for this bar code type.

'edges: not enough edges for a start, a stop and at least one data character.'"edges: not enough edges for a start, a stop and at least one data character.""edges: not enough edges for a start, a stop and at least one data character.""edges: not enough edges for a start, a stop and at least one data character.""edges: not enough edges for a start, a stop and at least one data character." (3):

The number of edges in this scanline is too low to find at least the start pattern, the stop pattern and a data character.

'edges: too many edges detected.'"edges: too many edges detected.""edges: too many edges detected.""edges: too many edges detected.""edges: too many edges detected." (4):

The number of edges in this scanline is too high for this bar code type

'edges: center of scanline not within image domain.'"edges: center of scanline not within image domain.""edges: center of scanline not within image domain.""edges: center of scanline not within image domain.""edges: center of scanline not within image domain." (5)

'decoding: could not find stop character.'"decoding: could not find stop character.""decoding: could not find stop character.""decoding: could not find stop character.""decoding: could not find stop character." (6):

The symbology specific stop character could not be found.

'decoding: could not find start and stop characters.'"decoding: could not find start and stop characters.""decoding: could not find start and stop characters.""decoding: could not find start and stop characters.""decoding: could not find start and stop characters." (7):

The symbology specific start and stop characters could not be found.

'decoding: internal error when estimating the maximum string length.'"decoding: internal error when estimating the maximum string length.""decoding: internal error when estimating the maximum string length.""decoding: internal error when estimating the maximum string length.""decoding: internal error when estimating the maximum string length." (8):

Internal error.

'decoding: internal error when decoding a single character.'"decoding: internal error when decoding a single character.""decoding: internal error when decoding a single character.""decoding: internal error when decoding a single character.""decoding: internal error when decoding a single character." (9):

Internal error.

'decoding: number of wide bars of a single character is not equal to 2.'"decoding: number of wide bars of a single character is not equal to 2.""decoding: number of wide bars of a single character is not equal to 2.""decoding: number of wide bars of a single character is not equal to 2.""decoding: number of wide bars of a single character is not equal to 2." (10):

For bar code types '2/5 Industrial'"2/5 Industrial""2/5 Industrial""2/5 Industrial""2/5 Industrial" and '2/5 Interleaved'"2/5 Interleaved""2/5 Interleaved""2/5 Interleaved""2/5 Interleaved", the number of wide bars in a single character must be two.

'decoding: invalid encoding pattern.'"decoding: invalid encoding pattern.""decoding: invalid encoding pattern.""decoding: invalid encoding pattern.""decoding: invalid encoding pattern." (11):

The encoding pattern does not correspond to a character in the symbology specific look-up table.

'decoding: invalid mix of character sets.'"decoding: invalid mix of character sets.""decoding: invalid mix of character sets.""decoding: invalid mix of character sets.""decoding: invalid mix of character sets." (12):

For bar code types 'EAN-13'"EAN-13""EAN-13""EAN-13""EAN-13" and 'UPC-A'"UPC-A""UPC-A""UPC-A""UPC-A", the left half of the symbol contains an invalid mix of the number sets A and B.

'decoding: error decoding the reference to a human readable string.'"decoding: error decoding the reference to a human readable string.""decoding: error decoding the reference to a human readable string.""decoding: error decoding the reference to a human readable string.""decoding: error decoding the reference to a human readable string." (13):

For example, this could happen if not enough characters ( depending on whether a check character is expected) could be found.

'decoding: could not detect center guard pattern.'"decoding: could not detect center guard pattern.""decoding: could not detect center guard pattern.""decoding: could not detect center guard pattern.""decoding: could not detect center guard pattern." (14):

For bar code types 'EAN-13'"EAN-13""EAN-13""EAN-13""EAN-13", 'EAN-8'"EAN-8""EAN-8""EAN-8""EAN-8", and 'UPC-A'"UPC-A""UPC-A""UPC-A""UPC-A" (including add-on variants) the obligatory center guard pattern could not be found.

'decoding: could not detect left and/or right guard patterns.'"decoding: could not detect left and/or right guard patterns.""decoding: could not detect left and/or right guard patterns.""decoding: could not detect left and/or right guard patterns.""decoding: could not detect left and/or right guard patterns." (15):

For bar code types 'EAN-13'"EAN-13""EAN-13""EAN-13""EAN-13", 'EAN-8'"EAN-8""EAN-8""EAN-8""EAN-8", and 'UPC-A'"UPC-A""UPC-A""UPC-A""UPC-A" (including add-on variants) either the obligatory left or right normal guard patterns could not be found. For bar code types 'UPC-E'"UPC-E""UPC-E""UPC-E""UPC-E" (including add-on variants) either the left normal or right special guard patterns could not be found.

'decoding: could not detect add-on guard pattern.'"decoding: could not detect add-on guard pattern.""decoding: could not detect add-on guard pattern.""decoding: could not detect add-on guard pattern.""decoding: could not detect add-on guard pattern." (16):

For bar code types 'EAN-13'"EAN-13""EAN-13""EAN-13""EAN-13", 'EAN-8'"EAN-8""EAN-8""EAN-8""EAN-8", 'UPC-A'"UPC-A""UPC-A""UPC-A""UPC-A", and 'UPC-E'"UPC-E""UPC-E""UPC-E""UPC-E" containing add-on symbols, the obligatory add-on guard pattern could not be found.

'decoding: could not detect enough finder patterns.'"decoding: could not detect enough finder patterns.""decoding: could not detect enough finder patterns.""decoding: could not detect enough finder patterns.""decoding: could not detect enough finder patterns." (17):

For bar code types of the GS1 DataBar family, not enough finder patterns could be found.

'decoding: no segment found.'"decoding: no segment found.""decoding: no segment found.""decoding: no segment found.""decoding: no segment found." (18):

For stacked bar code types no segment could be found.

'check: checksum test failed.'"check: checksum test failed.""check: checksum test failed.""check: checksum test failed.""check: checksum test failed." (19):

The check character test failed. For bar codes with an optional check character, it is possible to disable the check character testing with 'check_char'"check_char""check_char""check_char""check_char" in set_bar_code_paramset_bar_code_paramSetBarCodeParamSetBarCodeParamSetBarCodeParam.

'check: check of add-on symbol failed.'"check: check of add-on symbol failed.""check: check of add-on symbol failed.""check: check of add-on symbol failed.""check: check of add-on symbol failed." (20):

For bar code types 'EAN-13'"EAN-13""EAN-13""EAN-13""EAN-13", 'EAN-8'"EAN-8""EAN-8""EAN-8""EAN-8", 'UPC-A'"UPC-A""UPC-A""UPC-A""UPC-A", and 'UPC-E'"UPC-E""UPC-E""UPC-E""UPC-E" containing add-on symbols, the mix of the number sets A and B does not match the implicit check digit.

'check: detected EAN-13 bar code type instead of specified type.'"check: detected EAN-13 bar code type instead of specified type.""check: detected EAN-13 bar code type instead of specified type.""check: detected EAN-13 bar code type instead of specified type.""check: detected EAN-13 bar code type instead of specified type." (21):

For the bar code type 'UPC-A'"UPC-A""UPC-A""UPC-A""UPC-A" and its add-on variants, the left half of the symbol must consist of six symbol characters of number set A, but a 'EAN-13'"EAN-13""EAN-13""EAN-13""EAN-13" compatible mix of number sets A and B has been found instead. Try decoding the bar code as 'EAN-13'"EAN-13""EAN-13""EAN-13""EAN-13".

'check: symbol region overlaps with another symbol region'"check: symbol region overlaps with another symbol region""check: symbol region overlaps with another symbol region""check: symbol region overlaps with another symbol region""check: symbol region overlaps with another symbol region" (22):

The bar code could be decoded, but its symbol region intersects with the symbol region of another successfully decoded symbol.

'decoding: could not detect the bar code type.'"decoding: could not detect the bar code type.""decoding: could not detect the bar code type.""decoding: could not detect the bar code type.""decoding: could not detect the bar code type." (23):

While scanning a candidate region in autodiscrimination mode (see find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode with CodeType='auto'"auto""auto""auto""auto"), the decoder was unable to detect which bar code type the symbol belongs to.

'check: symbol region detected outside of the candidate region.'"check: symbol region detected outside of the candidate region.""check: symbol region detected outside of the candidate region.""check: symbol region detected outside of the candidate region.""check: symbol region detected outside of the candidate region." (24):

A bar code could be decoded, but the resulting symbol region does not intersect the original candidate region. This is an indication that random clutter or another candidate was detected by accident by the scanlines used to scan the original candidate.

Warning messages:

The following messages are warnings only, not errors. They can appear in combination with a status message and are then added to the status message string. These messages are returned if the bar code reader detects possible quality issues in the input image. The messages 1000 to 1003 can appear only for successfully decoded scanlines and only for the following bar code types: 'Codabar'"Codabar""Codabar""Codabar""Codabar", '2/5 Industrial'"2/5 Industrial""2/5 Industrial""2/5 Industrial""2/5 Industrial", '2/5 Interleaved'"2/5 Interleaved""2/5 Interleaved""2/5 Interleaved""2/5 Interleaved", 'Code 39'"Code 39""Code 39""Code 39""Code 39", 'Code 93'"Code 93""Code 93""Code 93""Code 93", 'GS1-128'"GS1-128""GS1-128""GS1-128""GS1-128", 'Code 128'"Code 128""Code 128""Code 128""Code 128", 'MSI'"MSI""MSI""MSI""MSI", all 'EAN'"EAN""EAN""EAN""EAN"-, 'UPC-A'"UPC-A""UPC-A""UPC-A""UPC-A"- and 'UPC-E'"UPC-E""UPC-E""UPC-E""UPC-E"-variants. Note that in cases where scanlines were already decoded incorrectly but not recognized as invalid by the bar code reader, these warnings will be wrong and must be ignored.

'White spaces too wide.'"White spaces too wide.""White spaces too wide.""White spaces too wide.""White spaces too wide." (1000):

The measured width of the white spaces is bigger than internally expected. This is not a decoding error, but a warning that increasing white spaces could lead to undecodable symbols.

'White spaces too narrow.'"White spaces too narrow.""White spaces too narrow.""White spaces too narrow.""White spaces too narrow." (1001):

The measured width of the white spaces is smaller than internally expected. This is not a decoding error, but a warning that decreasing white spaces could lead to undecodable symbols.

'Bars too wide.'"Bars too wide.""Bars too wide.""Bars too wide.""Bars too wide." (1002):

The measured width of the bars is bigger than internally expected. This is not a decoding error, but a warning that increasing the width of the bars could lead to undecodable symbols.

'Bars too narrow.'"Bars too narrow.""Bars too narrow.""Bars too narrow.""Bars too narrow." (1003):

The measured width of the bars is smaller than internally expected. This is not a decoding error, but a warning that decreasing the width of the bars could lead to undecodable symbols.

'Possible saturation of gray values.'"Possible saturation of gray values.""Possible saturation of gray values.""Possible saturation of gray values.""Possible saturation of gray values." (1004):

Internal algorithms show that the white pixels in the symbol region could be saturated. This warning is not bar code type specific. This warning is returned for each scanline. For example, the combination of the status messages 1001/1004 or 1003/1004 is a hint, that the input images might be overexposured.

'No composite component found.'"No composite component found.""No composite component found.""No composite component found.""No composite component found." (1005):

The linkage flag in the linear bar code component indicates that there should be a composite component, but the composite component could not be found. The decoder returned the linear component only. This warning is returned for each scanline.

'Used for merging.'"Used for merging.""Used for merging.""Used for merging.""Used for merging." (1006):

This message is an information that some edges of the current scanline were used to compute the merged scanline.

'status_id'"status_id""status_id""status_id""status_id":

returns additional information about scanlines in a numeric format that can be easily parsed. The description of this functionality and the message numbers are described with the parameter 'status'"status""status""status""status" above. The numbers of the warnings can be returned together with other status numbers. The single status message and warning numbers for each scanline are returned as a string, separated by a semicolon, e.g. '1;1000;1004'.

Execution Information

Parameters

BarCodeHandleBarCodeHandleBarCodeHandleBarCodeHandlebarCodeHandle (input_control)  barcode HBarCode, HTupleHTupleHtuple (integer) (IntPtr) (Hlong) (Hlong)

Handle of the bar code model.

CandidateHandleCandidateHandleCandidateHandleCandidateHandlecandidateHandle (input_control)  integer HTupleHTupleHtuple (string / integer) (string / int / long) (HString / Hlong) (char* / Hlong)

Indicating the bar code results respectively candidates for which the data is required.

Default value: 'all' "all" "all" "all" "all"

Suggested values: 0, 1, 2, 'all'"all""all""all""all"

ResultNameResultNameResultNameResultNameresultName (input_control)  attribute.name HTupleHTupleHtuple (string) (string) (HString) (char*)

Names of the resulting data to return.

Default value: 'decoded_types' "decoded_types" "decoded_types" "decoded_types" "decoded_types"

Suggested values: 'decoded_types'"decoded_types""decoded_types""decoded_types""decoded_types", 'decoded_strings'"decoded_strings""decoded_strings""decoded_strings""decoded_strings", 'decoded_data'"decoded_data""decoded_data""decoded_data""decoded_data", 'decoded_reference'"decoded_reference""decoded_reference""decoded_reference""decoded_reference", 'element_size'"element_size""element_size""element_size""element_size", 'orientation'"orientation""orientation""orientation""orientation", 'composite_strings'"composite_strings""composite_strings""composite_strings""composite_strings", 'composite_reference'"composite_reference""composite_reference""composite_reference""composite_reference", 'aborted'"aborted""aborted""aborted""aborted", 'quality_isoiec15416'"quality_isoiec15416""quality_isoiec15416""quality_isoiec15416""quality_isoiec15416", 'quality_isoiec15416_labels'"quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels""quality_isoiec15416_labels", 'quality_isoiec15416_values'"quality_isoiec15416_values""quality_isoiec15416_values""quality_isoiec15416_values""quality_isoiec15416_values", 'status'"status""status""status""status", 'status_id'"status_id""status_id""status_id""status_id"

BarCodeResultsBarCodeResultsBarCodeResultsBarCodeResultsbarCodeResults (output_control)  attribute.value(-array) HTupleHTupleHtuple (string / integer / real) (string / int / long / double) (HString / Hlong / double) (char* / Hlong / double)

List with the results.

Result

The operator get_bar_code_resultget_bar_code_resultGetBarCodeResultGetBarCodeResultGetBarCodeResult returns the value 2 (H_MSG_TRUE) if the given parameters are correct and the requested results are available for the last symbol search. Otherwise, an exception will be raised.

Possible Predecessors

find_bar_codefind_bar_codeFindBarCodeFindBarCodeFindBarCode

See also

get_bar_code_objectget_bar_code_objectGetBarCodeObjectGetBarCodeObjectGetBarCodeObject

Module

Bar Code


ClassesClasses | | Operators