/libONVIF

Yet another ONVIF library

Primary LanguageC++GNU General Public License v3.0GPL-3.0

libONVIF

os os_build Status
Android Linux Build Status
Android Windows Build Status
Linux Linux Build Status
Windows Windows Build Status
Macos Macos Build Status

Yet another ONVIF library

This projects status is "work in progress". Don't expect binary compatibility. Actually don't expect anything other than major changes in the source code :-).

What does ONVIF stand for:

ONVIF (Open Network Video Interface Forum) is a global and open industry forum with the goal of facilitating the development and use of a global open standard for the interface of physical IP-based security products – or, in other words, to create a standard for how IP products within video surveillance and other physical security areas can communicate with each other. Wikipedia

The idea behind this library is to hide some complexity of gsoap and to provide 'high level' classes including QT5 goodness. Currently there are eleven client side service methods implemented:

For every service exists a class following the naming scheme Onvif*Client (* matches service name). These classes handle the RPCs. For the convenience of WS discovery and ONVIF (pull point) event handling there are two more classes: OnvifDiscovery and OnvifPullPoint.

Design thoughts:

  • The most of this library is thread safe and should work in a multithreaded environment
  • gsoap is 'hidden' from the user as much as possible
  • RAII classes Request<>, Response<> wrapping the RPC parameters are responsible for the memory management

Further reading

  • The library comes with a small application (named ovifinfo) that does some device-discovery, inspection. You may want to look at the source code.
  • If you want to learn more about how to use libONVIF in a qml app take a look at the following project ONVIFMonitor.
  • It is always advisable to look at the ONVIF programmers guide to learn more about ONVIF.