Windows SDK Sample Applications

Overview

This chapter provides information about testing and evaluation of the Zebra Scanner SDK's software components using the test utilities provided in the SDK.

NOTE For the attributes (parameters) applicable to a specific scanner, refer to the Product Reference Guide . Product Reference Guides may also contain an appendix listing the generic non-parameter attributes supported on most Zebra scanners.


Test Utilities Provided in the SDK

The Zebra Scanner SDK includes the following test utilities:

  • Zebra Scanner SDK C++ Sample Application
  • Zebra Scanner SDK C# .Net Sample Application

Each test utility demonstrates the main functionalities of the SDK. You can gain an understanding of the Zebra Scanner SDK using these test utilities. This section also describes how to use the test utilities' functionality.

NOTE You may need to install the Microsoft®.Net Framework v2.0 or later to execute C# .Net Sample application. If so, Microsoft detects and informs the user of this requirement.

The Zebra Scanner SDK Test Utilities support the following functionality:

  • Discovery of asset tracking information
  • Scan a bar code
  • Capture Image and Video
  • Capture documents with Intelligent Document Capture (IDC)
  • Attribute query and setting
  • Host Variant switching
  • Firmware upgrade.

Scanner SDK C++ Sample Application

The Scanner SDK C++ Sample Application enables you to simulate an application that communicates with the Scanner SDK. The utility demonstrates the functionality of the SDK. It includes C++ source code and its solution and project files for further reference.

Figure 1: C++ Sample Application

Scanner SDK C#.Net Sample Application

The Scanner SDK C#.Net Sample Application enables you to simulate an application that communicates with the Scanner SDK. The utility demonstrates the functionality of the SDK. It includes C#.Net source code and its solution and project files for further reference.

Figure 2: C#.Net Sample Application

Table 1: Test Utility Buttons and Fields by Tab Screen

