QOpenHD is the default OpenHD companion app that runs on the OHD Ground station or any other "external" devices connected to the ground station.
It is responsible for displaying the (main) video stream to the user, composed with the OSD and changing OpenHD settings.
As the name suspects, it is based on QT (5.15.X).
- QOpenHD is not OpenHD (main). It can talk to a running OpenHD main instance (ground and/or air) via Mavlink and rceives the (primary / secondary / ++) video streams.
- While QOpenHD is the default companion app, OpenHD MUST NOT assume there is a QOpenHD instance somewhere that initiates voodo settings / setup processes ( This is in contrast to OpenHD /QOpenHD releases before the "evo" series.) As a result of this limitation, Both OpenHD and QOpenHD can be developed independently from each other, and debugging becomes a lot easier.
We have a CI setup that checks compilation on ubuntu. You can look at the steps it performs to build and run QOpenHD. Other platforms than Linux are not supported right now.
- 
Install Xcode from the Mac App Store. 
- 
Install Qt using the Qt online installer 
- 
Have the Qt Installer download Qt 5.15.0+ for Mac, and Qt Creator 
- 
Clone the source code: git clone --recurse-submodules https://github.com/OpenHD/QOpenHD.git 
If you aren't using git from the command line but using a GUI git client instead, make sure you update the submodules or QOpenHD will not build properly.
Once you have those steps done you can open QOpenHD.pro with Qt Creator, build and run it.
- 
Install Xcode from the Mac App Store. 
- 
Install Qt using the Qt online installer 
- 
Have the Qt Installer download Qt 5.15.0+ for iOS, and Qt Creator 
- 
You will need an Apple developer membership to install directly to an iOS device 
- 
Clone the source code: git clone --recurse-submodules https://github.com/OpenHD/QOpenHD.git 
If you aren't using git from the command line but using a GUI git client instead, make sure you update the submodules or QOpenHD will not build properly.
Once you have those steps done you can open QOpenHD.pro with Qt Creator, build and run it.
- 
Install Visual Studio 2019 (free) 
- 
Install Qt using the Qt online installer 
- 
Have the Qt Installer download Qt 5.15.0+ and Qt Creator 
- 
Download the GStreamer development kit for Windows, both the Runtime and Development packages. You must use the 32-bit MinGW packages, NOT the one labeled MSVC, and it should be version 1.14.4. (QT will look for gstreamer in c:/gstreamer/1.0/x86 ) 
- 
Clone the source code: git clone --recurse-submodules https://github.com/OpenHD/QOpenHD.git 
If you aren't using git from the command line but using a GUI git client instead, make sure you update the submodules or QOpenHD will not build properly.
Once you have those steps done you can open QOpenHD.pro with Qt Creator, build and run it.
- 
Install Qt using the Qt online installer 
- 
Have it download Qt 5.15.0+ for Linux 
- 
Install GStreamer development packages from the package manager. On Ubuntu this would be apt install gstreamer1.0-gl libgstreamer1.0-dev libgstreamer-plugins-good1.0-dev gstreamer1.0-plugins-good libgstreamer-plugins-base1.0-dev gstreamer1.0-plugins-base libgstreamer-plugins-bad1.0-dev gstreamer1.0-plugins-bad gstreamer1.0-plugins-ugly gstreamer1.0-qt. Those should pull in any others that are needed as well.
- 
Clone the source code: git clone --recurse-submodules https://github.com/OpenHD/QOpenHD.git 
If you aren't using git from the command line but using a GUI git client instead, make sure you update the submodules or QOpenHD will not build properly.
Once you have those steps done you can open QOpenHD.pro with Qt Creator, build and run it.
- 
Install Android Studio 
- 
Use Android Studio to install Android SDK level 28, along with NDK r18b and the associated build toolchain. 
- 
Install Qt using the Qt online installer 
- 
Have the Qt Installer download Qt 5.15.0+ for Android, not for the OS you're building on. 
- 
Clone the source code: git clone --recurse-submodules https://github.com/OpenHD/QOpenHD.git 
If you aren't using git from the command line but using a GUI git client instead, make sure you update the submodules or QOpenHD will not build properly.
You can then open QOpenHD.pro using Qt Creator and set up the Android kit (left side, click the Projects tab), build and run the app on your device.
QOpenHD relies on MAVSDK library. After recursively cloning qopenhd build this library:
cd lib/MAVSDK
cmake -Bbuild/default -DCMAKE_BUILD_TYPE=Release -H.
cmake --build build/default -j4
sudo cmake --build build/default --target install
After that, you can build QOpenHD by either opening it in QT Creator (recommended) or building it with the following commands:
mkdir build
cd build
qmake ..