Scanner OPOS Sample Application

Overview

The Zebra Scanner OPOS Driver suite ships with a sample application that demonstrates all the OPOS operations on a connected Zebra scanner.


OPOS Sample Applicaton (Scanner OPOS Test Utility)

The Scanner OPOS Test Utility allows you to simulate an application communicating with the Zebra Scanner OPOS Driver. This utility displays scanned data received from the scanner through the Zebra Scanner OPOS Driver. The Zebra Scanner SDK includes source code for this VC++ test utility.


OPOS Test Utility Window Functionality

Figure 1: Scanner OPOS Sample Application

Table 1: Scanner OPOS Test Utility Button/Field Functionality

Button / Field / Checkbox Description Values Code Samples
Open Open Method ZEBRA_SCANNER m_ctScanner.Open("ZEBRA_SCANNER")
Claim Claim the device with time out value. -1, Any integer starting from zero m_ctScanner.Claim(1000)
Device Enable Enable the scanner. Must enable before using scanners. n/a m_ctrScanner.SetDeviceEnabled(TRUE)
Device Disable Disable the scanner. n/a m_ctrScanner.SetDeviceEnabled(FALSE)
Release Release the scanner. n/a m_ctrScanner.ReleaseDevice()
Close Close the scanner. n/a m_ctrScanner.CloseDevice()
Recorded Data
Scan Data Label Label of the scan data. n/a m_ctrScanner.GetScanDataLabel()
Scan Data Type Type of the scanned data. This is only a readable property. n/a m_ctrScanner.GetScanDataType()
CH Internal Perform a Health check that does not physically change the device. The device is tested by internal tests to the extent possible. n/a m_ctrlScanner.CheckHealth(OPOS_CH_INTERNAL)
CH External Performs a more extensive test that may change the device. When executed, the scanner may beep. n/a m_ctrlScanner.CheckHealth(OPOS_CH_INTERNAL)
CH Interactive Not Supported n/a
Data Event
Clear Input Clear method. Clears the input data. n/a m_ctrScanner.ClearInput()
Decode Data Set decode data enable. n/a m_ctrScanner.SetDecodeData(1)
Data Events Set data event enabled. Must enable data event to get data. n/a m_ctrlScanner.SetDataEventEnabled(1)
Auto Enable Check box to automatically enable the scanner after a decode scan. n/a Refer to OPOS Scanner Sample Application source code provided with the SDK installation.
Statistics And Clear Input Properties
Retrieve Retrieve statistic. GoodScanCount m_ctrlScanner.RetrieveStatistics(&test)
Reset Statistics Reset statistics GoodScanCount m_ctrlScanner.ResetStatistics("GoodScanCount")
Update Statistics Update statistics GoodScanCount CString strTemp;
m_nGoodScanCount=100;
strTemp.Format("GoodScanCount=%d",m_nGoodScanCount );
m_ctrlScanner.UpdateStatistics(strTemp)
Clear Input Properties Clear input properties n/a m_ctrlScanner.ClearInputProperties()
Properties and Methods
Set Properties Set the value of property to the given value. n/a m_ctrScanner.SetFreezeEvents(0)
m_ctrScanner.SetAutoDisable(1)
Result Values
Return Value Return value of the last function call. This is only a readable property.
Result Code Return value of result code. This is only a readable property. m_ctrScanner.GetResultCode()
Direct IO
Command Select the Direct IO command to be executed. n/a
Execute Execute the selected command. n/a

Viewing Bar Code Data

To view bar code data using the Scanner OPOS Test Utility:

  1. Scan the USB OPOS (Hand-held) bar code, SNAPI bar code or Wincor-Nixdorf RS-232 Mode B bar code on Scanner Configuration Bar Codes to configure the scanner for the correct communication protocol.
  2. Under the folder \Program Files\Zebra Technologies\Barcode Scanners\Scanner SDK\OPOS\Scanner OPOS\Sample Applications\bin, enter the sub-folder appropriate to the host architecture (x86 or x64) and run Scanner-OPOS-Test.exe to launch the Scanner OPOS Test Utility.
  3. Select Open. The Open Service Object window appears.
  4. Select Ok to use the Zebra Scanner Service Object that the Scanner SDK Installshield setup program loaded on the PC.
  5. Select Claim
  6. Select Device Enable
  7. Select Data Events
  8. Select Decode Data
  9. Scan the following sample bar code:

    UPC-A 0-1234567890-5
  10. Select Data Events to view the scanned UPC-A bar code data. The bar code data that the driver processed appears in the Scan Data Label and Scan Data Type boxes:

    Figure 2: Scanner OPOS Sample Application - Scan Data

  11. Select Clear Input to clear the data from the Scan Data Type and Scan Data Label boxes.
  12. To perform a second test, scan another bar code.

