Creating and Setting Up Unreal Environment
This page contains the complete instructions start to finish for setting up Unreal environment with AirSim. The Unreal Marketplace has several environment available that you can start using in just few minutes. It is also possible to use environments available on websites such as turbosquid.com or cgtrader.com with bit more effort (here's tutorial video). In addition, there also several free environments available.
Below we will use a freely downloadable environment from Unreal Marketplace called Landscape Mountain but the steps are same for any other environments.
Note for Linux Users
There is no Epic Games Launcher
for Linux which means that if you need to create custom environment, you will need Windows machine to do that. Once you have Unreal project folder, just copy it over to your Linux machine.
Step-by-Step Instructions when using Cosys-AirSim from Precompiled Binaries
- It is assumed you downloaded the right precompiled Cosys-AirSim plugin from the GitHub releases page for the right Unreal version.
-
In
Epic Games Launcher
click the Samples tab then scroll down and findLandscape Mountains
. Click theCreate Project
and download this content (~2GB download). -
Open
LandscapeMountains.uproject
, it should launch the Unreal Editor.!!!note
The Landscape Mountains project is supported up to Unreal Engine version 4.24. If you do not have 4.24 installed, you should see a dialog titled `Select Unreal Engine Version` with a dropdown to select from installed versions. Select 5.X to migrate the project to a supported engine version. If you have 4.24 installed, you can manually migrate the project by navigating to the corresponding .uproject file in Windows Explorer, right-clicking it, and selecting the `Switch Unreal Engine version...` option.
-
Go to the
LandscapeMountains
project folder and create a new subfolder calledPlugins
. Now copy the precompiled AirSim Plugin folder into this newly created folder. This way now your own Unreal project has AirSim plugin. -
Edit the
LandscapeMountains.uproject
so that you add the AirSim plugin to the list of plugins to load.json { ... "Plugins": [ { "Name": "AirSim", "Enabled": true } ] ... }
-
Edit the
Config\DefaultGame.ini
to add the following lines at the end:+MapsToCook=(FilePath="/AirSim/AirSimAssets") +DirectoriesToAlwaysCook=(Path="/AirSim/HUDAssets") +DirectoriesToAlwaysCook=(Path="/AirSim/Beacons") +DirectoriesToAlwaysCook=(Path="/AirSim/Blueprints") +DirectoriesToAlwaysCook=(Path="/AirSim/Models") +DirectoriesToAlwaysCook=(Path="/AirSim/Sensors") +DirectoriesToAlwaysCook=(Path="/AirSim/StarterContent") +DirectoriesToAlwaysCook=(Path="/AirSim/VehicleAdv") +DirectoriesToAlwaysCook=(Path="/AirSim/Weather")
Doing this forces Unreal to include all necessary AirSim content in packaged builds of your project.
-
If using Unreal Engine 5.3 or higher check here for a fix to the camera scene rendering bug in these engine versions!
-
Close the
Unreal Editor
and restart it by opening the uproject file again. -
In
Window/World Settings
as shown below, set theGameMode Override
toAirSimGameMode
: -
Go to 'Edit->Editor Preferences' in Unreal Editor, in the 'Search' box type 'CPU' and ensure that the 'Use Less CPU when in Background' is unchecked. If you don't do this then UE will be slowed down dramatically when UE window loses focus.
-
Be sure to
Save
these edits. Hit the Play button in the Unreal Editor. See the other documentation pages for how to use it.
Step-by-Step Instructions when using Cosys-AirSim from Source Build
- Make sure AirSim is built and Unreal 5.X is installed as described in the installation instructions.
-
In
Epic Games Launcher
click the Samples tab then scroll down and findLandscape Mountains
. Click theCreate Project
and download this content (~2GB download). -
Open
LandscapeMountains.uproject
, it should launch the Unreal Editor.!!!note
The Landscape Mountains project is supported up to Unreal Engine version 4.24. If you do not have 4.24 installed, you should see a dialog titled `Select Unreal Engine Version` with a dropdown to select from installed versions. Select 5.X to migrate the project to a supported engine version. If you have 4.24 installed, you can manually migrate the project by navigating to the corresponding .uproject file in Windows Explorer, right-clicking it, and selecting the `Switch Unreal Engine version...` option.
-
From the
File menu
selectNew C++ class
, leave defaultNone
on the type of class, clickNext
, leave default nameMyClass
, and clickCreate Class
. We need to do this because Unreal requires at least one source file in project. It should trigger compile and open up Visual Studio solutionLandscapeMountains.sln
. -
Go to your folder for AirSim repo and copy
Unreal\Plugins
folder in to yourLandscapeMountains
folder. This way now your own Unreal project has AirSim plugin.!!!note
If the AirSim installation is fresh, i.e, hasn't been built before, make sure that you run `build.cmd` from the root directory once before copying `Unreal\Plugins` folder so that `AirLib` files are also included. If you have made some changes in the Blocks environment, make sure to run `update_to_git.bat` from `Unreal\Environments\Blocks` to update the files in `Unreal\Plugins`.
-
Edit the
LandscapeMountains.uproject
so that it looks like thisjson { "FileVersion": 3, "EngineAssociation": "", "Category": "Samples", "Description": "", "Modules": [ { "Name": "LandscapeMountains", "Type": "Runtime", "LoadingPhase": "Default", "AdditionalDependencies": [ "AirSim" ] } ], "TargetPlatforms": [ "MacNoEditor", "WindowsNoEditor" ], "Plugins": [ { "Name": "AirSim", "Enabled": true } ] }
-
Edit the
Config\DefaultGame.ini
to add the following lines at the end:+MapsToCook=(FilePath="/AirSim/AirSimAssets") +DirectoriesToAlwaysCook=(Path="/AirSim/HUDAssets") +DirectoriesToAlwaysCook=(Path="/AirSim/Beacons") +DirectoriesToAlwaysCook=(Path="/AirSim/Blueprints") +DirectoriesToAlwaysCook=(Path="/AirSim/Models") +DirectoriesToAlwaysCook=(Path="/AirSim/Sensors") +DirectoriesToAlwaysCook=(Path="/AirSim/StarterContent") +DirectoriesToAlwaysCook=(Path="/AirSim/VehicleAdv") +DirectoriesToAlwaysCook=(Path="/AirSim/Weather")
Doing this forces Unreal to include all necessary AirSim content in packaged builds of your project.
-
If using Unreal Engine or higher check here for a fix to the camera scene rendering bug in these engine versions!
-
Close Visual Studio and the
Unreal Editor
and right-click the LandscapeMountains.uproject in Windows Explorer and selectGenerate Visual Studio Project Files
. This step detects all plugins and source files in your Unreal project and generates.sln
file for Visual Studio.!!!tip
If the `Generate Visual Studio Project Files` option is missing you may need to reboot your machine for the Unreal Shell extensions to take effect. If it is still missing then open the LandscapeMountains.uproject in the Unreal Editor and select `Refresh Visual Studio Project` from the `File` menu.
-
Reopen
LandscapeMountains.sln
in Visual Studio, and make sure "DebugGame Editor" and "Win64" build configuration is the active build configuration. -
Press
F5
torun
. This will start the Unreal Editor. The Unreal Editor allows you to edit the environment, assets and other game related settings. First thing you want to do in your environment is set upPlayerStart
object. In Landscape Mountains environment,PlayerStart
object already exist, and you can find it in theWorld Outliner
. Make sure its location is set up as shown. This is where AirSim plugin will create and place the vehicle. If its too high up then vehicle will fall down as soon as you press play giving potentially random behavior -
In
Window/World Settings
as shown below, set theGameMode Override
toAirSimGameMode
: -
Go to 'Edit->Editor Preferences' in Unreal Editor, in the 'Search' box type 'CPU' and ensure that the 'Use Less CPU when in Background' is unchecked. If you don't do this then UE will be slowed down dramatically when UE window loses focus.
-
Be sure to
Save
these edits. Hit the Play button in the Unreal Editor. See the other documentation pages for how to use it.
Congratulations! You are now running AirSim in your own Unreal environment.
Updating Your Environment to Latest Version of AirSim
Once you have your environment using above instructions, you should frequently update your local AirSim code to latest version from GitHub. Below are the instructions to do this:
- First put clean.bat (or clean.sh for Linux users) in the root folder of your environment. Run this file to clean up all intermediate files in your Unreal project.
- Do
git pull
in your AirSim repo followed bybuild.cmd
(or./build.sh
for Linux users). - Replace [your project]/Plugins folder with AirSim/Unreal/Plugins folder.
- Right-click on your .uproject file and chose "Generate Visual Studio project files" option. This is not required for Linux.
Choosing Your Vehicle: Car or Multirotor
By default, AirSim prompts user for which vehicle to use. You can easily change this by setting SimMode. Please see using car guide.
Unreal Scene camera bug
Note that Unreal 5.3 and higher breaks camera scene rendering when Effects is not set to the Epic scalability preset. You can use the console command r.DetailMode 2 to fix this at runtime! For the Blocks and other available environments we have made a fix for this. By placing a DefaultScalability.ini file in the Config folder of your Unreal project, you can set the scalability settings to custom values for each one (low, medium, high, epic, cine). As you can see in the Blocks environment, we have added the following to it to fix this bug automatically. You can find the DefaultScalability.ini file in the Unreal/Environments/Blocks folder. Copy this file to your Unreal project's Config folder.
[EffectsQuality@0]
r.DetailMode=2
[EffectsQuality@1]
r.DetailMode=2
[EffectsQuality@2]
r.DetailMode=2
[EffectsQuality@3]
r.DetailMode=2
[EffectsQuality@Cine]
r.DetailMode=2
FAQ
What are other cool environments?
Unreal Marketplace has dozens of prebuilt extraordinarily detailed environments ranging from Moon to Mars and everything in between. The one we have used for testing is called Modular Neighborhood Pack but you can use any environment. Another free environment is Infinity Blade series. Alternatively, if you look under the Learn tab in Epic Game Launcher, you will find many free samples that you can use. One of our favorites is "A Boy and His Kite" which is 100 square miles of highly detailed environment (caution: you will need very beefy PC to run it!).
When I press Play button some kind of video starts instead of my vehicle.
If the environment comes with MatineeActor, delete it to avoid any startup demo sequences. There might be other ways to remove it as well, for example, click on Blueprints button, then Level Blueprint and then look at Begin Play event in Event Graph. You might want to disconnect any connections that may be starting "matinee".
Is there easy way to sync code in my Unreal project with code in AirSim repo?
Sure, there is! You can find a bunch of .bat
files (for linux, .sh
) in AirSim\Unreal\Environments\Blocks
. Just copy them over to your own Unreal project. Most of these are quite simple and self-explanatory.
I get some error about map.
You might have to set default map for your project. For example, if you are using Modular Neighborhood Pack, set the Editor Starter Map as well as Game Default Map to Demo_Map in Project Settings > Maps & Modes.
I see "Add to project" option for environment but not "Create project" option.
In this case, create a new blank C++ project with no Starter Content and add your environment in to it.
I already have my own Unreal project. How do I use AirSim with it?
Copy the Unreal\Plugins
folder from the build you did in the above section into the root of your Unreal project's folder. In your Unreal project's .uproject file, add the key AdditionalDependencies
to the "Modules" object
as we showed in the LandscapeMountains.uproject
above.
"AdditionalDependencies": [
"AirSim"
]
and the Plugins
section to the top level object:
"Plugins": [
{
"Name": "AirSim",
"Enabled": true
}
]