Open 3D Engine (O3DE) is an Apache 2.0-licensed multi-platform 3D engine that enables developers and content creators to build AAA games, cinema-quality 3D worlds, and high-fidelity simulations without any fees or commercial obligations. #o3de #gameengine #engine

Mike Chang a417f5a380 Update dco.yaml to allow signoff on behalf of others (#13539) il y a 2 ans
.github a417f5a380 Update dco.yaml to allow signoff on behalf of others (#13539) il y a 2 ans
Assets 14df1e2fc5 Asset browser: move collapse button to menu il y a 2 ans
AutomatedTesting 2200f15194 Migrate tests to multitest and remove hydra dependencies (#13447) il y a 2 ans
Code 890a362816 Fix IsSubFolder not validating partial is a folder (#13518) il y a 2 ans
Gems 954bd12807 Merge pull request #13532 from aws-lumberyard-dev/atom/guthadam/material_canvas/material_compiler_options_and_status_messages il y a 2 ans
Registry fcdb2c36fd Fix for GHI-7588: Don't merge meshes with varying vertex layouts (#11082) il y a 2 ans
Templates 6068722911 Fix Gem templates to respect the `PAL_TRAIT_<gem_name>_SUPPORTED` option (#12998) il y a 2 ans
Tools 3435961dd7 Fbx test improvements for linux (#13270) il y a 2 ans
cmake bbf5b24e5d Fixed iOS when built non-monolithically. (#13503) il y a 2 ans
python 10e664f571 Update minimum CMake version to 3.22 (#12979) il y a 2 ans
scripts ed9735b040 Allow for Optional Gem annotations (#13421) il y a 2 ans
.clang-format df2f6564e5 Adapt BinPackArguments: false in .clang-format. il y a 3 ans
.editorconfig a10351f38d Initial commit il y a 4 ans
.gitattributes badbcd3eab Initial Stars Feature (#8624) il y a 3 ans
.gitignore c577d3fd65 fix gitignore (#8246) il y a 3 ans
.lfsconfig 7cda947f6e Update .lfsconfig instructions il y a 4 ans
CMakeLists.txt 10e664f571 Update minimum CMake version to 3.22 (#12979) il y a 2 ans
CMakePresets.json 442bc3dd61 Adding CMakePresets support for O3DE. (#9037) il y a 3 ans
CODE_OF_CONDUCT.md 70dc678be7 Create CODE_OF_CONDUCT.md il y a 4 ans
CONTRIBUTING.md 4b74fcf708 Updated CONTRIBUTING.md il y a 4 ans
Doxyfile_ScriptBinds a10351f38d Initial commit il y a 4 ans
LICENSE.txt 5d941ddee6 Update license references (#11031) il y a 3 ans
LICENSE_APACHE2.TXT eb0b7346c4 o3de development - update licenses (#1665) il y a 4 ans
LICENSE_MIT.TXT eb0b7346c4 o3de development - update licenses (#1665) il y a 4 ans
README.md 10e664f571 Update minimum CMake version to 3.22 (#12979) il y a 2 ans
RETIRED_CODE.md c3899c6d5c Updated retired code listing with GridMate and GridHub il y a 3 ans
SECURITY.MD 0b5cea7397 Provide initial SECURITY.md for O3DE (#8039) il y a 3 ans
SerializeContextAnalysis.bat 38261d0800 Shorten copyright headers by splitting into 2 lines (#2213) il y a 4 ans
SliceBuilderSettings.json a10351f38d Initial commit il y a 4 ans
editor.cfg 80db67e90a Remove many unused variables and unused setting files (#4607) il y a 3 ans
engine.json d3d49c2a3d Moved ScriptCanvasMultiplayer gem to be a sub-gem of Multiplayer gem (#12929) il y a 2 ans
pytest.ini edda1f862f Update pytest.ini path blacklist (#12212) il y a 2 ans
system_android_android.cfg 80db67e90a Remove many unused variables and unused setting files (#4607) il y a 3 ans
system_ios_ios.cfg 80db67e90a Remove many unused variables and unused setting files (#4607) il y a 3 ans
system_linux_pc.cfg 80db67e90a Remove many unused variables and unused setting files (#4607) il y a 3 ans
system_mac_mac.cfg 80db67e90a Remove many unused variables and unused setting files (#4607) il y a 3 ans
system_windows_pc.cfg c35f74e9ce Physics/test axis aligned box shape configuration works #7378a (#5366) il y a 3 ans

README.md

O3DE (Open 3D Engine)

O3DE (Open 3D Engine) is an open-source, real-time, multi-platform 3D engine that enables developers and content creators to build AAA games, cinema-quality 3D worlds, and high-fidelity simulations without any fees or commercial obligations.

Contribute

For information about contributing to Open 3D Engine, visit https://o3de.org/docs/contributing/.

Download and Install

This repository uses Git LFS for storing large binary files.

Verify you have Git LFS installed by running the following command to print the version number.

git lfs --version 

If Git LFS is not installed, download and run the installer from: https://git-lfs.github.com/.

Install Git LFS hooks

git lfs install

Clone the repository

git clone https://github.com/o3de/o3de.git

Building the Engine

Build requirements and redistributables

For the latest details and system requirements, refer to System Requirements in the documentation.

Windows

Optional

  • Wwise audio SDK
    • For the latest version requirements and setup instructions, refer to the Wwise Audio Engine Gem reference in the documentation.

Quick start engine setup

To set up a project-centric source engine, complete the following steps. For other build options, refer to Setting up O3DE from GitHub in the documentation.

  1. Create a writable folder to cache downloadable third-party packages. You can also use this to store other redistributable SDKs.

  2. Install the following redistributables:

    • Visual Studio and VC++ redistributable can be installed to any location.
    • CMake can be installed to any location, as long as it's available in the system path.
  3. Configure the engine source into a solution using this command line, replacing <your build path>, <your source path>, and <3rdParty package path> with the paths you've created:

    cmake -B <your build path> -S <your source path> -G "Visual Studio 16" -DLY_3RDPARTY_PATH=<3rdParty package path>
    

    Example:

    cmake -B C:\o3de\build\windows -S C:\o3de -G "Visual Studio 16" -DLY_3RDPARTY_PATH=C:\o3de-packages
    

    Note: Do not use trailing slashes for the <3rdParty package path>.

  4. Alternatively, you can do this through the CMake GUI:

    1. Start cmake-gui.exe.
    2. Select the local path of the repo under "Where is the source code".
    3. Select a path where to build binaries under "Where to build the binaries".
    4. Click Add Entry and add a cache entry for the <3rdParty package path> folder you created, using the following values:
      1. Name: LY_3RDPARTY_PATH
      2. Type: STRING
      3. Value: <3rdParty package path>
    5. Click Configure.
    6. Wait for the key values to populate. Update or add any additional fields that are needed for your project.
    7. Click Generate.
  5. Register the engine with this command:

    scripts\o3de.bat register --this-engine
    
  6. The configuration of the solution is complete. You are now ready to create a project and build the engine.

For more details on the steps above, refer to Setting up O3DE from GitHub in the documentation.

Setting up new projects and building the engine

  1. From the O3DE repo folder, set up a new project using the o3de create-project command.

    scripts\o3de.bat create-project --project-path <your new project path>
    
  2. Configure a solution for your project.

    cmake -B <your project build path> -S <your new project source path> -G "Visual Studio 16"
    

    Example:

    cmake -B C:\my-project\build\windows -S C:\my-project -G "Visual Studio 16"
    

    Note: Do not use trailing slashes for the <3rdParty cache path>.

  3. Build the project, Asset Processor, and Editor to binaries by running this command inside your project:

    cmake --build <your project build path> --target <New Project Name>.GameLauncher Editor --config profile -- /m
    

    Note: Your project name used in the build target is the same as the directory name of your project.

This will compile after some time and binaries will be available in the project build path you've specified, under bin/profile.

For a complete tutorial on project configuration, see Creating Projects Using the Command Line Interface in the documentation.

License

For terms please see the LICENSE*.TXT files at the root of this distribution.