Getting and Setting OPOS Properties

This utility allows getting and setting the OPOS properties of the Zebra Scanner OPOS Driver via the Properties And Methods drop-down list.

To get and set the OPOS properties of the Zebra Scanner OPOS Driver:

  1. Scan the USB OPOS (Hand-held) bar code, SNAPI bar code or Wincor-Nixdorf RS-232 Mode B bar code on Scanner Configuration Bar Codes to configure the scanner for the correct communication protocol.
  2. Under folder \Program Files\Zebra Technologies\Barcode Scanners\Scanner SDK\OPOS\Scanner OPOS\Sample Applications\bin, enter the sub-folder appropriate to the host architecture (x86 or x64) and run Scanner-OPOS-Test.exe to launch the Scanner OPOS Test Utility.
  3. Select Open. The Open Service Object window appears.
  4. Select Ok to use the Zebra Scanner Service Object that the SDK Installshield loaded on the PC.
  5. Select Claim
  6. Select Device Enable
  7. Select a configurable (setable) property in the Properties And Methods drop-down list. You can configure some properties (e.g., AutoDisable, FreezeEvents); other properties are read only (e.g., ServiceObjectVersion, DataCount).
  8. The current value of the OPOS driver appears in the edit box below the property selected in the list box. The values 1 and 0 represent true and false, respectively.
  9. To change the configurable property, change the value in the edit box and select Set Properties. This updates the property with the new value.

Creating a Custom OPOS Sample Application

You may use any programming language to create a custom OPOS sample application. However, Microsoft supported languages are recommended (e.g., Visual Basic, Visual C++ or C#).

To create a custom OPOS sample application:

  1. Create a project in the desired Microsoft Visual Studio development environment.
  2. Select Choose Toolbox Items… from the Tools menu.
  3. Select (check) OPOS Scanner Control from the COM Components tab.
  4. Add OPOSScanner.ocx to the project.
  5. Drag and drop to the form/Dialog window.
  6. Add a variable (handle) for the scanner control added to the form/Dialog window.
  7. Call Open(), Claim() methods [e.g., Open ("SYMBOL_SCANNER"); Claim (2000);].
  8. SetDeviceEnabled to TRUE.
  9. Set Freeze Events property to FALSE [e.g., SetFreezeEvents (FALSE)].
  10. SetDataEventsEnable to TRUE to get scan data events.
  11. When done, SetDeviceEnabled to FALSE, Release() and Close() the service.
  12. Call Device Disable property, release and close methods to close the connection.

Return Value and Result Code

When calling any method, check whether the return value is 0 (=OPOS_SUCCESS) to ensure the method is successful. Otherwise it returns an error code, which indicates the reason for the error. After setting property values, check that the result code returns 0 (=OPOS_SUCCESS), indicating success. If unsuccessful, it returns an error code.


Direct IO

The OPOS driver does not support any direct I/O functions to the scanner. However, an application developer can get management access to an RSM-ready scanner through the Zebra Scanner SDK. Refer to the Zebra Scanner SDK for Windows Developer’s Guide (p/n 72E-149784-xx) for more information.


Statistics Methods

The Zebra OPOS Driver supports the retrieveStatistics, resetStatistics, and updateStatistics methods. GoodScanCount is the only defined statistic in the Zebra OPOS Driver and can be used as a parameter for these methods.


Modified Claim Functionality

Model number, serial number and the Type (Scanner Host Mode) parameters are available in the system registry as configurable entries so that user can configure them according to the business requirement. Claiming a scanner compares the scanner details provided in system registry with the attached scanner properties. The claim is successful when they match.

Enter * to include anything for the particular entry. For example, enter * for the serial number to claim scanners with any serial number. Otherwise, the claim is successful only if the provided serial number and model number matches the present scanner.

For the model number and serial number, provide the exact value, or part of the string and a star (*). Do not enter a star (*) in the middle of a string; in this case, all data after star (*) is ignored. Provide a value and star as a model number (e.g., LS4208*) to accept all scanners starting with that model number (LS4208). Provide a star (*) for the serial number to accept all scanners regardless of serial number.

It is required to add the full name of each scanner type as a comma or space delimited list to enable the scanners to be Claimed. As an example, to include SNAPI scanners and IBM hand- held mode scanners the "Type" entry should be (USBIBMHID SNAPI). To include all scanner modes (Types) the value should be (ALL)

Since non-RSM scanners, including serial scanners in Wincor-Nixdorf RS-232 Mode B, do not provide the model number and serial number, to claim these scanners set a " * " to both ModelNumber and SerialNumber registry values.