 
							Communicating with Human Interface Devices such as Alphanumeric display, Bar Code Reader, Sensors, Volume control on Speakers/Headsets becomes a primary use case for real-world, Cross-platform applications. Do you spend more time in building libraries to communicate with HID for your Delphi/C++ FireMonkey applications? WINSOFT Provides a powerful library to get the job done. It uses the standard Windows HID API.
Features:
- Able to notify on HID Device arrival and removal.
- Can retrieve all the HID devices information available in the System.
- Flexible to getting/set Feature Report for the HID devices.
- Works with Windows 32/64-bit applications.
Versions Supported: Delphi/C++ Builder XE2 – Delphi 10.4.
Platforms: Windows, OS X, Android, and iOS;
Steps to Download and use the Native HID Library:
- Download Native HID for FireMonkey and Unzip the file.
- Nahttps://winsoft.sk/nathid.htmvigate to the Library folder for different Versions. e.g) Delphi104-Win32.
- Read the Readme.txt file to know about features and copyright information.
- Create a Windows VCL Application and use FHid.pas in the uses section.
- Include the Library folder into Project->Options->Delphi Compiler->Search Path.
- Compile and check for using the library.
NativeHID Download and Use for FireMonkey demo:
Key HID concepts:
Report -Reports are the actual data that is exchanged between a device and a software client.
- Input Report – Data sent from the HID device to the application, typically when the state of a control changes.
- Output Report – Data sent from the application to the HID device, for example to the LEDs on a keyboard.
- Feature Report -Data that can be manually read and/or written, and are typically related to configuration information.
Report Descriptor – The Report Descriptor describes the format and meaning of the data that the device supports.
UsageTables – Contain a list with descriptions of Usages, which describe the intended meaning and use of a particular item described in the Report Descriptor. For example, a Usage is defined for the left button of a mouse.  USB-IF WorkGroup Publishes the Usage Tables. See USB-IF HID Specifications.
How to build FireMonkey applications using Native HID library:
1. Open Rad Studio 10.4 and Create a Blank Multi Device Application, use FHid.pas in the uses section.
2. Include the Library folder into Project->Options->Delphi Compiler->Search Path.
3. Create a Device instance and open,
| 1 2 | Device := TFHidDevice.Create; // Creates an Instance of TFHidDevice Device.Open // Open the HID Device | 
- OnDeviceArrival– Provide the DeviceName which arrives at the system. Using DeviceName you can open the device, show the device properties.
- OnDeviceRemoved – Provide the DeviceName which removed from the system.
- Get/SetFeatureReport – Use this to manually Read/Write Related to configuration information.
- GetInputReport – Get the data sent by HID Device for the Report ID.
- SetOutputReport – Set the data to HID Device for the Report ID.
4. ShowDeviceProperties.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | with Device do   try     AddLine('Vendor ID: ' + IntToHex(VendorID, 4));     AddLine('Product ID: ' + IntToHex(ProductID, 4));     AddLine('Version number: ' + IntToHex(VersionNumber, 4));     AddLine('Serial number: ' + SerialNumber);     AddLine('Manufacturer: ' + Manufacturer);     AddLine('Product: ' + Product);     AddLine('Usage page: ' + IntToStr(UsagePage));     AddLine('Usage: ' + IntToStr(Usage));     AddLine('Input report length: ' + IntToStr(InputReportLength));     AddLine('Output report length: ' + IntToStr(OutputReportLength));     AddLine('Feature report length: ' + IntToStr(FeatureReportLength));     AddLine('Input buffer count: ' + IntToStr(InputBufferCount));     for I := 1 to 255 do       if HasString[I] then         AddLine('String ' + IntToStr(I) + ': ' + Strings[I])       else         Break;   except     on E: Exception do       AddLine('Exception: ' + E.Message);   end; | 
5. Get Device Names,
| 1 | var   DeviceNames : TWStringDynArray; begin   With Device do     DeviceNames := Enumerate; end; | 
6. For each DeviceNames GetFeatureReport, GetInputReport and Read data by reopening the device in Read-only,
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 | with Device do   // Feature Report   if FeatureReportSupported then     for J := 0 to 9 do       try         AddLine('Feature report ' + IntToStr(J) + ': ' + ByteArrayToString(GetFeatureReport(J)));       except       on E: Exception do         AddLine('Feature report ' + IntToStr(J) + ' exception: ' + E.Message);       end;    // Input Report       if InputReportSupported then      for J := 0 to 9 do        try          AddLine('Input report ' + IntToStr(J) + ': ' + ByteArrayToString(GetInputReport(J)));        except        on E: Exception do          AddLine('Input report ' + IntToStr(J) + ' exception: ' + E.Message);        end;    // Open Device read only    if ReadSupported then    begin      // reopen device with read access      Open(DeviceNames[I], True, False);        for J := 0 to 9 do          try            AddLine('Read: ' + ByteArrayToString(Read(300)));          except          on E: Exception do            AddLine('Read exception: ' + E.Message);          end;     end; | 
7. Close the Device.
| 1 | Device.close // Close the HID Device. | 
Native HID Library for FireMonkey Code demo :
Conclusion: It’s quite easy to interact with HID in your FireMonkey applications. WINSOFT saved our time in nailing the Windows HID API and help us to build quickly using NativeHID Library.
Head over and check out the full WINSOFT Native HID Library for Access in Delphi and C++Builder.
Design. Code. Compile. Deploy.
Start Free Trial Upgrade Today
Free Delphi Community Edition Free C++Builder Community Edition








