This repository contains:
- A collection of O3DE Asset Gems, used in o3de-multiplayersample project
- The source folder for each Gem, for development by Contributors.
- E.g. an Asset Gem for sample characters: https://github.com/o3de/o3de-multiplayersample-assets/Gems/character_mps
- "MPS-Asset-Test" project in: o3de-multiplayersample-assets/tree/main/Project
- (Future) A
repo.json
file containing information about this O3DE Remote Gem Repository - (Future) A GitHub release folder
- The gem .zip containing the gem and associated gem.json for each gem
These gems are required for and utilized by the o3de-multiplayer sample project, you can find the repo and instructions for that project and adding these gems here:
GitHub - o3de/o3de-multiplayersample: Multiplayer sample project for the Open 3D Engine
!!! Skip to Option #2 !!!
Use of this as a remote gem repository is not yet implemented!
Add this remote repository in the Project Manager using this URL:
https://raw.githubusercontent.com/AMZN-temp-user-replace-me/o3de-remote-gem-repo-demo/main
You can then browse the gems in the Project Manager and add them to your Project.
You can clone the repo to download the repository source, then register the local gem source folders with the engine to make available for use in a Project. This entails the same steps as a developer contributing content creation or performing other maintenance of the gem data. (see the next section below.)
This repository uses Git LFS for storing large binary files. You will need to create a Github personal access token to authenticate with the LFS service.
You will need your personal access token credentials to authenticate when you clone the repository.
Create a personal access token with the 'repo' scope.
Recent versions of Git install a credential manager to store your credentials so you don't have to put in the credentials for every request. It is highly recommended you check that you have a credential manager installed and configured
You can clone the project to any folder locally, including inside the engine folder. If you clone the project inside an existing Git repository (e.g. o3de) you should add the project folder to the Git exclude file for the existing repository.ne-the-repository)
# clone the project into a folder outside your engine repository folder
> git clone https://github.com/o3de/o3de-multiplayersample-assets.git
Cloning into 'o3de-multiplayersample-assets'...
# clone the project into a folder named 'o3de-multiplayersample' in your existing engine repository folder
> git clone https://github.com/o3de/o3de-multiplayersample-assets.git c:/path/to/o3de/o3de-multiplayersample-assets
Cloning into 'o3de-multiplayersample'...
# modify the local engine git exclude file to ignore the project folder
> echo o3de-multiplayersample-assets > c:/path/to/o3de/.git/info/exclude
If you have a Git credential helper configured, you should not be prompted for your credentials anymore.
You may have already done this, these are the same steps as setting up the o3de-multiplayer sample project. But if you are adding them to your own project these are the steps to do so.
Make sure your engine is registered.
:: register the gems with the engine, you only need to do this once
> C:\path\to\o3de\scripts\o3de register --this-engine
Make sure your project is registered.
:: register the project with the engine, you only need to do this once
> C:\path\to\o3de\scripts\o3de register -p C:\path\to\o3de-multiplayersample
Now make sure that the source gems are registered
:: register the gems with the engine, you only need to do this once
> o3de register --all-gems-path C:\path\to\o3de-multiplayersample-assets\Gems
The above command will recursively scan the input path, then registers all paths with gem.json files into the ~/.o3de/o3de_manifest.json
Now these Gems will be available in the Project Manager and can be added to your Project.
This repository contains it's own O3DE Game project, which can be used by contributors to build, validate, and maintain new assets independently.
# the test project for mps assets, is in this project folder in repo
> cd C:\path\to\o3de-multiplayersample-assets\Project
-
Launch your O3DE Project Manager (o3de.exe)
-
Use the blue button in the upper right labeled "New Project ...", and with the pulldown select "Open Existing Project"
-
Browse to and add the MPS Asset Test Project folder:
C:\path\to\repo\o3de-multiplayersample-assets\Project
-
You may be prompted to rebuild the project (there are other options for building as a developer)
-
Launch the Editor for the project
You can use the o3de cli tools to register your project with your engine.
# change directory to the engine root folder
> cd C:\path\to\your\o3de-engine
# register the gems with the engine, you only need to do this once
> scripts\o3de register --project-path C:\depot\o3de-multiplayersample-assets\Project
There are a number of ways to configure and build the engine and project ...
Configure and Build - Open 3D Engine
As a developer, I often find it useful to build in an engine-centric way
# change directory to the engine root folder
> cd C:\path\to\your\o3de-engine
# create a build folder
> mkdir build
> cd build
# configure cmake and create solution
> cmake .. -G "Visual Studio 16" -A x64 -DLY_3RDPARTY_PATH="%LY_3RDPARTY_PATH%" -DLY_UNITY_BUILD=OFF -DLY_PROJECTS="C:\path\to\repo\o3de-multiplayersample-assets\Project"
This should generate a build\O3DE.sln
file, which can be opened in Visual Studio 2019 and compiled.
Don't forget to build the project in Profile
Building the Editor project will build with all dependencies.
The built binary executables will be in:
# bin folder
> cd C:\path\to\your\o3de-engine\build\bin\profile\
# executables
# C:\path\to\your\o3de-engine\build\bin\profile\o3de.exe
# C:\path\to\your\o3de-engine\build\bin\profile\editor.exe
# ...
If this is the project you are primarily working with, you can also set it as the "default project".
# change directory to the engine root folder
> cd C:\path\to\your\o3de-engine
# register the gems with the engine, you only need to do this once
> scripts\o3de set-global-project -pp <project-path>
This will make this the project that launches by default if you manually directly double-click on a o3de executable like editor.exe
After following all the steps above, you should be ready to start working. Once you are in the Editor, you can develop assets to be committed to the asset repo. Working with the o3de-multiplayersample-assets repo is a similar workflow to the o3de codebase, the general git contributor guide is here for reference: https://docs.o3de.org/docs/contributing/to-code/git-workflow/
The main O3DE contributor guide is here: https://www.o3de.org/contribute/#contribution-guidelines
And the CONTRIBUTING guide for this asset repo has addtional information regarding best practices for developing and cotributing assets such as 3D models, texture images and materials, characters and animations, etc.: https://github.com/o3de/o3de-multiplayersample-assets/blob/main/CONTRIBUTING.md
The following steps help you validate you are set up correctly and get working to contribute changes.
After the Asset Processor (https://www.o3de.org/docs/user-guide/assets/asset-processor/interface/) and Editor have started, the first suggestion would be to validate that the Gems are active and processing. This is an important troubleshooting step if you actually are having asset issues, like them not showing up in the editor.
- In the Windows task-bar tray, there should be an icon for the O3DE Asset Processor
- To view the Asset Processor interface, right-click the Asset Processor icon in the system tray and select Show.
- Click on the Assets tab
- The Project: path should be visible, something like:
C:\path\to\repo\o3de-multiplayersample-assets\Project
- The Root: is the path to the active engine install
- The o3de-multiplayersample-assets\Gems should be visible:
This is a collection of modular Asset Gems used in o3de-multiplayersample game, but you can develop and contribute assets simply using the MPS Asset Test project. You simply need to place your assets into the appropriate Gem.
- Asset Gems have an Assets/ folder, this is the default location within the gem folder structure that the AP scans for assets to process and make game ready.
- From the AP, you can get to the folder by ...
- Selecting the gem, such as ‘character_mps’
- Right-click, from the context menu select ‘Open in Explorer’
- Or you can manually browse to them on disk in Windows File Explorer
- Examples:
C:\path\to\repo\o3de-multiplayersample-assets\Gems\kb3d_mps\Assets
C:\path\to\repo\o3de-multiplayersample-assets\Gems\character_mps\Assets
...
- Examples:
- Organize your files into the \Assets folder. We prefer one-folder per-asset, such as:
Gems\character_mps\Assets\MyCharacter\
Gems\character_mps\Assets\MyCharacter\mycharacter.fbx
Gems\character_mps\Assets\MyCharacter\mycharacter.material
Gems\character_mps\Assets\MyCharacter\textures
Gems\character_mps\Assets\MyCharacter\textures\mycharacter_basecolor.png
Gems\character_mps\Assets\MyCharacter\textures\mycharacter_roughness.png
...
- As you add asset files to the Gem folder, the AP will scan and process them (into runtime ready assets); so they will show up in your Game Project data in the Editor
The folder structure for each asset gem is retained and accessible in the Editor as well.
Switch to the branch you want to use as a base (e.g. create a feature branch off of development):
git switch development
Pull the branch state:
git pull
Create a new branch from that state:
git switch -c <user/branch_name>
Make changes (like adding new asset files) and commit these locally
This will display files that have changes:
git status
This action will stage your work:
git add <filename_or_directory>
This action will commit the new work:
git commit -s -m "<description of your change>"
Push changes to the origin. This is required to share your changes, run Automated Reviews, and submit Pull Requests.
Use the following to push the commits in your current branch to origin. -u will set the branch to track the origin repo. Only required one time:
git push -u origin HEAD
After using -u, the next time, you can just run a simple push for that branch:
git push
You’ll want to submit a Pull Request and get 2 reviewers before you merge your changes to the public repo.
- Go to: https://github.com/o3de/o3de-multiplayersample-assets
- Click New Pull Request
- Click compare and select your branch.
- Base branch: development
- Compare: <user/branch_name>
- Click Create pull request
Note: If you are comparing across forks (if you made one), the workflow will be slightly different. If you have any trouble, let us know so we can help.
Configuring your PR should look something like:
Add the necessary details to the PR
- Enter title and description
- Add reviewers: assign to GitHub users or teams
- Get reviews and approvals needed
- Then merge your PR
Notes:
- Get a few distinctly different people to review your PR, this repo only requires 2 approvals to merge, but it’s not a bad idea to get others to not only look at the changes but also try the asset changes themselves.
- This repo is not set up with AR, so make sure your changes work before merging to development, or from development to main.
- Test your changes, you don’t need to test them in MultiplayerSample (game)
- You can use the MPS Asset Test Project folder:
C:\path\to\repo\o3de-multiplayersample-assets\Project
- Or, you can activate these asset gems into your own test project...
- You can use the MPS Asset Test Project folder:
After the gems are registered and added to a project, you can validate they are operational via the Asset Processor
How these Asset Gems were made with O3DE.
-
The Gems were created from the Asset Gem template
-
Then the
gem.json
(metadata) was manually updated per-gem in a text editor to customize the information to display when browsing and viewing the Gems from the O3DE project manager.
cd c:\path\to\o3de\
scripts\o3de create-gem --gem-path C:\o3de-multiplayersample-assets\Gems\props_mps --template-path C:\o3de\Templates\AssetGem
scripts\o3de create-gem --gem-path C:\o3de-multiplayersample-assets\Gems\level_art_mps --template-path C:\o3de\Templates\AssetGem
scripts\o3de create-gem --gem-path C:\o3de-multiplayersample-assets\Gems\character_mps --template-path C:\o3de\Templates\AssetGem
scripts\o3de create-gem --gem-path C:\o3de-multiplayersample-assets\Gems\landscape_mps --template-path C:\o3de\Templates\AssetGem
scripts\o3de create-gem --gem-path C:\o3de-multiplayersample-assets\Gems\pbr_material_pack_mps --template-path C:\o3de\Templates\AssetGem
scripts\o3de create-gem --gem-path C:\o3de-multiplayersample-assets\Gems\particlefx_mps --template-path C:\o3de\Templates\AssetGem
scripts\o3de create-gem --gem-path C:\o3de-multiplayersample-assets\Gems\kb3d_mps --template-path C:\o3de\Templates\AssetGem