Passer au contenu principal
Version: bleeding-edge 🩸

Assets Guide

All you need to know about Assets

Assets in nanos world are all objects or content which come from Unreal Engine. For example Maps, StaticMeshes, SkeletalMeshes, Sounds, Particles, Blueprints etc are all types of Assets.

In order to use custom Assets in your servers, for example to spawn a Prop, or a custom Weapon you must have an Asset Pack. Asset Packs are a set of Assets that were exported together from Unreal.

Folder Structure

All Asset Packs go under Server/Assets/ folder. Each Asset Pack is a folder under that.

Note

Asset Packs downloaded when connecting to servers or downloaded from the vault will be stored in Server/Assets/ folder as well!

This is an example of a server Assets folder:

Server Folder
NanosWorldServer.exe
Assets/
├── my-asset-pack-01/
│ ├── MyAsset_01.uasset
│ ├── MyAsset_02.uasset
│ ├── MyBigMap.umap
│ │ ...
│ └── Assets.toml
├── awesome-weapons/
│ ├── BigFuckingGun.uasset
│ │ ...
│ └── Assets.toml
Packages/
Config.toml

Assets Pack Configuration

Asset Packs have a configuration file in the root of the Asset Pack folder, called Assets.toml, in this file we can setup all pertinent settings related to the Asset Pack:

Assets.toml
loading...

Settings Detailed

See a description of what each setting does:

SettingDescription
nameFriendly name of the Asset Pack
authorAuthor(s) of the Asset Pack
versionVersion of the Asset Pack - please refer to SemVer
imageImage URL to be displayed in the Vault
unreal_folderName of the root folder in the Unreal Project which exported this Assets. This is important so the Assets can keep the relative references correctly
assets.mapsList of Maps in this Asset Pack
assets.static_meshesList of Static Meshes in this Asset Pack
assets.skeletal_meshesList of Skeletal Meshes in this Asset Pack
assets.soundsList of Sounds in this Asset Pack
assets.animationsList of Animations in this Asset Pack
assets.particlesList of Particles in this Asset Pack
assets.materialsList of Materials in this Asset Pack
assets.blueprintsList of Blueprints in this Asset Pack
assets.othersList of other Assets in this Asset Pack

Referencing Assets in Scripting

To be able to use Assets in your code, first you have to ensure that the Asset Pack is loaded. An Asset Pack is loaded when:

  1. A map is loaded (this will make it's Asset Pack to be loaded automatically).
  2. A package with it configured in assets_requirements is loaded.
  3. It is manually set in Server's Config.toml at assets to load.

With the Asset Pack loaded, you can refer to it's assets using the following pattern:

"[ASSET_PACK_PATH]::[ASSET_KEY]"

Example:

"my-asset-pack-01::SM_Cube"

note

[ASSET_PACK_PATH] is the folder name and [ASSET_KEY] is the key defined in the Assets.toml.

Types of Assets

Some scripting methods require some specific Type of Assets to load. Attempting to load an invalid or wrong type will cause an Error. E.g.: Character:SetMesh() requires an Asset of type Skeletal Mesh.

Here's a list of all supported Asset types:

TypeDescription
MapAn Unreal Engine Map/Level
Static MeshUnreal Static Meshes can be used to load meshes for Props and StaticMeshes
Skeletal MeshUnreal Skeletal Meshes can be used to load meshes for Characters and Vehicles
SoundUnreal Sounds to load Sounds
ParticleUnreal Particles can be used for settings in several entities, including Particle Class itself
AnimationUnreal Animations can be used for settings in Character and Weapons
MaterialUnreal Materials can be used for customizing meshes surfaces and used as Post Process
BlueprintUnreal Actor Blueprints can be used for spawning Blueprint entities

Creating your own Assets

To create your own Asset Pack, please refer to Importing Custom Assets Guide.

📦 Importing Custom Assetsassets-modding/creating-assets/setting-up-ue

Pack d'Asset par défaut

nanos world provides a default Asset Pack which is already included in the base game. Please refer to the Default Asset Pack page for more information.

📦 Default Asset Packassets-modding/default-asset-pack/default-assets-list