This page has been translated automatically.
Video Tutorials
Interface
Essentials
Advanced
How To
Basics
Rendering
Professional (SIM)
UnigineEditor
Interface Overview
Assets Workflow
Version Control
Settings and Preferences
Working With Projects
Adjusting Node Parameters
Setting Up Materials
Setting Up Properties
Lighting
Sandworm
Using Editor Tools for Specific Tasks
Extending Editor Functionality
Built-in Node Types
Nodes
Objects
Effects
Decals
Light Sources
Geodetics
World Nodes
Sound Objects
Pathfinding Objects
Players
Programming
Fundamentals
Setting Up Development Environment
Usage Examples
C++
C#
UnigineScript
UUSL (Unified UNIGINE Shader Language)
Plugins
File Formats
Materials and Shaders
Rebuilding the Engine Tools
GUI
Double Precision Coordinates
API
Animations-Related Classes
Containers
Common Functionality
Controls-Related Classes
Engine-Related Classes
Filesystem Functionality
GUI-Related Classes
Math Functionality
Node-Related Classes
Objects-Related Classes
Networking Functionality
Pathfinding-Related Classes
Physics-Related Classes
Plugins-Related Classes
IG Plugin
CIGIConnector Plugin
Rendering-Related Classes
VR-Related Classes
Content Creation
Content Optimization
Materials
Material Nodes Library
Miscellaneous
Input
Math
Matrix
Textures
Art Samples
Tutorials

Working with Projects

A project is an independent entity that contains all data on your application content organized in a set of directories. The *.project file containing metadata is associated with the project.

Notice
One project can consist of several worlds. So, there is no need to create a separate project for each world.

Creating New Project#

Before starting to create new projects you should have an SDK installed. Once you have the required version of the SDK, you can create a new project as follows:

  1. Open the Projects tab in the SDK browser.

  2. Click Create New. The new project creation window will be opened.
  3. Define the name of the project, choose a path to store project files, specify the SDK and UNIGINE Engine build to be used.

    The project will be created in the <project path>/<unigine_project> folder.

  4. Specify the required application and general settings.
  5. Click Create New Project. The project will appear in the projects list.

Notice
You can change the project settings any time by clicking Other Actions -> Configure.

Application Settings#

The project can be created with the following application settings:

Template

A template that is used as a basis for the project:

  • Empty — no template is used for the project.
  • VR — a template is used to facilitate creation of a custom application for VR.
  • IG — a template is used to facilitate creation of a custom Image Generator application.
API+IDE

Programming language to be used for project creation. The following APIs are available:

  • UnigineScript only — UnigineScript will be used to implement the project.
  • C++ — C++ API will be used to implement the project. For a project using a template, one of the following variants should be used depending on the OS:

    • On Windows:

      • C++ (Visual Studio 2022)
      • C++ (Qt-based) — Qt Creator, QMake, or CMake is required for building the project.
      • C++ (CMake)
    • On Linux:

      • C++ GNU Make
  • C# (.NET) — C# API and Component System will be used to implement the project. .NET is required for building the project.
Precision

The coordinates precision to be used:

Features#

The project can be created with the following features:

Command-line Runtimes Generator Enables Command-line Runtimes Generator for the project.
Command-line Build Tool Enables the Command-line Build Tool for the project.
Sandworm Distributed & Headless Mode Enables creation of the console application required on Worker computers for distributed computing and headless generation of terrain using the Sandworm tool for the project.
Editor Plugin Template

Enables the creation of an editor plugin based on available templates for the project.

The Plugins (0) button opens the list of available plugins:

STEREO 3D
Oculus support (Oculus plugin) Create project with the Oculus Rift virtual display support.
Dual output stereo 3D (Separate plugin) Output 2 separate images for each eye.
Notice
The Separate plugin supports DirectX 11 only.
Varjo support (Varjo plugin) Create project with the Varjo output support.
HTC Vive support (OpenVR plugin) Create project with the HTC Vive/OpenVR output support.
MULTI-MONITOR
3-monitor output (Surround plugin) Render the application across 3 monitors simultaneously.
SpiderVision
(SpiderVision plugin)
Render the application into the configurable number of monitors or projections, or use a multi-projector setup stored in a calibration file created via Scalable Display Manager and set up via EasyBlend SDK.
NETWORK
ARTTracker plugin Create a project with the ARTTracker plugin.
Steam plugin Create a project with the plugin for Steam integration.
Syncker plugin Create a project with the Syncker plugin for multi-channel rendering synchronization.
VRPN Client plugin Create a project with the VRPN Client plugin.
SPECIALS
GPU Monitor plugin Enable GPU frequencies and temperature monitoring for your project.
Kinect2 Plugin Create a project with the Kinect2 plugin.
Leap Motion plugin Tracking hands and fingers with Leap Motion.
VCSIntegration Plugin Using the version control system (SVN, Git) to track all file changes performed in UNIGINE Editor.
TeslaSuit plugin Creating sensations, tracing the body motions, and capturing the user's biometrics with Teslasuit.
Ultraleap Tracking hands and fingers with Ultraleap.
GEODETIC
Geodetics plugin Plugin that allows translating GPS latitude, longitude, and altitude coordinates to X, Y, and Z and vice versa.

