Configure C++ Samples With CMake and Build Them in Visual Studio in Windows

이 자습서는 CMake로 Zivid C++ 샘플을 구성한 다음 Windows에서 Visual Studio로 빌드하는 방법을 보여줍니다.

Requirements

Optional requirements

일부 샘플은 다음과 같은 외부 라이브러리가 필요합니다.

참고

다음 지침은 이러한 버전의 종속성으로 테스트되었습니다.

  • Visual Studio 2019 이상

  • CMake 3.24 이상

  • PCL 1.12.1

  • Eigen 3.4.0

  • OpenCV 4.7.0

다른 버전을 사용하는 경우 문제가 발생할 수 있습니다.

Instructions

Clone C++ Samples

GitHub Zivid C++ Samples 저장소를 복제하세요. 복제하려면 키보드에서 Win + R 키를 눌러 명령 프롬프트를 실행한 다음, cmd 를 입력하고 Enter 키를 누르세요.

저장소를 복제하려는 위치로 이동합니다. 예:

cd C:\Users\Public

그런 다음 다음 명령을 실행합니다:

git clone https://github.com/zivid/zivid-cpp-samples

Configure the solution with CMake

명령 프롬프트나 CMake GUI를 통해 CMake를 실행합니다.

빌드 디렉토리를 Zivid-cpp-samples 디렉토리에 만들고 다음을 실행하여 솔루션을 구성합니다:

mkdir build && cd build
cmake -DUSE_EIGEN3=OFF -DUSE_OPENCV=OFF -DUSE_PCL=OFF ../source

위 명령을 사용하려면 cmake 가 시스템 PATH에 있는지 확인하세요. CMake를 시스템 PATH에 추가하는 방법은 아래 드롭다운 메뉴를 참조하세요.

시스템 PATH에 CMake를 추가합니다.

PC에서 Control PanelSystem and SecuritySystemAdvanced System SettingsEnvironment Variables 로 이동합니다. 시스템 변수 에서 Path 변수를 선택하고 Edit 을 클릭합니다.

Windows의 시스템 정보 스크린샷.

Edit environment variable 창에서 New 클릭하고 CMake 바이너리에 대한 경로를 추가합니다. 예:

C:\Program Files\CMake\bin

Program Files 에 CMake를 설치한 경우.

경고

변경 사항을 적용하려면 Windows 계정에서 로그아웃한 다음 다시 로그인해야 할 수도 있습니다.

생성된 Visual Studio 솔루션 ZividCppSamples.sln 파일 탐색기에서 열어 샘플을 추가로 빌드합니다.

CMake GUI를 열고 빌드 폴더의 소스 폴더와 대상 폴더를 선택합니다.

Zivid C++ 샘플에 대한 구성이 포함된 CMake GUI의 스크린샷.

Configure 를 클릭합니다. 프로젝트에 사용할 생성기를 지정하고 (선택 사항) 플랫폼이 x64 인지 확인합니다. Finish 클릭합니다.

생성기를 지정하는 CMake GUI의 스크린샷.

Configure 을 다시 클릭합니다.

종속성 오류가 있는 CMake GUI의 스크린샷입니다.

CMake 오류에서 OK 클릭하고 USE_EIGEN3 , USE_OPENCVUSE_PCL 변수를 비활성화하여 이러한 종속성 없이 솔루션을 구성합니다.

종속성을 구성할 수 있는 CMake GUI의 스크린샷.

마지막으로 Configure 한 번 더 클릭하고 GenerateOpen Project 를 클릭하여 Visual Studio 솔루션을 엽니다.

Build the solution

Visual Studio에서 빌드 구성을 Debug 에서 Release 로 변경합니다. Ctrl + Shift + B 를 눌러 솔루션을 빌드합니다.

C++ 샘플에 대한 Visual Studio 빌드 이벤트의 스크린샷.

Run the sample program

Release 폴더로 이동하여 파일 탐색기에서 exe 두 번 클릭하거나 명령 프롬프트를 사용하여 샘플 프로그램을 실행합니다. 예:

.\CaptureVis3D.exe
CaptureVis3D 샘플의 스크린샷.

Running samples that require Sample Data

포인트 클라우드, 파일 카메라, 변환 등 일부 샘플을 실행하려면 추가 데이터가 필요합니다. 이러한 샘플을 다운로드하고 설치하는 방법에 대한 지침은 Sample Data 로 이동하세요.

Configuring the samples with optional dependencies

Some of the samples depend on Point Cloud Library, Eigen, OpenCV, and/or Halcon. If you want to run samples with one or more of these dependencies, follow the instructions in the below dropdown.

Optional dependencies

