Impact Acquire SDK C++
|
In general all Impact Acquire host drivers claim to support any compliant device with any firmware version running on the device. Whenever this is not the case this page will provide some guidelines on what to do. Apart from that all known compatibility issues are listed here.
Changes in Impact Acquire (previously known as mvIMPACT Acquire) known to have a potential impact on existing applications are listed below. If any of the following items is involved in the user application using mvIMPACT Acquire, please adapt it accordingly when migrating to Impact Acquire 3.0.0 or higher.
Item | Previously in mvIMPACT Acquire | Currently in Impact Acquire | Comments |
---|---|---|---|
GUI application name | wxPropView | ImpactControlCenter | |
GUI application name | mvDeviceConfigure | DeviceConfigure | A link pretending the existence of the previous application name will be provided for some time but scripts calling the previous name should be adjusted. |
GUI application name | mvIPConfigure | IPConfigure | |
GUI application name | mvGigEConfigure | GigEConfigure | |
Vendor name reported by various GetInfo functions on GenTL Producer libraries (e.g. GCGetInfo(..., TL_INFO_VENDOR, ...) , GCGetPortInfo(..., PORT_INFO_VENDOR, ...) ) | MATRIX VISION | Balluff | Applications relying on these strings must be changed! |
Device vendor name (e.g. DevGetInfo(..., DEVICE_INFO_VENDOR, ...) ) (depending on the Firmware version, not the SDK version) | MATRIX VISION GmbH | Balluff GmbH or MATRIX VISION GmbH (depending on the device family) | |
mvIMPACT::acquire::Device::manufacturer (depending on the Firmware version, not the SDK version) |
mvIMPACT_AcquireConfig.cmake
stays the same for compatibility reasons! Changing this would be possible but would force everyone using it to apply slight adjustments to their build environment.Item | Previously in mvIMPACT Acquire | Currently in Impact Acquire | Comments |
---|---|---|---|
Default installation path | %ProgramFiles%/MATRIX VISION/mvIMPACT Acquire | %ProgramFiles%/Balluff/Impact Acquire | |
Default value of the environment variable MVIMPACT_ACQUIRE_DIR | %ProgramFiles%/MATRIX VISION/mvIMPACT Acquire | %ProgramFiles%/Balluff/Impact Acquire | |
Default value of the environment variable MVIMPACT_ACQUIRE_DATA_DIR | %PUBLIC%/Documents/MATRIX VISION/mvIMPACT Acquire | %PUBLIC%/Documents/Balluff/Impact Acquire | Please consider using the environment variable MVIMPACT_ACQUIRE_DATA_DIR ! Otherwise the path must be adjusted manually. |
The location of various Registry Keys containing settings stored by GUI tools using a new name | HKEY_CURRENT_USER\SOFTWARE\<NameOfTheTool> | HKEY_CURRENT_USER\SOFTWARE\<NameOfTheTool> | When starting the GUI tools with the new name, settings stored with the previous versions of the tools will not be applied. |
Item | Previously in mvIMPACT Acquire | Currently in Impact Acquire | Comments |
---|---|---|---|
Default installation path | /opt/mvIMPACT_Acquire/ | /opt/Impact_Acquire/ | |
Default value of the environment variable MVIMPACT_ACQUIRE_DIR | /opt/mvIMPACT_Acquire/ | /opt/Impact_Acquire/ | |
Default value of the environment variable MVIMPACT_ACQUIRE_DATA_DIR | /opt/mvIMPACT_Acquire/data | /opt/Impact_Acquire/data | |
The location of various files containing settings stored by GUI tools using a new name | /home/<user>/<NameOfTheTool> | /home/<user>/<NameOfTheTool> | Previous settings of tools with older names will not be found and therefore an application will start up with its default settings, for instance, a previously disabled QSW will run again. |
Pseudo file generated by the BVS CA-BN (mvBlueNAOS) kernel module and used to reboot the camera | /sys/kernel/matrix-vision | /sys/kernel/balluff | The kernel module will not be built and installed depending on the design flavour because this might result in two drivers being installed and responsible for the same hardware. Instead, it will always create /sys/kernel/balluff but the producer checks both locations. It will try the old directory only if it finds nothing in the new one. |
Since Impact Acquire 2.6.4 and the migration to version 2.4 of the GenICam runtime libraries the embedded *.exe installers for the GenICam runtime are no longer shipped. When migrating custom installers that shall support device drivers depending on the GenICam runtime to Impact Acquire 2.6.4 or greater the GenICamRuntime.msm
or GenICamRuntime.x64.msm
must be installed instead of the deprecated GenICam_VC80_Win32_i86_v2_3_0.exe
or GenICam_VC80_Win64_x64_v2_3_0.exe
files. Using these newer merge modules also comes with the advantage, that whenever a new version of the GenICam runtime gets released, this will automatically end up in these files thus custom installers do no longer need to be updated manually.
Since Impact Acquire 2.8.0 all Balluff installation packages are built using VisualStudio 2013, and therefore use the Microsoft_VC120_OpenMP OpenMP runtime and Microsoft_VC120_CRT C/C++ runtime. Earlier versions used to be compiled with Visual Studio 2005, meaning that the VC80 counterparts of OpenMP and C/C++ runtime were used.
Since Impact Acquire 2.50.0 all Balluff installation packages are built using VisualStudio 2019. Therefore custom installers no longer need to contain the merge modules mentioned in the previous section but have to install more recent redistributables now. See Prerequisites for details. Earlier versions used to be compiled with Visual Studio 2013, meaning that the VC120 counterparts of OpenMP and C/C++ runtime were used in the form of merge modules (*.msm files). See previous section for details.
This section affects only the mvGenTL_Acquire packages and firmware for Balluff/MATRIX VISION devices that are operated using this package such as GigE Vision, USB3 Vision or other devices operated through the GenICam GenTL interface.
The following host driver and firmware combinations do NOT work together:
Impact Acquire version | Balluff GenICam device firmware version | Details |
---|---|---|
1.10.95 - 2.6.3 | 2.14.0 - 2.27.0 | A GenICam Device Supporting The 'ValidValueSet' Node Inside Its XML File Cannot Be Initialised |
2.15.0 - 2.16.1 | 1.4.57 - 1.6.5 | A GenICam Device With A Floating Enum Entry Node Inside Its XML File Cannot Be Initialised |
Potential issues:
Additional details about changes in the API and how to port existing code can be found here: Porting Existing Code