Button for Field Description
Discover Scanners Invokes Open, GetScanners methods and register for all the events.
Select Scanner Select the scanner you want to invoke the command
Connected Scanners List all the connected scanners regardless of the mode
Pull Trigger Soft Pull Trigger the scanner for Bar code, Image and Video actions
Release Trigger Soft Release Trigger the scanner for Bar code, Image and Video actions
Bar Code Tab
Flush Macro PDF Flush Macro PDF bar code buffer
Abort Macro PDF Abort Macro PDF continues read
Clear Clear the Bar code data area
Decoded Bar Code Display label value of the scanned bar code
Symbology Display the symbology of scanned bar code
Enable Emulation Enable Simulated HID Keyboard Output
Image/Video Tab
Image Invoke image capture mode
Video Invoke video capture mode
Abort Transfer Abort Image Transfer on serial scanners
Image Type Select JPG, TIFF or BMP image type
Enable Video View Finder Enable the view finder in image mode
Save Image Save the captured image
IDC Tab
Get Display value of the IDC-related parameter in the drop down menu
Set Temporarily set the value of the IDC-related parameter in the drop down menu
Store Permanently store the value of the IDC-related parameter in the drop down menu
Value Field to display, and enter an IDC-related parameter value
Decode Data Value of linked or anchor bar code data
Symbology Symbology of linked or anchor bar code
Use HID Specify HID channel for data transmission (instead of the default BULK channel)
Clear Clears all the fields
Scanner Actions Tab
Enable/Disable Scanner Enable/Disable the scanner for data/image/video capture initiation
Aim Switch on and off Aim control of the scanner
Beeper Beep the peeper of the scanner
Reboot Scanner Reboot the scanner
LED Light the LED(s) on the scanner
Switch Host Variant Switch the scanner host type from current type to desired type; the user has the option to select silent feature and variant change persistent and non-persistent.
RSM Tab
Get All IDs Get all supported attribute IDs from the selected scanner
Get Value Select one or more attribute IDs and get the value for them
Next Value Get the next attributes value given the current attribute number
Store Value Store value(s) for selected attribute(s)
Set Value Set value(s) for selected attribute(s)
Select All Select all the attribute IDs at the RSM data viewer
Clear All Clear all the attribute data at the RSM data viewer
Clear All Values Clear all the attribute values at the RSM data viewer (C# only)
Clear Value Clear a selected attribute value at the RSM data viewer (C# only)
Advanced Tab
Firmware Update Options Updated firmware and launch the new firmware on the scanner
Browse Browse the Firmware file (*.DAT) or Plug-in file (*.SCNPLG)
Update Initiate firmware update process
Abort If you want to abort firmware update process
Launch Once firmware update finishes launch the new firmware in the scanner
Claim Scanner Exclusively claim and declaim the scanner for this application
Miscellaneous Tab
SDK Version Get the scanner SDK version
Get Device Topology Get the scanner device topology, this is useful to get an idea of scanner topology for cascaded scanners
Serial Interface Settings Serial interface settings for serial scanners
Scale Tab
Read Weight Read the weight of the item on the scale
Zero Scale Zero the scale
Reset Scale Reset the scale
Weight Measured Weight of the item (Pounds or Kilograms)
Weight Unit Weight mode of the scale (English or Metric)
Logs Tab
Event Log Command and event log, logs commands initiated
XML Log Displays Output of each function if an output exists
Clear Event Log Clear command and event log area
Clear XML Log Clear XML log area

NOTE The SDK Sample Application in the latest release of the Scanner SDK for Windows implements a ScanToConnect tab. The ScanToConnect feature enables a Zebra cordless Bluetooth scanner to pair directly to a PC/tablet by scanning an on-screen bar code, replacing the need for a paper pairing label. This paperless pairing solution wirelessly connects the scanner directly to the host, without the need for a cradle.

NOTE Sample source code for the ScanToConnect tab is included with installation of the SDK Sample Application. For further information on this functionality, contact the Zebra Technologies Global Customer Support Center at: www.zebra.com/support


How to Verify Scanner SDK Functionality

This section guides you through a series of use cases and test cases of the Zebra Scanner SDK and its functionality.

See Basic Installation Verification for more information

Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation

  1. Connect a Zebra USB scanner(s) to the computer and put the scanner into USB OPOS (Hand Held) or USB SNAPI mode by scanning one of the bar codes below.

    USB (IBM Hand-Held)
    USB (IBM Hand-Held)
  2. Launch the Zebra Scanner SDK Sample Utility by selecting Start > All Programs > Zebra Scanner > Scanner SDK > Scanner SDK Sample Application (C++)"or Scanner SDK Sample Application (C#.Net).

    Figure 3: Start Scanner SDK Sample Application (C++) or C# .Net
  3. Click Discover Scanners to display all the connected scanners in the Connected Scanners area
  4. Clicking Discover Scanners in the sample application executes an Open for all types of scanners and an ExecCommand with the REGISTER_FOR_EVENTS method using the following XML and a GetScanners API call:

    
    <inArgs>
        <cmdArgs>
            <arg-int>6</arg-int>
            <arg-int>1,2,4,8,16,32</arg-int>
        </cmdArgs>
    </inArgs>
    
    

NOTE The first <inArgs> tag in the XML is filled with the number of events you want to register. In the example above, number of event it wants to register is "6". The second tag is filled with the event ids that you want to register separated by the commas (","). See event IDs in table below.

Table 2: Supported Event IDs

Event Name Event ID
SUBSCRIBE_BARCODE 1
SUBSCRIBE_IMAGE 2
SUBSCRIBE_VIDEO 4
SUBSCRIBE_RMD 8
SUBSCRIBE_PNP 16
SUBSCRIBE_OTHER 32

  1. The GetScanners API call produces XML code as follows:

    
    <?xml version="1.0" encoding="UTF-8" ?>
    <scanners>
        <scanner type="SNAPI"> 
            <scannerID>1</scannerID> 
            <serialnumber>7116000501003</serialnumber>
            <GUID>A2E647DED2163545B18BCEBD0A2A133D</GUID> 
            <VID>1504</VID>
            <PID>6400</PID>
            <modelnumber>DS670-SR20001ZZR</modelnumber>
            <DoM>27APR07</DoM>
            <firmware>NBRPUAAC</firmware>
        </scanner>
    </scanners>
    
    

    Table 3: Data Representation of the GetScanners Output in this Example

    Scanner Information Value Description
    Scanner ID 1 A unique ID assigned for a scanner from the SDK; any scanner specific method execute from ExecCommand should point to a scanner ID
    Serial Number 7116000501003 Device serial number printed on the label
    Model Number DS670-SR20001ZZR Device model number
    Date of Manufacture 27APR07 Device date of manufacture
    Firmware Version NBRPUAAC Current firmware version
    H/W GUID A2E647DED2163545B18BCEBD0A2A133D Hardware unique ID

  2. The XML consists of the scanner type, scanner ID, serial number, GUID, VID, PID, model number, date of manufacture and firmware version of the connected scanners.

    All discovered scanners are presented in the Connected Scanners window by processing the XML received from the GetScanners command along with their asset tracking information returned by querying device parameters. The detection of scanners indicates the SDK was installed successfully. Click Discover Scanners to display the connected scanners.

    Figure 4: Connected Scanners

Generating Scan-to-Connect Parameter Barcode

This document provides detailed instructions for generating a “Scan to Connect” parameter barcode, which is used to directly connect Bluetooth scanners to the host.

Prerequisites

Before proceeding, ensure you have the following:

  1. CoreScanner Driver for Windows installed.
  2. A host with a Bluetooth radio module (either inbuilt or external).

Steps to Generate the Scan to Connect Barcode

  1. Install CoreScanner Service

    Ensure that the CoreScanner Service is properly installed on your host machine. This service is required to communicate with the scanner and execute necessary commands.

  2. Verify Bluetooth Radio Module

    Ensure your host has an operational Bluetooth radio module. This module can be either inbuilt or an external one connected to your host.

  3. Execute OPEN API of CoreScanner

    To begin, you need to execute the OPEN API of the CoreScanner. This will initialize the communication with the CoreScanner service.

  4. Execute API to Register for Events

    After successfully opening the CoreScanner, the next step is to register for events. This is done by calling the EXEC API with a specific command to subscribe to the desired events.

  5. Send ExecCommand to Generate Bluetooth Parameter Barcode

    After successfully opening the CoreScanner, send an ExecCommand to generate the Bluetooth parameter barcode.

    Here is an example of how to execute the ExecCommand in C#:

    
    private void GetPairingBarcode()
    {    
        // Check the selection from the drop down is slected.        
        if (cmbScannerType.SelectedItem != null && cmbProtocol.SelectedItem != null && cmbHostName.SelectedItem != null)
        {
            /*
            //-- Enums for defaultOptions -- //
                [Description("No Defaults")]
                NoDefaults = 0,
                [Description("Set Factory Defaults")]
                SetFactoryDefaults = 1,
                [Description("Restore Factory Defaults")]
                RestoreFactoryDefaults = 2
            */
            Constants.DefaultOption defaultOption = GetSelectedDefaultOptionID(cmbDefaultOption.SelectedIndex);
            
            /*
            //-- Enums for imageSize -- //
                [Description("Small")]
                Small = 1,
                [Description("Medium")]
                Medium = 2,
                [Description("Large")]
                Large = 3
            */
            Constants.ImageSize imageSize = GetSelectedImageSizeID(cmbImageSize.SelectedIndex);
            
            /*
            //-- Enums for scannerType -- //
                [Description("Legacy")]
                Legacy = 0,
                [Description("New")]
                New = 1            
            */
            Constants.ScannerType scannerType = GetSelectedScannerTypeID(cmbScannerType.SelectedIndex);
            
            /*
            //-- Enums for protocol -- //
                [Description("Simple Serial Interface (SSI)")]
                SSI = 1,
                [Description("Serial Port Profile(SPP)")]
                SPP = 14,
                [Description("Human Interface Device(HID)")]
                HID = 17            
            */
            Constants.ProtocolName protocol = GetSelectedProtocolID(cmbProtocol.SelectedIndex);
            
            /*
            //-- Enums for host -- //
                [Description("SSI BT Classic (Non-Discoverable)")]
                SSIBTClassic = 22                    
            */
            Constants.HostName host = GetSelectedHostID(cmbHostName.SelectedIndex);
    
            int iProtocol = (int)protocol;
            int iDefaultOption = (int)defaultOption;
            int iImagesize = (int)imageSize;
    
            //Logic for protocol SSI and scanner
            if (scannerType == Constants.ScannerType.New && protocol == Constants.ProtocolName.SSI)
            {
                iProtocol = (int)host;
            }
    
            int status = STATUS_FALSE; //This will hold the status of the Exec API. if Success returns '0', else it's an error.
            string outXml = "";
            string inXml = "";
            int NoOfParameters = 3; //This is the number of parameters that we send throgh the inXml.
    
            string parameters = string.Join(",", iProtocol, iDefaultOption, iImagesize);
            inXml = scanToConnect.GenerateInitXML(NoOfParameters, parameters);
    
            /*
            // -- Example of inXml with above parameters.
            "<inArgs>"
                + " <cmdArgs>"
                    + "<arg-int>" + NoOfParameters + "</arg-int>" 
                    + "<arg-int>" + Parameters + "</arg-int>"
                + " </cmdArgs>"
            + "</inArgs>"
            */
            ExecCmd(Constants.GetPairingBarcode, ref inXml, out outXml, out status); //Constants.GetPairingBarcode = 1005
            DisplayResult(status, "GET_PAIRING_BARCODE");
        }
    }                                                                
    
    
  6. Receive Scan to Connect Barcode Image.

    If the ExecCommand in step 5 returns a success status, the pairing barcode will be received as an image in the parameter barcode event.

Handling the Parameter Barcode Event

You need to handle the event where the pairing barcode image is received. Here is an example event handler in C#:


private void OnParameterBarcodeEvent(short eventType, int size, short imageFormat, ref object sfImageData, ref string pData)
{
    if (eventType == 1) //Pairing Barcode event type would be '1'
    {
        Image img = BaseMethods.ProcessImageData(sfImageData); 
        if (picBBarcode.Width < img.Width)
        {
            picBBarcode.SizeMode = PictureBoxSizeMode.StretchImage;
        }
        else
        {
            picBBarcode.SizeMode = PictureBoxSizeMode.CenterImage;
        }
        picBBarcode.Image = img;        
        if (picBBarcode.Image != null)
        {
            btnSaveBarcode.Enabled = true;
            //Image saving method
        }
        UpdateResults("ParameterBarcode Event fired");
    }
}

/// <summary>
/// Process the Image object data to Image 
/// </summary>
/// <param name="ImageData">object that contains raw image data</param>
/// <returns>Formatted Image</returns>
public static Image ProcessImageData(object ImageData)
{
    try
    {
        Array arr = (Array)ImageData;
        long len = arr.LongLength;
        byte[] byImage = new byte[len];
        arr.CopyTo(byImage, 0);

        MemoryStream ms = new MemoryStream();
        ms.Write(byImage, 0, byImage.Length);

        Image img = Image.FromStream(ms);
        return img;
    }
    catch (Exception ex)
    {
        throw ex;
    }
}                                                            

Figure 5: Sample App UI of the selection and the Scan-to-Connect Barcode Image

Bar Code Scanning

  1. Connect and discover a scanner (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).
  2. Scan a bar code and its decoded data is returned in the form of XML data and displayed on the Barcode tab. To illustrate the typical implementation, the sample application also displays only the "Bar code" data below the XML data.

    Figure 6: Decoded Bar Code Data

Example

  1. Scan the following sample bar code after discovering the scanner in the sample application (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).

    UPC-A 0-1234567891-2
  2. The following XML is returned:

    
    <?xml version="1.0" encoding="UTF-8" ?>
    <outArgs>
        <scannerID>2</scannerID>
        <arg-xml>
            <scandata>
                <modelnumber>DS670-SR20001ZZR</modelnumber>
                <serialnumber>7116000501003</serialnumber>
                <GUID>A2E647DED2163545B18BCEBD0A2A133D</GUID>
                <datatype>8</datatype>
                <datalabel>0x30 0x31 0x32 0x33 0x34 0x35 0x36 0x37 0x38 0x39 0x31 0x32</datalabel>
                <rawdata>0x30 0x31 0x32 0x33 0x34 0x35 0x36 0x37 0x38 0x39 0x31 0x32</rawdata>
            </scandata>
        </arg-xml>
    </outArgs>
    
    
  3. By processing the XML above, the sample application displays the decoded bar code in the Decoded Bar code text box and the symbology in the Symbology text box.

Language/Locale Details

  1. Toggle the Enable Emulation check box to enable/disable Simulated HID Keyboard Output.
  2. Select the language locale from the drop down menu.

    The sample application first retrieves the current config.xml file (see Simulated HID Keyboard Configuration) by executing an ExecCommand API call with the KEYBOARD_EMULATOR_GET_CONFIG method and an empty inXML. It receives outXML as shown below:

    inXML:

    
    <inArgs></inArgs>
    
    

    outXML:

    
    <outArgs>
        <arg-xml>
            <KeyEnumState>1</KeyEnumState>
            <KeyEnumLocale>0</KeyEnumLocale>
        </arg-xml>
    </outArgs>
    
    

    The sample application processes the XML above and populates the user interface. The <KeyEnumState> tag indicates the current state of Simulated HID Keyboard Output, where enabled = 1 and disabled = 0. The <KeyEnumLocale> tag indicates the language locale number currently active with the CoreScanner service. The value of "0" above indicates English.

    Use the ExecCommand API call with the KEYBOARD_EMULATOR_ENABLE method and following inXML to enable/disable Simulated HID Keyboard Output.

    
    <inArgs>
        <cmdArgs>
            <arg-bool>TRUE</arg-bool>
        </cmdArgs>
    </inArgs>
    
    

    To enable HID KB Emulator use "TRUE" in <arg-bool> tags and "FALSE" to disable it.

    
    <inArgs>
        <cmdArgs>
            <arg-int>1</arg-int>
        </cmdArgs>
    </inArgs>
    
    

    Use the ExecCommand API call with the KEYBOARD_EMULATOR_SET_LOCALE method and following inXML to change the language locale.

    Set the <KeyEnumLocale> tag value to "1" for French and "0" for English.

Capture Image and Video

  1. Connect and discover an imaging scanner (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).
  2. Select a "SNAPI" mode scanner ID from the Select Scanner drop-down box. Your selection is then reflected in the Connected Scanners window.

    NOTE If no SNAPI scanner is shown in the Connected Scanners window, you must connect an imaging scanner that supports image/video transfer. For an up-to-date table listing scanner models and their supported communication modes refer to the Scanner SDK for Windows website at: www.zebra.com/scannersdkforwindows

    Alternatively, select "SNAPI" mode scanner in the Connected Scanners area. Your selected Scanner's ID is displayed in the Select Scanner drop-down combo box.

    Figure 7: Scanner Selection
  3. Go to the Image & Video tab.
  4. Select an image type of JPG, TIFF or BMP.
  5. Selecting the image type in the sample application executes an ExecCommand API call using the DEVICE_SET_PARAMETERS method and following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-xml>
                <attrib_list>
                    <attribute>
                        <id>304</id>
                        <datatype>B</datatype>
                        <value>4</value>
                    </attribute>
                </attrib_list>
            </arg-xml>
        </cmdArgs>
    </inArgs>
    
    

    NOTE The <scannerID> tag in the XML is filled with the scanner’s ID selected in the Connected Scanners list of the sample application. The <id> tag contains the image file type parameter of the selected scanner. In the XML example above, this value is 304. The value 4 indicates the image type the user should get from the scanner. See the following table for valid Image Types.

    Table 4: Image Types

    Image Type Value
    BMP_FILE_SELECTION 3
    TIFF_FILE_SELECTION 4
    JPEG_FILE_SELECTION 1

    NOTE These values may change with the scanner model. Refer to the scanner Product Reference Guide for more information on scanner parameters. For more information about parameter settings, see Parameter Setting (Device Configuration) on page 4-21

  6. Check Enable Video View Finder and click either Image to put the scanner into image capture mode or Video to put the scanner into video capture mode.
  7. Checking Enable Video View Finder in the sample application executes an ExecCommand API call with the DEVICE_SET_PARAMETERS method and following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-xml>
                <attrib_list>
                    <attribute>
                        <id>324</id>
                        <datatype>B</datatype>
                        <value>1</value>
                    </attribute>
                </attrib_list>
            </arg-xml>
        </cmdArgs>
    </inArgs>
    
    

    NOTE The <scannerID> tag in the XML contains the selected scanner’s ID from the Connected Scanners list of the sample application. The <id> tag contains the video view finder parameter number of the scanner and value 1 indicates that the view finder is enabled. A value “0” indicates the view finder is disabled.

  8. Click Image in the sample application. Image executes an ExecCommand API call using the DEVICE_CAPTURE_IMAGE method with the XML code below. Click Video to execute an ExecCommand API call using the DEVICE_CAPTURE_VIDEO method with the following XML code.

    
    <inArgs>
        <scannerID>1</scannerID>
    </inArgs>
    
    
  9. Click Pull Trigger on the bottom left side of the utility to capture an image. If the scanner was place into video capture mode in the previous step, click Pull Trigger once to start video capture and click Release Trigger to stop video capture.
  10. Clicking Pull Trigger or Release Trigger in the sample application executes an ExecCommand API call using the corresponding DEVICE_PULL_TRIGGER or DEVICE_RELEASE_TRIGGER method with the following XML code

    
    <inArgs>
        <scannerID>1</scannerID>
    </inArgs>
    
    

    NOTE You can use the trigger on the scanner to start and stop image or video capture instead of the soft trigger buttons provided in the sample utility.

    Figure 8: Captured Image Displayed on the Image & Video Tab

  11. If you registered with ImageEvent you receive an image event for the performed pull trigger when in image mode.
  12. 12. If you registered with VideoEvent you receive a video event for the performed pull trigger when in video mode.

Beep the Beeper

Zebra scanners are capable of sounding the beeper by invoking the Beeper method from the host system.

  1. Connect and discover a scanner (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).
  2. Select a "SNAPI" or "OPOS/IBM OPOS" mode scanner ID from the Select Scanner drop-down box. Your selection is reflected in the Connected Scanners window (see Figure 6).
  3. Select the desired beep sequence from the list defined on the Scanner Actions tab as shown below.

    Figure 9: Beep Values
  4. Click Beep
  5. Clicking Beep in the sample application executes an ExecCommand API call with the SET_ACTION method and following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-int>2</arg-int>
        </cmdArgs>
    </inArgs>
    
    

    NOTE The <scannerID> tag in the XML is filled with the scanner's ID selected in the Connected Scanners list of the sample application. The <arg-int> tag in the XML is filled with the beep's ID selected in the Beeper drop-down list shown in Figure 8.

  6. You can sound any of the beeps by changing the value of the tag in the XML code. Successful execution of the command returns the status parameter as "0".

Flash the LED

Zebra scanners are capable of flashing an LED by initiating the flash LED method from the host system.

  1. Connect and discover a scanner (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).
  2. Select a "SNAPI" or "OPOS/IBM OPOS" mode scanner ID from the Select Scanner drop-down box. Your selection is reflected in the Connected Scanners window (see Figure 6).
  3. Select the desired LED from the list, defined on the Scanner Actions tab

    Figure 10: LED Selection
  4. Click On to light the LED and Off to turn it off.
  5. Clicking On in the sample application executes an ExecCommand API call with the SET_ACTION method and the following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-int>43</arg-int>
        </cmdArgs>
    </inArgs>
    
    

    NOTE The <scannerID> tag in the XML is filled with the scanner ID selected in the Connected Scanners list of the sample application. The tag in the XML is filled with the corresponding action value to turn on or off the LED selected from the drop-down list shown in Figure 9.

  6. You can control any LED supported by the scanner by changing the action value in the <arg-int> tag. The list of action values can be found in Action Attributes and Values.
  7. Clicking Off in the sample application executes an ExecCommand API call using the DEVICE_LED_OFF method with the same XML code that turned it on.

NOTEThe Beep the Beeper and Flash the LED XML code examples are the same. The only difference between these commands is the method name. All XML used in an ExecCommand API call has a common format. The </inArgs> tag always contains the <scannerID> tag and optionally contains <cmdArgs> tags and <arg-xml> tags inside the </inArgs> tag. Inside <cmdArgs>, there can be <arg-string>,<arg-bool> and <arg-int> tags. You can execute different commands for the same XML by changing the method parameter in ExecCommand.

Querying Attributes and Parameters

To query parameters from a specific device, such as the Date of Manufacture and Firmware Version, use the following procedure.

  1. Connect and discover a scanner (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).
  2. Select the scanner you want to query from the list of Connected Scanners and then select the RSM tab.
  3. Click Get All IDs to retrieve the entire list of supported attribute IDs of the selected scanner. This operation executes an ExecCommand API call with the ATTR_GETALL method and the following XML:

    
    <inArgs>
        <scannerID>1</scannerID>
    </inArgs>
    
    

    NOTE The <scannerID> tag in the XML contains the scanner's ID selected in the Connected Scanners list of the sample application.

  4. The sample application receives the XML output below and displays the corresponding attribute IDs on the grid (see Figure 13).

    
    <?xml version="1.0" encoding="UTF-8" ?>
    <outArgs>
        <scannerID>1</scannerID>
        <arg-xml>
            <modelnumber>DS670-SR20001ZZR</modelnumber>
            <serialnumber>7116000501003</serialnumber>
            <GUID>A2E647DED2163545B18BCEBD0A2A133D</GUID>
            <response>
                <opcode>5000</opcode>
                <attrib_list>
                    <attribute name="">0</attribute>
                    <attribute name="">1</attribute>
                    <attribute name="">2</attribute>
                    <attribute name="">3</attribute>
                    <attribute name="">4</attribute>
                    <attribute name="">5</attribute>
                    <attribute name="">6</attribute>
                    <attribute name="">7</attribute>
                    <attribute name="">8</attribute>
                    <attribute name="">9</attribute>
                    <attribute name="">10</attribute>
                    <attribute name="">11</attribute>
                    <attribute name="">12</attribute>
                    <attribute name="">13</attribute>
                    <attribute name="">14</attribute>
                    <attribute name="">15</attribute>
                    <attribute name="">16</attribute>
                    <attribute name="">17</attribute>
                    <attribute name="">18</attribute> 
                    <attribute name="">20</attribute>
                    <attribute name="">21</attribute>
                    <attribute name="">22</attribute>
                    <attribute name="">23</attribute>
                    <attribute name="">24</attribute>
                    <attribute name="">25</attribute>
                    <attribute name="">26</attribute>
                    <attribute name="">27</attribute>
                    <attribute name="">28</attribute>
                    <attribute name="">29</attribute>
                    <attribute name="">30</attribute>
                    <attribute name="">31</attribute>
                    <attribute name="">34</attribute>
                    <attribute name="">35</attribute>
                    <attribute name="">36</attribute>
                    <attribute name="">37</attribute>
                    <attribute name="">38</attribute>
                    <attribute name="">39</attribute>
                    <attribute name="">655</attribute>
                    <attribute name="">656</attribute>
                    <attribute name="">657</attribute>
                    <attribute name="">658</attribute>
                    <attribute name="">659</attribute>
                    <attribute name="">665</attribute>
                    <attribute name="">670</attribute>
                    <attribute name="">672</attribute>
                    <attribute name="">673</attribute>
                    <attribute name="">705</attribute>
                    <attribute name="">716</attribute>
                    <attribute name="">718</attribute>
                    <attribute name="">721</attribute>
                    <attribute name="">724</attribute>
                    <attribute name="">726</attribute>
                    <attribute name="">727</attribute>
                    <attribute name="">728</attribute>
                    <attribute name="">730</attribute>
                    <attribute name="">731</attribute>
                    <attribute name="">734</attribute>
                    <attribute name="">735</attribute>
                    <attribute name="">745</attribute>
                    <attribute name="">6000</attribute>
                    <attribute name="">6001</attribute>
                    <attribute name="">6002</attribute>
                    <attribute name="">6003</attribute>
                    <attribute name="">6004</attribute>
                    <attribute name="">20004</attribute>
                    <attribute name="">20006</attribute>
                    <attribute name="">20007</attribute>
                    <attribute name="">20008</attribute>
                    <attribute name="">20009</attribute>
                    <attribute name="">20010</attribute>
                    <attribute name="">20011</attribute>
                    <attribute name="">20013</attribute>
                </attrib_list>
            </response>
        </arg-xml>
    </outArgs>
    
    
    Figure 11: Get RSM IDs

  5. To query attributes, select attribute IDs and click Get Value to view the attribute values. This operation executes an ExecCommand API call with the ATTR_GET method and the following XML.

    
    <inArgs>
        <cmdArgs>
            <scannerID>1</scannerID>
            <arg-xml>
                <attrib_list>535,20004,1,140,392</attrib_list>
            </arg-xml>
        </cmdArgs>
    </inArgs>
    
    

    NOTE The tag in the XML contains the scanner's ID selected in the Connected Scanners list and the <attrib_list> tag with the attribute IDs selected in the RSM grid.

    For example, if you want to retrieve the values of the Date of Manufacture, Firmware Version, UPC-A status, Beeper Volume and ADF Rule parameters, you need to know their attribute IDs. Table 5 shows the corresponding IDs. Selecting these attribute IDs in the grid of the sample application and clicking Get Value executes an ExecCommand API call with the ATTR_GET method and the XML shown above.

    Table 5: Device Parameters to Query

    Parameter Attribute #
    Date of Manufacture 535
    Firmware Version 20004
    UPC A status 1
    Beeper Volume 140
    ADF Rule 392

    After successfully executing the command, the output XML appears in the Logs tab of the sample application as follows:

    
    <?xml version="1.0" encoding="UTF-8" ?> 
    <outArgs>
        <scannerID>1</scannerID>
        <arg-xml>
            <modelnumber>DS670-SR20001ZZR</modelnumber>
            <serialnumber>7116000501003</serialnumber>
            <GUID>A2E647DED2163545B18BCEBD0A2A133D</GUID>
            <response>
                <opcode>5001</opcode>
                <attrib_list>
                    <attribute>
                    <id>535</id>
                        <name></name>
                        <datatype>S</datatype>
                        <permission>R</permission>
                        <value>27APR07</value>
                    </attribute>
                    <attribute>
                        <id>20004</id>
                        <name></name>
                        <datatype>S</datatype>
                        <permission>R</permission>
                        <value>DS6707X4</value>
                    </attribute>
                    <attribute>
                        <id>1</id>
                        <name></name>
                        <datatype>F</datatype>
                        <permission>RWP</permission>
                        <value>True</value>
                    </attribute>
                    <attribute>
                        <id>140</id>
                        <name></name>
                        <datatype>B</datatype>
                        <permission>RWP</permission>
                        <value>0</value>
                    </attribute>
                    <attribute>
                        <id>392</id>
                        <name></name>
                        <datatype>A</datatype>
                        <permission>RWP</permission>
                        <value>0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00 0x00</value>
                    </attribute>
                </attrib_list>
            </response>
        </arg-xml>
    </outArgs>
    
    

    The sample application's RSM grid displays the output as in Figure 12 by processing the XML above.

    Figure 12: RSM Attribute Values for Selected IDs

Parameter Setting (Device Configuration)

To set parameters of a specific device, such as UPC-A status or Beeper Volume, use the following procedure.

  1. Query the parameter.
  2. To set an attribute, select and edit the attribute value in the RSM window data grid. Then select the entire row of the changed attribute and click Set Value or Store Value. Clicking these buttons execute an ExecCommand API call using the ATTR_SET or ATTR_STORE method and XML code shown below.

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-xml>
                <attrib_list>
                    <attribute>
                        <id>1</id>
                        <datatype>F</datatype>
                        <value>False</value>
                    </attribute>
                </attrib_list>
            </arg-xml>
        </cmdArgs>
    </inArgs>
    
    

    NOTE The <scannerID> tag in the XML contains the scanner's ID selected from the Connected Scanners list and the <attrib_list> tag contains the <attribute> tags selected in the RSM grid.

Examples

These examples demonstrate how to enable/disable a symbology, program an ADF rule, control beeper volume and control LEDs.

Before starting the example, scan the Set All Defaults barcode below to return all parameters to the scanner's default values (replacing the scanner's current settings). Refer to the scanner's Product Reference Guide for default values.

USB (IBM Hand-Held)

Enable/Disable a Symbology

To disable the UPC-A symbology, determine the attribute ID of UPC-A by referencing the scanner's Product Reference Guide. The attribute ID of the UPC-A parameter is 1. To change and validate the setting, use the following procedure:

  1. Put the scanner into USB OPOS (Hand Held) or USB SNAPI mode by scanning one of the barcodes in Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation
  2. Get the value of attribute ID 1. The value of this attribute should be TRUE if you scanned the Set All Defaults barcode before beginning the example.
  3. To disable the UPC-A attribute of a scanner, change the value of the attribute ID 1 to FALSE in the RSM grid and click Set Value or Store Value.
  4. The sample application then executes an ExecCommand API call with the ATTR_SET or ATTR_STORE method and the XML shown in Parameter Setting (Device Configuration).
  5. If the command executed successfully, you cannot scan the following UPC-A barcode.

    USB (IBM Hand-Held)

Programming an ADF Rule

If you want to create an ADF rule to add the prefix A to any barcode and an Enter key after scanning a barcode, you must modify the ADF buffer of the scanner. The attribute ID of the ADF rule is 392.

To change and validate the setting:

USB Host Type = HID Keyboard Wedge

  1. Scan the barcode below, or follow the procedure in Host Variant Switching to switch the scanner to HID keyboard mode. This enables the scanner to send data to any text editor.

    USB (IBM Hand-Held)
  2. Open a text editor such as Windows Notepad and scan the Sample UPC-A Barcode while the text editor is the active window. The text 012345678912 is inserted into the editor window.
  3. Put the scanner into USB OPOS (hand held) or USB SNAPI mode by scanning one of the barcodes in Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation, or following the procedure in Host Variant Switching to switch the host mode.
  4. In the sample application, change the value of the selected scanner's attribute 392 to: 0x01 0x0C 0x11 0xF4 0x14 0x10 0x47 0x0D.
  5. Click Store Value.
  6. The sample application then executes an ExecCommand API call using the ATTR_STORE method and the following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-xml>
                <attrib_list>
                    <attribute>
                        <id>392</id>
                        <datatype>A</datatype>
                        <value>0x01 0x0C 0x11 0xF4 0x14 0x10 0x47 0x0D</value>
                    </attribute>
                </attrib_list>
            </arg-xml>
        </cmdArgs>
    </inArgs>
    
    
  7. After successfully executing the command, repeat steps 1 and 2.
  8. The text entered in Notepad is A012345678912<Enter key>.

Beeper Volume Control

Suppose you want to change the beeper volume of the scanner. The corresponding attribute ID is 140 and the scanner beeper has three volume levels:

  • 2 - low
  • 1 - medium
  • 0 - high

To change and validate this setting:

  1. Put the scanner into USB OPOS (hand held) or USB SNAPI mode by scanning one of the barcodes in Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation, or following the procedure in Host Variant Switching switch the host mode.
  2. Scan the Sample UPC-A Barcode and listen to the beeper carefully.
  3. Select attribute ID 140 from the RSM attribute grid. Its value should be 0 (if the Set All Defaults barcode was scanned at the beginning of the example).
  4. Change the value to 2 and click Set Value or Store Value.
  5. The sample application then executes an ExecCommand API call with the ATTR_SET or ATTR_STORE method and the following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-xml>
                <attrib_list>
                    <attribute>
                        <id>140</id>
                        <datatype>B</datatype>
                        <value>2</value>
                    </attribute>
                </attrib_list>
            </arg-xml>
        </cmdArgs>
    </inArgs>                                                                        
    
    
  6. After successfully executing the command, scan the Sample UPC-A barcode again and note that the beeper volume is lower.

    NOTE Changes made using the Store Value commands are permanent (persistent over power down and power up cycles). Changes made using the Set Value command are temporary (parameters set using this temporary command are lost after the next power down).

Beeper and LED Control

Suppose you want to beep the scanner or light the LED of the scanner. The Action Attribute ID is 6000.

To change and validate this setting:

  1. Put the scanner into USB OPOS (hand held) or USB SNAPI mode by scanning one of the barcodes in Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation, or following the procedure in Host Variant Switching switch the host mode.
  2. To light the LED of the scanner execute an ExecCommand API call with the ATTR_SET or ATTR_STORE method and the following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-xml>
                <attrib_list>
                    <attribute>
                        <id>6000</id>
                        <datatype>X</datatype>
                        <value>43</value>
                    </attribute>
                </attrib_list>
            </arg-xml>
        </cmdArgs>
    </inArgs>
    
    

Host Variant Switching

  1. Connect and discover a scanner (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).
  2. Under the Scanner Action tab, select a Target Mode from the drop-down menu in the Switch Host Variant area.
  3. Permanent Change or Silent Reboot options (hidden by the Target Mode drop-down list) may be selected if desired.
  4. Click Switch Host Mode and the scanner reboots and sets to the selected target mode.

    Figure 13: Changing Host Mode
  5. Clicking Switch Host Mode in the sample application executes an ExecCommand API call with the DEVICE_SWITCH_HOST_MODE method and the following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-string>XUA-45001-1</arg-string>
            <arg-bool>TRUE</arg-bool>
            <arg-bool>FALSE</arg-bool>
        </cmdArgs>
    </inArgs>
    
    

    When you are in HID Keyboard mode the only allowed target host variants are IBM Hand-held USB and SNAPI.

Firmware Upgrade

Firmware Upgrade Scenarios

Three firmware upgrade scenarios that should be considered are discussed below.

Scenario A: Loading a compatible, different version of firmware from the firmware already on the scanner.

  • Upgrading the firmware on a scanner includes two steps:

    1. The firmware file downloads to the scanner.
    2. The firmware file on the scanner is activated (programmed into the scanner). Activation lasts for approximately 50 seconds, during which the LED blinks red. During activation, the scanner does not respond to network queries. When activation (programming) completes, the scanner automatically reboots (the LED turns off) and emits a power up beep, and powers up with the new upgraded firmware.
  • A firmware download can take up to 20 minutes depending on the connection speed between the POS terminal and the scanner, the operating mode of the scanner and the size of the firmware file.

Scenario B: Loading the same version of firmware that is already on the scanner.

  • A firmware file can include multiple components. When loading the same version of firmware, some components in the firmware file may be the same as those already on the scanner, while other components are different.
  • Before firmware loads to the scanner, the scanner driver reads the header information of each firmware component to validate the model number and version. For example, if the first component downloading from the firmware file is the same version as the one already on the scanner, the component does not load to the scanner. Each remaining component in the firmware file is verified against the equivalent component on the scanner, and only components that are different are downloaded to the scanner.

Scenario C: Loading an incompatible version of firmware on the scanner.

  • This occurs when attempting to load firmware designed for one scanner model say DS6707 onto another incompatible scanner model say DS6708.

A firmware file can include multiple components. Before downloading firmware to the scanner, the scanner driver reads the header information of each firmware component to validate the model number and version. If the scanner driver determines that the firmware component model number does not match the scanner, the component does not load. This process continues to verify each remaining component in the firmware file.

Firmware Upgrade Procedure
  1. Connect and discover a scanner (see Scanner Discovery / Asset Tracking Information / Validating Successful SDK Installation).
  2. Obtain the latest firmware .DAT file for loading to a scanner using 123Scan.

    • Download and launch 123Scan.
    • Using 123Scan2, confirm you have the latest scanner plug-in. The plug-in contains a number of files including the firmware file and release notes.

      1. To download the latest scanner plug-ins from within 123Scan, launch 123Scan, go to the help menu and click Check for updates.
      2. For a listing of scanner models, plug-ins and firmware files supported in 123Scan select Supported scanners and plug-ins under the Help menu.
      3. The plug-ins are contained within a 123Scan sub folder accessible in: [WINDOWSDRIVE]\Users\ Application Data\123Scan2\Plug. The firmware file is named with a .DAT extension (e.g., CAAABS00-006-R02D0.DAT).
  3. From the Advanced tab of the sample application, browse to and select the firmware .DAT file.
  4. Check the Bulk Update option if bulk channel updating is preferred.
  5. Click Update to transfer the firmware file from the computer to the scanner.
  6. Clicking Update in the sample application executes an ExecCommand API call with the UPDATE_FIRMWARE method and the following XML code:

    
    <inArgs>
        <scannerID>1</scannerID>
        <cmdArgs>
            <arg-string>D:\scanner\ScannerFW\DS6707\DS6707X4.DAT</arg-string>
            <arg-int>2</arg-int>
        </cmdArgs>
    </inArgs>
    
    
  7. If you have registered with ScanRMDEvent you receive six types of events per firmware update cycle.
  8. The OnScanRMDEvent function has two parameters where the first short type parameter contains the event type described above. The six event type values are listed in Table 6.

    Table 6: Firmware Update Event Types

    Event Value Event Type Description
    11 SCANNER_UF_SESS_START Triggered when flash download session starts.
    12 SCANNER_UF_DL_START Triggered when component download starts.
    13 SCANNER_UF_DL_PROGRESS Triggered when block(s) of flash completed.
    14 SCANNER_UF_DL_END Triggered when component download ends
    15 SCANNER_UF_SESS_END Triggered when flash download session ends
    16 SCANNER_UF_STATUS Triggered when update error or status

    The second parameter of the same function contains an XML for the above event types. By processing the XML further information can be obtained. The formats of the receiving XMLs for each event types are as follows. All XMLs are containing the information about the scanner that it updates.

    1. SCANNER_UF_SESS_START

      
      <?xml version="1.0" encoding="UTF-8"?>
      <outArgs>
          <scannerID>1</scannerID>
          <arg-xml>
              <sess_start>
                  <modelnumber>DS670-SR20001ZZR</modelnumber>
                  <serialnumber>S/N:7108E15933CA1B4BB776F7BDB4B3F826</serialnumber>
                  <GUID>7108E15933CA1B4BB776F7BDB4B3F826</GUID>
                  <maxcount>3075</maxcount>
                  <status>0</status>
              </sess_start>
          </arg-xml>
      </outArgs>
      
      

      The <maxcount> tag contains the number of records in the firmware file.

    2. SCANNER_UF_DL_START

      
      <?xml version="1.0" encoding="UTF-8"?>
      <outArgs>
          <scannerID>1</scannerID>
          <arg-xml>
              <dl_start>
                  <modelnumber>DS670-SR20001ZZR</modelnumber>
                  <serialnumber>S/N:7108E15933CA1B4BB776F7BDB4B3F826</serialnumber>
                  <GUID>7108E15933CA1B4BB776F7BDB4B3F826</GUID>
                  <software_component>0</software_component>
                  <status>0</status>
              </dl_start>
          </arg-xml>
      </outArgs>
      
      

      The <software_component> tag contains the component number that downloads started.

    3. SCANNER_UF_DL_PROGRESS

      
      <?xml version="1.0" encoding="UTF-8"?>
      <outArgs>
          <scannerID>1</scannerID>
          <arg-xml>
              <dl_progress>
                  <modelnumber> DS670-SR20001ZZR </modelnumber>
                  <serialnumber>S/N:7108E15933CA1B4BB776F7BDB4B3F826</serialnumber>
                  <GUID>7108E15933CA1B4BB776F7BDB4B3F826</GUID>
                  <software_component>1</software_component>
                  <progress>7</progress>
                  <status>600</status>
              </dl_progress>
          </arg-xml>
      </outArgs>
      
      

      The <progress> tag contains the record number that it downloading at that moment. The <status> tag contains the status of the download progressing record. 600 value means that it is the resident firmware.

    4. SCANNER_UF_DL_END

      
      <?xml version="1.0" encoding="UTF-8"?>
      <outArgs>
          <scannerID>1</scannerID>
          <arg-xml>
              <dl_end>
                  <modelnumber> DS670-SR20001ZZR </modelnumber>
                  <serialnumber>S/N:7108E15933CA1B4BB776F7BDB4B3F826</serialnumber>
                  <GUID>7108E15933CA1B4BB776F7BDB4B3F826</GUID>
                  <software_component>2</software_component>
                  <size>0</size>
                  <status>0</status>
              </dl_end>
          </arg-xml>
      </outArgs>
      
      
    5. SCANNER_UF_SESS_END

      
      <?xml version="1.0" encoding="UTF-8"?>
      <outArgs>
          <scannerID>1</scannerID>
          <arg-xml>
              <sess_end>
                  <modelnumber> DS670-SR20001ZZR </modelnumber>
                  <serialnumber>S/N:7108E15933CA1B4BB776F7BDB4B3F826</serialnumber>
                  <GUID>7108E15933CA1B4BB776F7BDB4B3F826</GUID>
                  <status>0</status>
              </sess_end>
          </arg-xml>
      </outArgs>
      
      
    6. SCANNER_UF_STATUS

      
      <?xml version="1.0" encoding="UTF-8"?>
      <outArgs>
          <scannerID>1</scannerID>
          <arg-xml>
              <sess_info>
                  <modelnumber> DS670-SR20001ZZR </modelnumber>
                  <serialnumber>S/N:7108E15933CA1B4BB776F7BDB4B3F826</serialnumber>
                  <GUID>7108E15933CA1B4BB776F7BDB4B3F826</GUID>
                  <status>506</status>
              </sess_info>
          </arg-xml>
      </outArgs>
      
      
  9. After the file transfer is complete, click Launch to activate (program into the scanner) the new firmware. Activation takes approximately one minute, during which the LED blinks red and scanning barcode data is disabled. During activation, the scanner does not respond to network queries. When activation (programming) completes, the scanner automatically reboots (the LED turns off), emits a power up beep and restarts with the new upgraded firmware.

    Figure 14: Firmware Upgrade Through Bulk (Faster Download Mode) Channel

Scan Scan Write

Scan Scan Write can be used to "commission" tags (change the Serial Number and EPC id). This information gets written to the tag. Scan Scan Write works with all interfaces (except Keyboard Wedge) but SNAPI is recommended.

NOTE The new tab control will be visible only when a DS9908R device is connected and selected from the list of barcode scanners currently connected to the demo application.

Follow these steps.

  1. Download the latest version of the Zebra CoreScanner Driver and Zebra Scanner SDK for Windows from zebra.com.
  2. Set the USB Device Type to "SNAPI" (with or without imaging) on the DS990R and connect it to your PC.
  3. Open the Scanner SDK C# Sample Applications app.
  4. Select "Discover Scanners". DS9908-xxxxxxxxxxx will appear in the "Connected Scanners List".

    Select the "Scan Scan Write" tab you will see a screen similar to the one below.

    NOTE: The new tab control will be visible only when a DS9908R device is connected and selected from the list of barcode scanners currently connected to the demo application.

    Figure 15: Device Discovery
  5. Scan the RFID tag. The Existing EPC id, Filter value, Position, Serial Number and User Bank data (if applicable) will be populated. See screen shot below.

    Figure 16: Scan RFID Tag
  6. Scan the barcode. The Scan Barcode and New EPC id will be populated. See screen shot below.

    Figure 17: Scan Barcode
  7. Edit the Serial Number if desired. New EPC id will change to reflect the new Serial Number.

    Figure 18: Edit Serial Number
  8. Rescan the RFID tag and select "Write tag". The new EPC id will be written to the RFID tag. A green checkmark will appear after the new EPC id. Or red X if.

    Figure 19: Write Tag
  9. Select "Clear" to clear the fields.

    Figure 20: Clear Fields
  10. Rescan the RFID tag and Select "verify tag" to verify the contents.

    Figure 21: Verify Tag

Write Simple Application Using the Scanner SDK API

Overview

This section provides a step by step guide to writing simple applications using CoreScanner APIs.

Before you start to write applications using CoreScanner APIs, please prepare your development environment properly.

  • Install Microsoft Visual Studio 2017 or newer version and make sure you have enough system resources to develop an application on your system.
  • Install the Scanner SDK and make sure the SDK is operational. See Installing the SDK for more details.

Import CoreScanner Reference, Class Declaration and Instantiation

To create an empty project in Microsoft Visual Studio 2017 (create a console project):

  1. Start Microsoft Visual Studio 2019.
  2. Go to New → New → Project

    Figure 22: Create New Project
  3. Select Project Visual C# and Template as Console App (.NET Framework) and type a name for your project. In this example, it is ConsoleApplication1.

    Figure 23: C# Console Application
  4. Import CoreScanner as a reference into your application. Go to Project → Add Reference.

    Figure 24: Add Reference
  5. Select the CoreScanner Type Library from the COM tab and click OK.

    Figure 25: CoreScanner Type Library
  6. To avoid versioning conflicts between different versions of the COM component set Embed Interop Types to False in the reference properties windows.

    Figure 26: COM Interop Type
  7. CoreScanner is listed in your project under references as shown below.

    Figure 27: CoreScanner Reference
  8. You are now ready to import the CoreScanner library into your application. After importing, you can declare and instantiate the CoreScanner class for the application.

    Open the Program.cs file and enter the modifications as shown below.

    Figure 28: CoreScanner Initialization
  9. Now you are ready to start dealing with CoreScanner APIs.

Open API

After you instantiate CoreScanner class into your application you can call Open API as shown below.


using System;
using System.Collections.Generic;
using System.Text;
using CoreScanner;

namespace ConsoleApplication1
{
    class Program
    {
        // Declare CoreScannerClass
        static CCoreScannerClass cCoreScannerClass;

        static void Main(string[] args)
        {
            //Instantiate CoreScanner Class
            cCoreScannerClass = new CCoreScannerClass();

            //Call Open API
            short[] scannerTypes = new short[1];    // Scanner Types you are interested in
            scannerTypes[0] = 1;                    // 1 for all scanner types
            short numberOfScannerTypes = 1;         // Size of the scannerTypes array 
            int status;                             // Extended API return code

            cCoreScannerClass.Open(0, scannerTypes, numberOfScannerTypes, out status);

            if (status == 0)
            { 
                Console.WriteLine("CoreScanner API: Open Successful");
            }
            else
            {
                Console.WriteLine("CoreScanner API: Open Failed"); 
            }
        }
    }
}                                                            

If you have successfully executed all the commands, you see the following output on the console window.

Figure 29: Open API Success - Console Window

GetScanners API

After you call Open API as described above you can call the GetScanners API as shown below.


using System;
using System.Collections.Generic;
using System.Text;
using CoreScanner;

namespace ConsoleApplication1
{
    class Program
    {
        // Declare CoreScannerClass
        static CCoreScannerClass cCoreScannerClass;

        static void Main(string[] args)
        {
            //Instantiate CoreScanner Class
            cCoreScannerClass = new CCoreScannerClass();

            //Call Open API
            short[] scannerTypes = new short[1];    // Scanner Types you are interested in
            scannerTypes[0] = 1;                    // 1 for all scanner types
            short numberOfScannerTypes = 1;         // Size of the scannerTypes array 
            int status;                             // Extended API return code

            cCoreScannerClass.Open(0, scannerTypes, numberOfScannerTypes, out status);

            // Lets list down all the scanners connected to the host

            short numberOfScanners;                         // Number of scanners expect to be used 
            int[] connectedScannerIDList = new int[255];    // List of scanner IDs to be returned 
            string outXML;                                  // Scanner details output

            cCoreScannerClass.GetScanners(out numberOfScanners, connectedScannerIDList, out outXML, out status);

            Console.WriteLine(outXML);
        }
    }
}

If you have successfully executed all the commands, you see the following output on the console window.

Figure 30: GetScanners API Success - Console Window

ExecCommand API to Demonstrate Beep the Beeper

After you call Open API as described above, you can call ExecCommand API as shown below.


using System;
using System.Collections.Generic;
using System.Text;
using CoreScanner;

namespace ConsoleApplication1
{
    class Program
    {
        // Declare CoreScannerClass
        static CCoreScannerClass cCoreScannerClass;

        static void Main(string[] args)
        {
            // Instantiate CoreScanner Class 
            cCoreScannerClass = new CCoreScannerClass();

            // Call Open API
            short[] scannerTypes = new short[1];    // Scanner Types you are interested in     
            scannerTypes[0] = 1;                    // 1 for all scanner types
            short numberOfScannerTypes = 1;         // Size of the scannerTypes array 
            int status;                             // Extended API return code

            cCoreScannerClass.Open(0, scannerTypes, numberOfScannerTypes, out status);

            // Let's beep the beeper
            int opcode = 6000;  // Method for Beep the beeper 
            string outXML;      // Output
            string inXML = "<inArgs>" +
                                "<scannerID>1</scannerID>" + // The scanner you need to beep
                                "<cmdArgs>" +
                                    "<arg-int>3</arg-int>" + // 4 high short beep pattern
                                "</cmdArgs>" + 
                            "</inArgs>";

            cCoreScannerClass.ExecCommand(opcode, ref inXML, out outXML, out status);
        }
    }
} 

If you have successfully executed all the commands, you see the following output on the console window. There is no visual output for this beep command but an audible beep sounds from the scanner.

Figure 31: ExecCommand API Success (Scanner Beep) - Console Window

Retrieve Asset Tracking Information from ExecCommand with the RSM_GET Method

After you call Open API as described above, you can call ExecCommand API as shown below.


using System;
using System.Collections.Generic;
using System.Text;
using CoreScanner;

namespace ConsoleApplication1
{
    class Program
    {
        // Declare CoreScannerClass
        static CCoreScannerClass cCoreScannerClass;

        static void Main(string[] args)
        {
            // Instantiate CoreScanner Class
            cCoreScannerClass = new CCoreScannerClass();

            // Call Open API
            short[] scannerTypes = new short[1];    // Scanner Types you are interested in
            scannerTypes[0] = 1;                    // 1 for all scanner types
            short numberOfScannerTypes = 1;         // Size of the scannerTypes array 
            int status;                             // Extended API return code

            cCoreScannerClass.Open(0, scannerTypes, numberOfScannerTypes, out status);

            // Let's retrieve assert tracking information
            int opcode = 5001;                  // Method for Get the scanner attributes 
            string outXML;                      // XML Output
            string inXML = "<inArgs>" +
                                "<scannerID>1</scannerID>" + // The scanner you need to get the information
                                "<cmdArgs>" +
                                    "<arg-xml>" +
                                        "<attrib_list>20004,533,20007,1</attrib_list>" + // attribute numbers you need
                                    "</arg-xml>" +
                                "</cmdArgs>" +
                            "</inArgs>";

            cCoreScannerClass.ExecCommand(opcode, ref inXML, out outXML, out status);
            Console.WriteLine(outXML); 
        }
    }
}

If you have successfully executed all the commands, you see the following output on the console window.

Figure 32: ExecCommand API Success (RSM GET) - Console Window

Enable the UPC-A Attribute by Calling SET_ATTRIBUTE via ExecCommand

After you call Open API as described above, you can call ExecCommand API as shown below.

This method does not show any output but it sets the UPC-A to enable (True) or disable (False).

Capture Barcode Data into an Application

  1. Create an empty C# Windows Forms App (.NET Framework) project in Microsoft Visual Studio.

    Figure 33: Create Empty C# Windows Forms Application
  2. Add CoreScanner as a reference into your project. See Import CoreScanner Reference, Class Declaration and Instantiation above for more details.
  3. Add a button and a text area into your application.

    Figure 34: C# Win Forms Application
  4. Include the following code segment into the Button click method.

    
    try
    {
        // Instantiate CoreScanner Class
        cCoreScannerClass = new CCoreScannerClass();
    
        // Call Open API
        short[] scannerTypes = new short[1];    // Scanner Types you are interested in
        scannerTypes[0] = 1;                    // 1 for all scanner types
        short numberOfScannerTypes = 1;         // Size of the scannerTypes array 
        int status;                             // Extended API return code
    
        cCoreScannerClass.Open(0, scannerTypes, numberOfScannerTypes, out status);
    
        // Subscribe for barcode events in cCoreScannerClass
        cCoreScannerClass.BarcodeEvent += new _ICoreScannerEvents_BarcodeEventEventHandler(OnBarcodeEvent);
    
        // Let's subscribe for events
        int opcode = 1001;  // Method for Subscribe events 
        string outXML;      // XML Output
        string inXML = "<inArgs>" +
                            "<cmdArgs>" +
                                "<arg-int>1</arg-int>" + // Number of events you want to subscribe
                                "<arg-int>1</arg-int>" + // Comma separated event IDs
                            "</cmdArgs>" +
                        "</inArgs>";
    
        cCoreScannerClass.ExecCommand(opcode, ref inXML, out outXML, out status);
        Console.WriteLine(outXML);
    }
    catch (Exception exp)
    {
        Console.WriteLine("Something wrong please check... " + exp.Message);
    }
    
    
  5. Implement a method to receive the event as shown below and populate the text box with scanned data.

    
    void OnBarcodeEvent(short eventType, ref string pscanData)
    {
        string barcode = pscanData;
        this.Invoke((MethodInvoker)delegate { textBox1.Text = barcode; });
    } 
    
    
  6. If you execute the application and click on the button, the application instantiates CoreScanner and is ready to receive barcode events. Following image illustrates the output when you scan a barcode.

    Figure 35: Scanned Barcode Output