실행하려는 샘플 프로그램에 따라 필요한 종속성을 설치하세요. 아래 표를 참조하세요.

Sample program

PCL

Eigen

OpenCV

Halcon

ReadPCLVis3D

YES

CaptureWritePCLVis3D

YES

CaptureAndVisualizeNormals

YES

StitchByTransformation

StitchByTransformationFromZDF

MaskPointCloud

YES

YES

ROIBoxViaCheckerboard

YES

UtilizeHandEyeCalibration

YES

PoseConversions

YES

ROIBoxViaArucoMarker

YES

YES

CaptureUndistort2D

YES

CreateDepthMap

YES

ProjectAndFindMarker

YES

ReprojectPoints

YES

ReadProjectAndCaptureImage

YES

GammaCorrection

YES

AllocateMemoryForPointCloudData

YES

TransformPointCloudViaCheckerboard

YES

TransformPointCloudViaArucoMarker

YES

CaptureHalconViaGenICam

YES

CaptureHalconViaZivid

YES

http://eigen.tuxfamily.org/ 에서 Eigen의 최신 안정 버전을 다운로드하고 원하는 위치에 폴더를 추출하세요. CMake 프로젝트를 구성할 때 Eigen을 포함하여 해당 프로젝트에 종속된 샘플을 구성하세요.

zivid-cpp-samples 에서 생성한 빌드 디렉토리로 이동하여 다음을 실행합니다.

cmake -DEIGEN3_INCLUDE_DIR=<path> -DUSE_OPENCV=OFF -DUSE_PCL=OFF ../source

여기서 <path> Eigen을 설치한 전체 경로입니다(예 C:/Program Files/Eigen ).

CMake GUI에서 Add Entry 클릭하여 Eigen 경로를 추가합니다. EIGEN3_INCLUDE_DIR 추가하고 값을 폴더 압축을 푼 위치로 지정합니다.

Eigen 3 포함 디렉토리를 입력할 수 있는 CMake GUI의 스크린샷.

USE_EIGEN3 상자가 선택되어 있는지 확인하고 Configure 클릭합니다. 그런 다음 GenerateOpen Project 를 클릭하여 Visual Studio 솔루션을 엽니다.

https://github.com/PointCloudLibrary/pcl/releases 에서 .exe 선택하여 미리 빌드된 PCL 바이너리를 다운로드하고 설치하세요. 타사 라이브러리 설치 옵션을 선택하세요.

Windows의 PCL 설치 마법사 스크린샷.

Zivid PCL 코드 샘플을 구성하려면 먼저 PATH 시스템 변수에 일부 설정을 포함해야 합니다. PC에서 Control PanelSystem and SecuritySystemAdvanced System SettingsEnvironment Variables 로 이동합니다. System variables 에서 Path 변수를 선택하고 Edit 를 클릭합니다.

Windows의 시스템 정보 스크린샷.

Edit environment variable 창에서 New 클릭하고 PCL 바이너리 및 OpenNI2(타사 라이브러리)에 대한 경로를 추가합니다.

C:\Program Files\PCL 1.12.1\bin
C:\Program Files\OpenNI2\Tools

Program Files 에 PCL 1.12.1과 OpenNI2를 설치한 경우, 변경 사항을 적용하려면 Windows 계정에서 로그아웃했다가 다시 로그인해야 할 수 있습니다.

경고

VTK와 같은 일부 타사 PCL 라이브러리에 수동으로 연결해야 할 수도 있습니다. 오류가 발생하면 PATH 시스템 변수에 라이브러리 바이너리 경로를 추가하세요. 예를 들어 VTK의 경우, Program Files 에 PCL 1.12.1을 설치했다면 C:/Program Files/PCL 1.12.1/3rdParty/VTK/bin 추가합니다.

CMake 프로젝트를 구성할 때 PCL 경로는 이미 구성되어 있어야 합니다.

zivid-cpp-samples 에서 생성한 빌드 디렉토리로 이동하여 다음을 실행합니다.

cmake -DUSE_PCL=ON -DUSE_EIGEN3=OFF -DUSE_OPENCV=OFF ../source

CMake GUI에서 USE_PCL 상자가 선택되어 있는지 확인하고 Configure 를 클릭합니다.

../../../_images/cmake_gui_screenshot_add_pcl.png

GenerateOpen Project 를 클릭하여 Visual Studio 솔루션을 엽니다.

https://opencv.org/releases/ 에서 미리 빌드된 OpenCV 바이너리를 다운로드하여 설치합니다. 원하는 위치에 압축을 풉니다(예:

C:\Users\Public

