Custom Asset Importing

From Ardenfall Wiki
Jump to navigation Jump to search

At some point you may want to import a new model, texture, sound, etc.

This can be done one of two ways - manually via scripting, or by using the built in mod asset importer feature. I suggest the latter, unless you want to do something funky.

Asset Manifest

Every mod can have an asset manifest file defined. This lists out all assets you want to import.

Create a file called manifest.txt in your mod directory.

Example Asset Manifest

{
  "assets": [
    {
      "assetId": "testmod.dog",
      "type": "texture",
      "properties": [
        {
          "name": "path",
          "value": "Assets/dog.png"
        }
      ]
    }
  ]
}

Built in Importers

There are several built in importers to load up your assets. Most of them are pretty self explanatory!

Name Description ID Properties
GLTFScene Imports a GLTF file as a GameObject. Ideal for weapons, items, simple objects.

You can define a built in material to use, and it will automatically apply said material + hook up included textures.

gltf_scene path: the path to the gltf file

shader: (optional) the shader id to import.

Texture Imports a .png or .jpeg as a Texture2D texture path: the path to the image file
AudioClip Imports a .mp3, .wav, or .ogg as an ArdenAudioClip audio_clip path: the path to the audio file
AssetBundle Imports a unity asset bundle. asset_bundle path: the path to the asset bundle file

GLTFScene

A GLTF scene / model importer. Will import the GLTF object as a gameobject.

Supports material applying using ModMaterialResolver.

Built on the GLTFFast library.

Properties

Property Required Default Description
path YES - The path to the gltf / glb file
shader NO "Ardenfall/SimpleDiffuse" Defines the shader to be imported.

Only a single shader per scene is supported at the moment.

See Common Shaders for a list of shaders to try out.

If you leave it blank, will not import any materials.

Common Shaders

SimpleDiffuse

"Ardenfall/Simple Diffuse"

The most common shader used in Ardenfall. An opaque shader that supports:

- Texture, Color, Cullmode, Cutoff

- Specularity, Fake Specularity

- Emission Texture, Emission Color, Emission Fading, Time of Day Emission

- Pivot Rotation Animation

- Vertex Wind Animation

- Fresnel

- Triplaner Texture

SimpleDiffuse Transparent

"Ardenfall/Simple Diffuse Transparent"

A version of the Simple Diffuse shader that is transparent.

EnchantableItem

"Ardenfall/Enchantable Item Diffuse"

The shader used for items that have enchanted glows. (Weapons)

CharacterSkin

"Ardenfall/Avatar/Character Skin"

The shader used for characters (humanoid skin, monsters bodies).

CharacterClothing

"Ardenfall/Avatar/Character Clothing"

The shader used for character clothing/armor.

Example: A Custom Weapon

TODO