CloudCompare requires CMake to be built.
The main dependency of CloudCompare is Qt. CloudCompare 2.13+ requires 5.12 <= Qt < 6.0.
- On Windows it is recommended to use the installer from the Qt website.
- On macOs you can also use the installer from Qt's website, or use homebrew.
- On Linux it is recommended to use your distribution's package manager:
Debian/ubuntu package names:
libqt5svg5-dev libqt5opengl5-dev qt5-default qttools5-dev qttools5-dev-tools libqt5websockets5-dev
The command to clone CloudCompare is:
git clone --recursive https://github.com/cloudcompare/CloudCompare.git
The --recursive
is important as CloudCompare uses Git's submodules system to 'vendor' external libraries
or plugins.
When doing a basic build of CloudCompare, the only CMake arguments that is required
is the CMAKE_PREFIX_PATH
to tell CMake where to find your Qt installation.
This is only required on Windows and macOs as on Linux Qt is installed in a standard location that CMake will find.
You can also use the CMAKE_INSTALL_PREFIX
to customize the path where CloudCompare will be installed.
If you use CMake-GUI the options are the same, you just enter the values in the GUI.
Example:
# Windows
mkdir build & cd build
cmake -DCMAKE_PREFIX_PATH=C:\Qt\5.15.2\msvc2019_64 ..
# macOs
mkdir build && cd build
cmake -DCMAKE_PREFIX_PATH=/usr/local/opt/qt@5 ..
# Linux
mkdir build && cd build
cmake ..
You can always take a look at how CloudCompare is being build on GitHub's CI
# Still in the build folder
cmake --build .
# Still in the build folder
cmake --install .
CloudCompare has a bunch of optional features and plugins not built by default.
Below you will find a list of these options/plugins. To add an option to CMake use the -DMY_OPTION=ON
syntax.
Example, to build the qEDL
plugin, add -DPLUGIN_GL_QEDL=ON
argument to CMake at the configuration step.
The optional features are:
CMake Option | Default Value | Description |
---|---|---|
OPTION_BUILD_CCVIEWER | ON | Whether or not to build the ccViewer side project. |
OPTION_USE_SHAPE_LIB | ON | Use the vendored shapelib to add support for SHP files. |
OPTION_USE_DXF_LIB | ON | Use the vendored dxflib to add support for DXF files. |
OPTION_USE_GDAL | OFF | Add support for a lot of raster files in CloudCompare/ccViewer with GDAL library. |
The following options are Windows-only:
CMake Option | Default Value | Description |
---|---|---|
OPTION_MP_BUILD | OFF | Visual Studio only (multi-process build --> much faster but uses a lot of CPU power) |
OPTION_SUPPORT_3D_CONNEXION_DEVICES | OFF | 3D mouses handling |
OPTION_USE_OCULUS_SDK | OFF | Build with Oculus SDK (LibOVR) support. |
OPTION_USE_VISUAL_LEAK_DETECTOR | OFF | To use the Visual Leak Detector library for MSVC (http://vld.codeplex.com/) |
The available plugins are
Plugin Name | CMake Option | Default Value | Description |
---|---|---|---|
qEDL | PLUGIN_GL_QEDL | OFF | |
qSSAO | PLUGIN_GL_QSSAO | OFF |
Plugin Name | CMake Option | Default Value | Description |
---|---|---|---|
qAdditionalIO | PLUGIN_IO_QADDITIONAL | OFF | |
qCoreIO | PLUGIN_IO_QCORE | ON | |
qCSVMatrixIO | PLUGIN_IO_QCSV_MATRIX | OFF | Add support for CSV matrix files. |
qDraco | PLUGIN_IO_QDRACO | OFF | Add support force draco files |
qE57IO | PLUGIN_IO_QE57 | OFF | Add support for e57 files using libE57. |
qFBXIO | PLUGIN_IO_QFBX | OFF | Add support for AutoDesk FBX files using the official FBX SDK |
qLASFWIO | PLUGIN_IO_QLAS_FWF | OFF | Windows only. Support for LAS/LAZ with and without waveform using LIBlas (deprecated, consider using qLASIO instead). |
qLASIO | PLUGIN_IO_QLAS | OFF | Support for LAS/LAZ with and without waveform (all platforms) using LASZIP. |
qPDALIO | PLUGIN_IO_QPDAL | OFF | Add support for LAS/LAZ files using PDAL (deprecated, consider using qLASIO instead). |
qPhotoscanIO | PLUGIN_IO_QPHOTOSCAN | OFF | |
qRDBIO | PLUGIN_IO_QRDB | OFF | Add support for RDB. |
qStepCADImport | PLUGIN_IO_QSTEP | OFF | Add support for STEP files. |
Plugin Name | CMake Option | Default Value | Description |
---|---|---|---|
q3DMASC | PLUGIN_STANDARD_3DMASC | OFF | Automatic point cloud classification: https://lidar.univ-rennes.fr/en/3dmasc |
qAnimation | PLUGIN_STANDARD_QANIMATION | OFF | Plugin to create videos: https://www.cloudcompare.org/doc/wiki/index.php/Animation_(plugin). |
qBroom | PLUGIN_STANDARD_QBROOM | OFF | Interactive cloud cleaning tool: https://www.cloudcompare.org/doc/wiki/index.php/Virtual_broom_(plugin) |
qCanupo | PLUGIN_STANDARD_QCANUPO | OFF | Automatic point cloud classification: https://www.cloudcompare.org/doc/wiki/index.php/CANUPO_(plugin) |
qCloudLayers | PLUGIN_STANDARD_QCLOUDLAYERS | OFF | Manual point cloud classification/labelling: https://www.cloudcompare.org/doc/wiki/index.php/QCloudLayers_(plugin) |
qColorimetricSegmenter | PLUGIN_STANDARD_QCOLORIMETRIC_SEGMENTER | OFF | Point cloud color-based segmentation: https://www.cloudcompare.org/doc/wiki/index.php/Colorimetric_Segmenter_(plugin) |
qCompass | PLUGIN_STANDARD_QCOMPASS | OFF | Digitization of geological structures and structural traces on point clouds: https://www.cloudcompare.org/doc/wiki/index.php/Compass_(plugin) |
qCork | PLUGIN_STANDARD_QCORK | OFF | Mesh Boolean Operations: https://www.cloudcompare.org/doc/wiki/index.php/Cork_(plugin) |
qCSF | PLUGIN_STANDARD_QCSF | OFF | Automatic ground/non-ground classification: https://www.cloudcompare.org/doc/wiki/index.php/CSF_(plugin) |
qFacets | PLUGIN_STANDARD_QFACETS | OFF | Structural geology plugin: https://www.cloudcompare.org/doc/wiki/index.php/Facets_(plugin) |
qHoughNormals | PLUGIN_STANDARD_QHOUGH_NORMALS | OFF | Normals computation: https://www.cloudcompare.org/doc/wiki/index.php/HoughNormals_(plugin) |
qHPR | PLUGIN_STANDARD_QHPR | OFF | Hidden Point Removal: https://www.cloudcompare.org/doc/wiki/index.php/Hidden_Point_Removal_(plugin) |
qJSonRPCPlugin | PLUGIN_STANDARD_QJSONRPC | OFF | Json/RPC control plugin |
qM3C2 | PLUGIN_STANDARD_QM3C2 | OFF | Robust point cloud distances computation: https://www.cloudcompare.org/doc/wiki/index.php/M3C2_(plugin) |
qMasonry | Segmentation of masonry structures: https://www.cloudcompare.org/doc/wiki/index.php/Masonry_Segmentation_(plugin) | ||
- qAutoSeg | PLUGIN_STANDARD_MASONRY_QAUTO_SEG | OFF | |
- qManualSeg | PLUGIN_STANDARD_MASONRY_QMANUAL_SEG | OFF | |
qMeshBoolean | PLUGIN_STANDARD_QMESH_BOOLEAN | OFF | Mesh Boolean Operations: https://www.cloudcompare.org/doc/wiki/index.php/Mesh_Boolean_(plugin) |
qMPlane | PLUGIN_STANDARD_QMPLANE | OFF | Normal distance measurements against a defined plane: https://www.cloudcompare.org/doc/wiki/index.php/MPlane_(plugin) |
qPCL | PLUGIN_STANDARD_QPCL | OFF | Interface to some algorithms of the PCL library: https://www.cloudcompare.org/doc/wiki/index.php/Point_Cloud_Library_Wrapper_(plugin) |
qPCV | PLUGIN_STANDARD_QPCV | OFF | Ambient Occlusion for meshes or point clouds: https://www.cloudcompare.org/doc/wiki/index.php/ShadeVis_(plugin) |
qPoissonRecon | PLUGIN_STANDARD_QPOISSON_RECON | OFF | Surface Mesh Reconstruction: https://www.cloudcompare.org/doc/wiki/index.php/Poisson_Surface_Reconstruction_(plugin) |
qRANSAC_SD | PLUGIN_STANDARD_QRANSAC_SD | OFF | Automatic RANSAC shape detection: https://www.cloudcompare.org/doc/wiki/index.php/RANSAC_Shape_Detection_(plugin) |
qSRA | PLUGIN_STANDARD_QSRA | OFF | Surface of Revolution Analysis: https://www.cloudcompare.org/doc/wiki/index.php/Surface_of_Revolution_Analysis_(plugin) |
qTreeIso | PLUGIN_STANDARD_QTREEISO | OFF | Individual Tree Isolation: https://www.cloudcompare.org/doc/wiki/index.php/Treeiso_(plugin) |
Some plugins do not have their dependencies vendored in CloudCompare's repo, thus they require additional steps to install them. This section aims to document the steps for these plugins.
The qAnimation plugin has an additional option QANIMATION_WITH_FFMPEG_SUPPORT
to be able to create
movies with FFMPEG.
If you want to compile CloudCompare (and ccViewer) with LibE57 files support, you'll need:
-
Xerces-C++ multi-thread static libraries
- On Ubuntu install the package
libxerces-c-dev
- On Visual C++ (Windows):
- select the
Static Debug
orStatic Release
configurations - you'll have to manually modify the
XercesLib
project options so that theC/C++ > Code Generation > Runtime Library
are of DLL type in both release and debug modes (i.e./MD
in release or/MDd
in debug) - for 64 bits version be sure to select the right platform (x64 instead of Win32). If you use Visual Studio
Express 2010, be sure also that the
toolset
(in the project properties) is set to something likeWindows7.1SDK
- select the
- only the XercesLib project neet to be compiled
- eventually, CMake will look for the resulting files in
/include
(instead of/src
) and/lib
(without the Release or Debug subfolders). By default the visual project will put them in/Build/WinXX/VCXX/StaticXXX
. Therefore you should create a custom folder with the right organization and copy the files there.
- On Ubuntu install the package
-
LibE57 (last tested version: 2.0.1 on Windows)
- Checkout the submodule in
plugins/core/IO/qE57IO/extern/libE57Format
or download and extract the latest libE57Format release
- Checkout the submodule in
qPCL relies on the PCL library. Follow the instructions from their website PCL.
If you want to compile CloudCompare (and ccViewer) with FBX files support, you'll need: The official Autodesk's FBX SDK (last tested version: 2015.1 on Windows)
Then, the CloudCompare CMake project will request that you set the 3 following variables:
FBX_SDK_INCLUDE_DIR
: FBX SDK include directory (pretty straightforward ;)FBX_SDK_LIBRARY_FILE
: main FBX SDK library (e.g.libfbxsdk-md.lib
)FBX_SDK_LIBRARY_FILE_DEBUG
: main FBX SDK library for debug mode (if any)
If you want to compile CloudCompare (and ccViewer) with LAS/LAZ files support, you'll need LASZip.
If you want to compile the deprecated PDAL I/O plugin to load LAS/LAZ files, you'll need PDAL.
The deprecated LAS FWF I/O plugin can also be compiled on Windows with LASlib.
You'll have to set the following variables:
LASLIB_INCLUDE_DIR
: LAStools/LASlib/incLASZIP_INCLUDE_DIR
: LAStools/LASzip/srcLASLIB_RELEASE_LIBRARY
orLASLIB_DEBUG_LIBRARY
, depending on build type: the compiled library, e.g.LAStools/LASlib/VC14/lib/x64/LASlibVC14.lib
If you want to compile CloudCompare (and ccViewer) with GDAL (raster) files support, you'll need a compiled version of the GDAL library (last tested version: 2.2.1 on Windows, 2.0.2 on Mac OS X)
Then, the CloudCompare CMake project will request that you set the following variables:
GDAL_INCLUDE_DIR
: GDAL include directory (pretty straightforward ;)GDAL_LIBRARY
: the static library (e.g.gdal_i.lib
)GDAL_BIN_DIR
: on Windows, the folder with DLL files
If you want to compile the qCork plugin (on Windows only for now), you'll need:
- MPIR 2.6.0
- the forked version of the Cork library for
CC: https://github.com/cloudcompare/cork
- on Windows see the Visual project shipped with this fork and corresponding to your version (if any ;)
- for VS2013 just edit the
mpir
property sheet (in the Properties manager) and update the MPIR macro (in theUser macros
tab)
Then, the CloudCompare CMake project will request that you set the following variables:
-
CORK_INCLUDE_DIR
andMPIR_INCLUDE_DIR
: both libraries include directories (pretty straightforward ;) -
CORK_RELEASE_LIBRARY_FILE
andMPIR_RELEASE_LIBRARY_FILE
: both main library files -
and optionally
CORK_DEBUG_LIBRARY_FILE
andMPIR_DEBUG_LIBRARY_FILE
: both main library files (for debug mode) -
Make sure you have a C++11 compliant compiler (gcc 4.7+ / clang / Visual 2013 and newer)
To compile the project with older versions of Qt (from 4.8 to 5.4) or with a non C++11 compliant compiler, you'll have to stick with the https://github.com/cloudcompare/CloudCompare/releases/tag/v2.6.3.1 version
- Last but not least, the
CMAKE
group contains aCMAKE_INSTALL_PREFIX
variable which is where CloudCompare and ccViewer will be installed (when you compile theINSTALL
project)
- On Linux, default install dir is
/usr/local
(be sure to have administrative rights if you want to install CloudCompare there: once configured, you can call# make install
from the sources directory) - On Windows 7/8/10 CMake doesn't have the rights to 'install' files in the
Program Files
folder (even though it's CMake's default installation destination!)
With versions of CMake prior to 3.13, the compiled application might not work for all users (due to some libraries being linked from the /usr/local directory). See CloudCompare#1680.
If you are compiling and running locally, add -DCC_MAC_DEV_PATHS
to the CMAKE_CXX_FLAGS
in the CMAKE
group. This
will look for the plugins in your build directory rather than the application bundle. If you need the shaders as well,
you will have to create a shaders
folder in the build directory and copy the shaders you need into it.
As all the files (executables, plugins and other DLLs) must be copied in the CMAKE_INSTALL_PREFIX
directory prior to execution,
the standard project launch/debug mechanism is broken. Therefore, by default you won't be able to 'run' the CloudCompare or ccViewer
projects as is (with F5 or Ctrl + F5 for instance).
See this post on the CloudCompare forum to setup Visual Studio correctly.
If you want to use or debug plugins in DEBUG mode while using a single configuration compiler/IDE (gcc, etc.) the you'll have to comment the automatic definition of the QT_NO_DEBUG
macro in '/plugins/CMakePluginTpl.cmake' (see http://www.cloudcompare.org/forum/viewtopic.php?t=2070).
If you wish to specify a custom directory to search for plugins, shaders, or translations, you may set the CC_PLUGIN_PATH
, CC_SHADER_PATH
, and CC_TRANSLATION_PATH
environment variables. The paths may be relative to the current working directory or absolute.