Zivid OpenCV 코드 샘플을 구성하려면 먼저 PATH 시스템 변수에 일부 설정을 포함해야 합니다. PC에서 Control PanelSystem and SecuritySystemAdvanced System SettingsEnvironment Variables 로 이동합니다. System variables 에서 Path 변수를 선택하고 Edit 클릭합니다.

Windows의 시스템 정보 스크린샷.

Edit environment variable 창에서 New 클릭하고 OpenCV 바이너리에 대한 경로를 추가합니다. 예:

C:\Program Files\opencv\build\x64\vc16\bin

OpenCV 4.7.0을 설치하고 C:/Program Files/opencv 에 압축을 풀었다면,

경고

변경 사항을 적용하려면 Windows 계정에서 로그아웃한 다음 다시 로그인해야 할 수도 있습니다.

CMake 프로젝트를 구성할 때, 이에 종속된 샘플을 구성하기 위해 OpenCV를 포함합니다.

zivid-cpp-samples 에서 생성한 빌드 디렉토리로 이동하여 다음을 실행합니다.

cmake -DOpenCV_DIR=<path> -DUSE_EIGEN3=OFF -DUSE_PCL=OFF ../source

여기서 <path> OpenCV 빌드 폴더의 전체 경로입니다(예 C:/Program Files/opencv/build).

CMake GUI에서 Add Entry 클릭하여 OpenCV 경로를 추가합니다. OpenCV_DIR 추가하고 값으로 OpenCV 빌드 폴더를 지정합니다.

OpenCV 포함 디렉토리를 입력할 수 있는 CMake GUI의 스크린샷입니다.

USE_OPENCV 상자가 선택되어 있는지 확인하고 Configure 클릭합니다. 그런 다음 GenerateOpen Project 를 클릭하여 Visual Studio 솔루션을 엽니다.

Halcon C++ 샘플을 실행하려면 PC에 Halcon이 설치되어 있어야 합니다. 자세한 내용은 Install Zivid + HALCON for Windows 를 참조하세요.

Halcon을 설치한 후 Halcon 샘플을 사용하도록 CMake를 구성합니다.

zivid-cpp-samples 에서 생성한 빌드 디렉토리로 이동하여 다음을 실행합니다.

cmake -DUSE_HALCON=ON -DUSE_EIGEN3=OFF -DUSE_OPENCV=OFF -DUSE_PCL=OFF ../source

USE_HALCON 상자가 선택되어 있는지 확인하고 Configure 클릭합니다.

../../../_images/cmake_gui_screenshot_add_halcon.png

그런 다음 GenerateOpen Project 를 클릭하여 Visual Studio 솔루션을 엽니다.

여러 종속성을 한 번에 구성하려면 CMake에서 여러 종속성을 동시에 추가하기만 하면 됩니다. 예를 들어 Eigen, PCL, OpenCV가 필요한 모든 샘플을 사용하려면 다음을 실행하면 됩니다.

cmake -DEIGEN3_INCLUDE_DIR=<path-to-eigen> -DUSE_PCL=ON -DOpenCV_DIR=<path-to-opencv> ../source

여기서 <path-to-eigen><path-to-opencv> 는 Eigen 및 OpenCV 폴더의 경로입니다.

Debug the sample program

샘플을 디버깅하려면 PATH 환경 변수에 C:/Program Files/Zivid/bin_debug 추가해야 합니다. 아래 드롭다운 메뉴의 지침을 따르세요.

Debugging a sample program

PC에서 다음으로 이동합니다. Control PanelSystem and SecuritySystemAdvanced System SettingsEnvironment Variables.

Windows의 시스템 정보 스크린샷.

System variables 에서 Path 변수를 선택하고 Edit 클릭합니다.

Windows의 시스템 정보 스크린샷.

Environment variables 창에서 New (창의 오른쪽 상단 모서리, 사용자 변수 섹션)를 클릭하고 다음 값을 추가합니다.

C:\Program Files\Zivid\bin_debug
PATH 변수에 :code:`C:\Program Files\Zivid\bin_debug` 경로를 추가하는 방법을 보여주는 스크린샷.

참고

입력 파일에 의존하는 프로그램을 디버깅하려면 작업 디렉터리를 ${TargetDir} 로 변경해야 합니다.

Visual Studio에서 디버그용 작업 디렉터리를 설정하는 방법을 보여주는 GIF.

빌드 구성을 Release 에서 Debug 로 변경하세요. 그런 다음 F5 를 눌러 디버그 모드로 빌드하고 실행하세요.

Version History

SDK

Changes

2.17.0

Removed dependency on Open3D due to native support for visualization of unorganized point clouds.

2.16.0

Added instructions for configuring C++ samples with optional dependencies on Ubuntu. Added instructions for configuring Open3D on both Ubuntu and Windows.