Configure C++ Samples With CMake and Build Them in Visual Studio in Windows
Introduction
This tutorial shows how to configure the Zivid C++ Samples with CMake and then build them with Visual Studio in Windows.
Requirements
Required
CMake - version 3.5 or higher
Note
The CMake version that is tested is 3.15.3.
Optional
Some of the samples depend on external libraries, in particular:
Note
Cloning/installation is covered below.
Instructions
Step by step instructions is provided with screenshots below.
Install external dependencies
Install required dependencies based on the sample programs you want to run; see the table below.
Sample program |
PCL |
Eigen |
OpenCV |
OpenCV_Contrib |
---|---|---|---|---|
ReadPCLVis3D |
YES |
|||
CaptureWritePCLVis3D |
YES |
|||
MaskPointCloud |
YES |
YES |
||
PoseConversions |
YES |
YES |
||
UtilizeHandEyeCalibration |
YES |
YES |
||
CaptureUndistort2D |
YES |
|||
CreateDepthMap |
YES |
|||
TransformPointCloudViaArucoMarker |
YES |
Clone Eigen
The Eigen version that is tested is 3.4.0. This version can be downloaded or cloned from gitlab.com/libeigen/eigen. To clone it, launch the Command Prompt by pressing Win + R keys on the keyboard, then type cmd and press Enter.
data:image/s3,"s3://crabby-images/cb110/cb110dc16615c717fe992a5265e87444ffb1607c" alt="Windows Run command"
Navigate to a location where you want to clone the repository:
cd C:\Users\Public\Downloads
Then run the following command (install Git if necessary):
git clone https://gitlab.com/libeigen/eigen
Navigate to eigen and checkout version 3.4.0.
cd eigen
git checkout tags/3.4.0
data:image/s3,"s3://crabby-images/f64a5/f64a52d6161ff41963809d41caec92d345c2ec72" alt="Screenshot of cloning Eigen with Git in cmd."
Install PCL
The PCL version that is tested is 1.9.1. Download and install prebuilt PCL binaries: pcl_1.9.1. Check the option to install 3rd Party Libraries including OpenNI.
data:image/s3,"s3://crabby-images/2e9f4/2e9f4de9c2ce0f5bb6f1c250cca38a556079dfcf" alt="Screenshot of PCL installation wizard on Windows."
Install OpenCV
The OpenCV version that is tested is 4.1.0. Download and install prebuilt OpenCV binaries: opencv_4.1.0.
data:image/s3,"s3://crabby-images/16d6a/16d6ae5477f957652060396f567fea876db96b95" alt="Screenshot of OpenCV zip-folder extraction on Windows."
Caution
The prebuilt OpenCV binaries are not sufficient for the samples that depend on OpenCV_Contrib. These samples require building OpenCV with extra modules.
Set PATH system variable for PCL and OpenCV
Some settings must be included in the PATH system variable before you can build Zivid C++ Samples.
On your PC, navigate to Control Panel → System and Security → System → Advanced System Settings → Environment Variables.
data:image/s3,"s3://crabby-images/8bbcb/8bbcb1a0a087303fb95b21660119eb203b433c72" alt="Screenshot of system information on Windows."
Under System variables (bottom of the window), select Path
variable and click Edit.
Warning
It is important to click Edit and not New in order not to overwrite the existing value(s) of the PATH system variable!
data:image/s3,"s3://crabby-images/4f6d9/4f6d985660d72795dd7120cffe8c10c250d127b5" alt="Screenshot of system information on Windows."
In the Environment variables window, click New (top-right corner of the window, in the section for user variables) and add the following values:
C:\Program Files\PCL 1.9.1\bin
C:\Program Files\OpenNI2\Tools
C:\Users\Public\Downloads\opencv\build\x64\vc15\bin
Note
Make sure to have the correct path for your PCL and OpenCV installations.
data:image/s3,"s3://crabby-images/c03f8/c03f883e0afff1eefcf8db574482d7473943d934" alt="Screenshot which shows how to add paths to the PATH variable."
Clone C++ Samples
This is our GitHub zivid-cpp-samples repository. To clone it, launch the Command Prompt by pressing Win + R keys on the keyboard, then type cmd and press Enter.
data:image/s3,"s3://crabby-images/cb110/cb110dc16615c717fe992a5265e87444ffb1607c" alt="Windows Run command"
Navigate to a location where you want to clone the repository (install Git if not already installed).
cd C:\Users\Public\Downloads
Then run the following command:
git clone https://github.com/zivid/zivid-cpp-samples
Configure the solution with CMake
Run CMake (cmake-gui.exe), then set the top two entries:
Where is the source code |
|
Where to build the binaries |
|
data:image/s3,"s3://crabby-images/6591f/6591f2f380da0399c796cfa647f9bff20027b407" alt="Screenshot of CMake GUI with configuration for Zivid C++ samples."
Click Configure. When prompted, click Yes to create a new build directory.
data:image/s3,"s3://crabby-images/6eec8/6eec8c63bf974e5484d77c625b4acbe03fc742bc" alt="Screenshot of CMake GUI with a note about creation of build directory."
Set the top two entries:
Specify the generator for this project |
Visual Studio 15 2017 |
Optional platform for generator |
x64 |
data:image/s3,"s3://crabby-images/40638/406388e752a04928329c51a941316c0e85771d39" alt="Screenshot of CMake GUI where you specify generator."
Click Configure.
data:image/s3,"s3://crabby-images/4b817/4b8172bbb302bafb40021952542c9d405d878c39" alt="Screenshot of CMake GUI where you can configure dependencies."
Note
USE_EIGEN
, USE_OPENCV
and USE_PCL
, respectively.USE_ARUCO
to configure the samples that depend on ArUco library (OpenCV_Contrib).Include Eigen
If you do want to use Eigen 3, click Add Entry to add the path of your Eigen3 installation.
Set the top three entries:
Name |
|
Type |
|
Value |
path chosen in Clone Eigen |
data:image/s3,"s3://crabby-images/94bc5/94bc54f2d45e294c01d2f5aa0b78c178bcad8c23" alt="Screenshot of CMake GUI where you can enter Eigen 3 include directory."
data:image/s3,"s3://crabby-images/47126/4712635727dda8cad54bebe02554febac1694f1f" alt="Screenshot of CMake GUI after EIGEN3_INCLUDE_DIR is added."
Click Configure again.
data:image/s3,"s3://crabby-images/22399/22399c1631dd9dab2857e3f2fa0bcdf89c8636dc" alt="Screenshot of CMake GUI with warning about missing OpenCV installation."
Include OpenCV
If you want to use OpenCV, add the path from Install OpenCV to the value of OpenCV_DIR
.
data:image/s3,"s3://crabby-images/6d6ee/6d6ee2675cc95969704a4cb8e2e67fdc402100c2" alt="Screenshot of CMake GUI after OpenCV_DIR is added."
Click Configure again.
data:image/s3,"s3://crabby-images/3c65e/3c65e7cfb110f130e68f43f6ec8fbf86d697b5f5" alt="Screenshot of CMake GUI after configuration has completed successfully."
Click Generate.
data:image/s3,"s3://crabby-images/58fa0/58fa0516a0b811449bff42276dbfe22925270d3f" alt="Screenshot of CMake GUI generation."
Click Open Project.
Build the solution
Change the build configuration from Debug to Release.
Build the solution by pressing Ctrl + Shift + B.
data:image/s3,"s3://crabby-images/ae6f7/ae6f7837624c9656e848342ada9bc596426b852b" alt="Screenshot of Visual Studio build events for C++ samples."
Run the sample program
Navigate to the Release folder in File Explorer.
data:image/s3,"s3://crabby-images/e6430/e64306c61a5195312ad49b8d2fef907bbda32695" alt="Screenshot of release folder for C++ samples."
Run a sample program, e.g. CaptureVis3D.exe.
data:image/s3,"s3://crabby-images/18e4d/18e4d2647dbece336993efab034759046039a6e8" alt="Screenshot of CaptureVis3D sample."
Close the window.
Debug the sample program
In order to debug you must add C:Program FilesZividbin_debug
to your PATH environment variable.
On your PC, navigate to Control Panel → System and Security → System → Advanced System Settings → Environment Variables.
data:image/s3,"s3://crabby-images/8bbcb/8bbcb1a0a087303fb95b21660119eb203b433c72" alt="Screenshot of system information on Windows."
Under System variables (bottom of the window), select Path
variable and click Edit.
Warning
It is important to click Edit and not New in order not to overwrite the existing value(s) of the PATH system variable!
data:image/s3,"s3://crabby-images/4f6d9/4f6d985660d72795dd7120cffe8c10c250d127b5" alt="Screenshot of system information on Windows."
In the Environment variables window, click New (top-right corner of the window, in the section for user variables) and add the following value:
C:\Program Files\Zivid\bin_debug
data:image/s3,"s3://crabby-images/9cf00/9cf00740ee8c17faaea5eacfc419a8d165d19d24" alt="Screenshot which shows how to add the :code:`C:\Program Files\Zivid\bin_debug` path to the PATH variable."
Note
Debug Program:
If you want to debug a program that depends on an input file you must change Working Directory to ${TargetDir}
.
data:image/s3,"s3://crabby-images/987a1/987a19888d993c6566b0c2f4386b98bbcd1f28d3" alt="GIF which shows how to set working directory for debug in Visual Studio."
Change the build configuration from Debug to Release. Then click F5 to build and run with debug.