SmartZone ICR/OCR allow you to provide a list of expected data contents. If you know potential actual values, providing that information will make your recognition results more accurate.
- To improve recognition using a Data Validation List, set the FieldType property (ICR: FieldType; OCR: FieldType) of the Reader class to DataValidationList.
- To populate the data validation list, call the DataValidationListAddEntry method (ICR: DataValidationListAddEntry; OCR: DataValidationListAddEntry) of the Reader class for every valid value.
- To remove an entry from the data validation list, call the DataValidationListRemoveEntry method (ICR: DataValidationListRemoveEntry; OCR: DataValidationListRemoveEntry).
- To remove all entries from the data validation list, call the DataValidationListClear method (ICR: DataValidationListClear; OCR: DataValidationListClear).
- To examine the data validation list, call the DataValidationListCount property (ICR: DataValidationListCount; OCR: DataValidationListCount) to get the number of entries in the data validation list. The DataValidationListGetAt method (ICR: DataValidationListGetAt; OCR: DataValidationListGetAt) will return the entries at that index. So, by calling DataValidationListGetAt with index value of zero to DataValidationListCount, you can get every entry in the data validation list.
ICR Example - Clear a data validation list and add from a checkbox list
//Clear previous DVL
smartZoneICR1.Reader.DataValidationListClear();
//Add new ones
for (int i = 0; i < checkedListBoxDVL.Items.Count; i++) {
object curritem = checkedListBoxDVL.Items[i];
if (checkedListBoxDVL.CheckedItems.Contains(curritem))
{
smartZoneICR1.Reader.DataValidationListAddEntry(curritem.ToString());
}
}
OCR Example - Clear a data validation list and add from a checkbox list
//Clear previous DVL
smartZoneOCR1.Reader.DataValidationListClear();
//Add new ones
for (int i = 0; i < checkedListBoxDVL.Items.Count; i++) {
object curritem = checkedListBoxDVL.Items[i];
if (checkedListBoxDVL.CheckedItems.Contains(curritem))
{
smartZoneOCR1.Reader.DataValidationListAddEntry(curritem.ToString());
}
}
Using a Data Validation list provides additional feedback on recognition by way of the returned FieldType value. For example, a regular string will return a FieldType of GeneralText.
- When a DataValidation list is used, if the recognized value matches a value in the list, the FieldType of DataValidationList is returned.
- Otherwise, the FieldType of Unknown is returned, indicating that the recognized value was not in the list.
Practical Uses of Data Validation Lists
-
Well known values from a static list. For example, a list of state abbreviations:
C#
var stateList = new List<String>() { "AL", "AK", "AZ" ... };
-
Dynamically set items based on the value of another field. For example, if the Area code for a phone number was 703, the corresponding State could be validated against VA and DC; it should be one of those values.
-
Dynamically set items based on program conditions. For example, your program could be in a state where the only acceptable values in a field would be "N2101", "N2102" or "N2117."
Case Sensitivity
When comparing list entries and recognized text, the Data Validation engine assumes both are words with standard capitalization.
Scenarios with Mixed Cased List Entries and Recognized Text
Refer to the following behaviors for scenarios with mixed cased list entries and recognized text:
- Recognized text whose first letter is uppercase will match list entries whose first letter is uppercase or lowercase.
Example: Recognized text "Sat'' will match a list entry of “Sat” or "sat".- The inverse is not true.
Example: Recognized text "sat'' will not match a list entry of "Sat".
- The inverse is not true.
- Recognized text with all uppercase letters will match list entries with the same characters, regardless of upper or lowercase.
Example: Recognized text of "SAT" will match a list entry of "Sat", "sat" or "saT" - Recognized text whose characters are mixed case after the first character will only match list entries that are exactly the same.
Example: Recognized text of "sAT" will only match with "sAT". Recognized text of "SaT" will only match with "SaT".
- Recognized field type with indistinguishable characters of any case will be set to the DataValidationList regardless of the case.
This characters set include COSUVWXZÇÒÓÔÕÖØŚŞŠŨŪŮŰŲŹŻŽƏƠƯΌΒΓΖΟЅВЖЗИЙКЛМНОПСТХЦЧШЩЪЫЬЭЮЯҒҖҚҜҢҲҶҸӘӢӨỌỎỐỒỔỖỘỚỜỞỠỢỤỦỨỪỬỮỰ symbols.