Upgrading to Unreal Engine 4.18
These instructions apply if you are already using AirSim on Unreal Engine 4.16. If you have never installed AirSim, please see How to get it.
Caution: The below steps will delete any of your unsaved work in AirSim or Unreal folder.
Do this first
For Windows Users
- Install Visual Studio 2017 with VC++, Python and C#.
- Install UE 4.18 through Epic Games Launcher.
- Start
x64 Native Tools Command Prompt for VS 2017
and navigate to AirSim repo. - Run
clean_rebuild.bat
to remove all unchecked/extra stuff and rebuild everything.
For Linux Users
- From your AirSim repo folder, run 'clean_rebuild.sh`.
- Rename or delete your existing folder for Unreal Engine.
- Follow step 1 and 2 to install Unreal Engine 4.18.
Upgrading Your Custom Unreal Project
If you have your own Unreal project created in an older version of Unreal Engine then you need to upgrade your project to Unreal 4.18. To do this,
- Open .uproject file and look for the line
"EngineAssociation"
and make sure it reads like"EngineAssociation": "4.18"
. - Delete
Plugins/AirSim
folder in your Unreal project's folder. - Go to your AirSim repo folder and copy
Unreal\Plugins
folder to your Unreal project's folder. - Copy .bat (or .sh for Linux) from
Unreal\Environments\Blocks
to your project's folder. - Run
clean.bat
(orclean.sh
for Linux) followed byGenerateProjectFiles.bat
(only for Windows).
FAQ
I have an Unreal project that is older than 4.16. How do I upgrade it?
Option 1: Just Recreate Project
If your project doesn't have any code or assets other than environment you downloaded then you can also simply recreate the project in Unreal 4.18 Editor and then copy Plugins folder from AirSim/Unreal/Plugins
.
Option 2: Modify Few Files
Unreal versions newer than Unreal 4.15 has breaking changes. So you need to modify your .Build.cs and .Target.cs which you can find in the Source
folder of your Unreal project. So what are those changes? Below is the gist of it but you should really refer to Unreal's official 4.16 transition post.
In your project's *.Target.cs
-
Change the contructor from,
public MyProjectTarget(TargetInfo Target)
topublic MyProjectTarget(TargetInfo Target) : base(Target)
-
Remove
SetupBinaries
method if you have one and instead add following line in contructor above:ExtraModuleNames.AddRange(new string[] { "MyProject" });
In your project's *.Build.cs
Change the constructor from public MyProject(TargetInfo Target)
to public MyProject(ReadOnlyTargetRules Target) : base(Target)
.
And finally...
Follow above steps to continue the upgrade. The warning box might show only "Open Copy" button. Don't click that. Instead, click on More Options which will reveal more buttons. Choose Convert-In-Place option
. Caution: Always keep backup of your project first! If you don't have anything nasty, in place conversion should go through and you are now on the new version of Unreal.