Cesium for Unreal 2.12.0
|
Detailed instructions for setting up a Cesium for Unreal development environment on Linux. Please see the Developer Setup page for an overview of the process.
After compiling Unreal Engine, set the following environment variables in your .bashrc
.
v20_clang-13.0.1-centos7
is correct for Unreal Engine v5.0.3. It may be different for other versions of Unreal Engine. See https://docs.unrealengine.com/5.0/en-US/SharingAndReleasing/Linux/GettingStarted/ or the equivalent for your version of Unreal Engine.The following illustrates the recommended directory layout for developers:
~/dev
- Your own root directory for development.~/dev/cesium-unreal-samples
- The directory for the Unreal project that will use the plugin.~/dev/cesium-unreal
- The directory for the actual Cesium for Unreal plugin.~/dev/cesium-unreal/extern/cesium-native
- The directory for the base libraries project.In this setup, we will build the Cesium for Unreal plugin separately from any project, and then install it as an Engine plugin.
First, let's clone the Cesium for Unreal repo by issuing the following command in the ~/dev
directory:
cesium-native
submodule and its dependencies. If you forget the --recursive
option, you will see many compiler errors later in this process. If this happens to you, run the following in the Plugins\cesium-unreal
directory to update the submodules in the existing clone:git submodule update –init –recursive
The cesium-native libraries and their dependencies use CMake and must be built separately from Cesium for Unreal. There are a number of ways to do this, but typically on Linux this is done with CMake from the command-line.
Configure the CMake project in the ~/dev/cesium-unreal/extern
directory by following the instructions below.
extern
directory, and not the cesium-native
subdirectory!Change to the ~/dev/cesium-unreal/extern
directory, and execute the following commands to build and install a Debug version of cesium-native:
cmake -B build -S . -DCMAKE_TOOLCHAIN_FILE="unreal-linux-toolchain.cmake" -DCMAKE_POSITION_INDEPENDENT_CODE=ON -DCMAKE_BUILD_TYPE=Debug cmake --build build --target install
To build a Release version, do the following:
-j14
to the build/install command above, i.e. cmake --build build --target install -j14
. "14" is the number of threads to use, and a higher or lower number may be more suitable for your system.You may encounter an issue with the Unreal Build tool generating errors with symlinks in the KTX-Software submodule. This directory is no longer needed after cesium-native is built, therefore it can safely be removed.
Delete the entire 'cesium-unreal/extern' directory:
cd .. rm -rf extern
Alternatively, this directory could be moved elsewhere and brought back in the case of a rebuild.
Store the absolute path of the root directory of the cesium-unreal
repo in an environment variable for ease of reference:
export CESIUM_FOR_UNREAL_DIR=~/dev/cesium-unreal # adjust path for your system
And build the plugin:
cd $UNREAL_ENGINE_DIR/Engine/Build/BatchFiles ./RunUAT.sh BuildPlugin -Plugin="$CESIUM_FOR_UNREAL_DIR/CesiumForUnreal.uplugin" -Package="$CESIUM_FOR_UNREAL_DIR/../packages/CesiumForUnreal" -CreateSubFolder -TargetPlatforms=Linux
And finally copy the built plugin into the Engine plugins directory:
CesiumForUnreal
plugin go in the Plugins/Marketplace/
subdirectory, rather than directly in Plugins/
. Otherwise, the relative paths to other plugin .so
files that the Unreal Build Tool has built into the plugin will not resolve correctly.The Cesium for Unreal Samples project demonstrates a bunch of features of Cesium for Unreal, and it is useful during development for testing the plugin. I can be cloned from GitHub as well:
cd ~/dev git clone https://github.com/CesiumGS/cesium-unreal-samples.git
Then, launch the Unreal Editor and open ~/dev/cesium-unreal-samples/CesiumForUnrealSamples.uproject
. Because we've already installed the plugin to the Engine Plugins directory, the samples project should pick it up automatically.