Adding Existing Project#

To add an existing project to the browser:

  1. Click Add Existing in the Projects tab.
  2. In the file dialog window that opens, specify the path to the project folder and click Apply. The project will appear in the projects list.
Notice
If the added project was created in the SDK of a previous version, it will be marked with the Upgrade label.

Upgrading Existing Project#

Projects that require upgrade are marked with the Upgrade label:

To upgrade your project to the newest installed version of UNIGINE SDK:

  1. Click the Upgrade label on the project image or Other Actions -> Configure. The following form will open:

  2. Choose the newest installed version of the SDK and click CONFIGURE PROJECT.
  3. Specify a path to the backup folder into which the original project will be copied. Keep Migrate Content checked and click UPGRADE PROJECT.

The project will be upgraded automatically. You can also manually upgrade the project by running the upgrade script. In both cases, the same script will be used.

Notice
The source code should be upgraded manually by using the Migration Guide.

Running a Project#

To run the actual compiled binary of the project with default settings, click the Run button:

You can also use launchers created by default in the project folder:

  • launch_debug — the launcher of the project's debug version.
  • launch_editor — the launcher of the project's with the loaded editor.
  • launch_release — the launcher of the project's release version.

    Notice
    To use the release launcher, you should reconfigure your project to the Release binaries first.

Running Project with Custom Settings#

To run the project with custom settings, click an ellipsis on the Run button:

The Customize Run Options form will open.

Depending on the value of the Application option, different sets of options are available:

  • Default — the default main application (<project_name>_x*.exe) will be run:

    The default main application should be used when only UnigineScript is used to implement the project. In this case, the following options can be customized:

    Debug Indicates whether debug or release version of the application should be run.
    Microprofile Enabled Run the application with the Microprofile tool enabled.
    Arguments Start-up command-line options.
    Remember Indicates whether to remember the specified custom settings for the future run.
  • Custom — a custom main application will be run:

    This option should be chosen if the C++ or C# API is used to implement the project (besides UnigineScript). In this case, the following options can be customized:

    Binary Name of the custom main application. Here the name of the compiled binary executable located in the bin folder of the project should be specified. If the binary executable is located outside this folder, a path to it relative to the bin folder should be specified.
    Arguments Start-up command-line options.
    Remember Indicates whether to remember the specified custom settings for future run.

Editing a Project#

The project content is edited via UNIGINE Editor, code is edited via IDE.

  • To edit the project content, click Open Editor.

  • To edit the source code use Open Code IDE. The IDE selected as the default one will be used to open code.

The project editing tools can also be run in a customized mode.

Customizing UNIGINE Editor Options#

Customize the UNIGINE Editor running options by clicking an ellipsis on the Open Editor button:

In the Customize UNIGINE Editor Options form that opens, set the required values and click Edit.

Additional arguments Start-up command-line options.
Debug The editor version (debug or release) that will be used for project's editing.
Microprofile Enabled Run the application with the Microprofile tool enabled.
Remember Indicates whether to remember the specified custom settings for a future run or not.

Customizing IDE Options#

To change a tool, do the following:

  • On Windows, click an ellipsis on the Open Code IDE button. The following form will open:

    Choose Custom in the drop-down list and specify a path to a custom tool (e.g. IDE or editor) with required arguments:

  • On Linux, click Open Folder and then edit code in an associated tool.

See Also

Release and Development Builds#

You can choose the Development or Release build of UNIGINE Engine:

  • The Development build includes additional features that can be useful for project's development (Microprofile, etc.)
  • The Release build allows checking the final performance of the application.

By default, the project is configured to use Development Engine binaries that contain additional debugging tools. Development binaries of the Engine require a running SDK Browser instance, just the same way as for the UnigineEditor.

You can run your application without running SDK Browser via the launch_release file in the project folder, but first, you should reconfigure the project to use the Release binaries.

To reconfigure the project:

  1. Click Other Actions -> Configure.

  2. Select the Release option in the Engine drop-down.

  3. Click the Update Configuration button at the bottom of the configuration window to save the configuration.

As soon as the project has been reconfigured to the Release build, it can be run without SDK Browser — run the launch_release file in the project folder.

The Release binaries should be used in the final build of the project.

Other Actions#

When clicking the Other Actions button, the following options are available:

Configure Change project settings.
Open Folder Open the project folder.
Delete Delete the project.

Updating Project Configuration#

When clicking Other Actions -> Configure, the following form opens:

Via this form, you can change settings of an existing project: the UNIGINE Engine build used for the project, the version of the release application, the coordinates precision, and the general settings. This option should also be used when you need to upgrade the existing project to the newest SDK version.

Moreover, you can restore the project's files that were corrupted, missed, or mistakenly modified. For this, you should leave settings in the form unchanged and press the Update Configuration button. In this case, the following files of the project will be restored (they will be copied from the SDK):

  • Binaries
  • core.ung, editor.ung and scripts.ung
  • Launchers
Notice
If some of the files listed above are changed, the .modified postfix is added to names of such files. At that, the files from the SDK will also be copied.
Last update: 2024-07-12
Build: ()