M.pbrmetal

From TrainzOnline
(Difference between revisions)
Jump to: navigation, search
(Examples)
(Examples)
Line 112: Line 112:
  
  
[[File:chart_roughness_metallic.jpg|border|middle|x1024px]]
+
[[File:chart_roughness_metallic.jpg|border|middle|x512px]]
  
 
Example asset (route + objects) download:
 
Example asset (route + objects) download:

Revision as of 15:18, 3 January 2018

m.pbrmetal is the most basic PBR-based material type used in Trainz, and should be the default material type of choice for any mesh unless some specific feature of some other material type is required. All PBR materials are defined using a multitude of texture channels (not just a simple RGB image) which define various aspects of the material on a per-texel basis. One major advantage of this approach is that a single in-game material can be used to display various different real-world materials, rather than requiring multiple separate in-game materials with different parameters. Trainz uses a Metallic/Roughness style PBR workflow.

It should be noted that the "metal" in the name of this material refers to the physical property used in the lighting equations; it does not mean that the material is only appropriate for metallic surfaces.

This page describes content format v4.6 and assumes that the FBX file format is used as a data source for any meshes.

Contents

Texture Slots

The following texture slots are used for this material. All textures should typically have the same dimensions unless they represent a uniform color, however this is not strictly enforced.

Albedo

RGB: The albedo map defines the base color of each texel. The sRGB color space is used.

Please note that there is no alpha channel support. For the most robust result, the alpha channel should be omitted or set to 1.0 (white). Note that unlike legacy Trainz materials, PBR materials do not autodetect opacity mode based on the texture in use. The content creator must select the appropriate material for their desired outcome. Runtime texture replacement should not expect to replace an opaque texture with a blended or masked texture and have the material update automatically.

Albedo Texture Example

Pbralbedomap1.jpg

Normal

RGB: Surface normal map. This defines which way the surface is facing, relative to the interpolated vertex normals. Since this is an XYZ format rather than color data, it should never be modified in Photoshop. Using Photoshop to add a fourth channel or copy/paste smaller textures into a texture atlas is acceptable. Per-pixel manipulation or use of filters on the "RGB" channels is not acceptable.

A: Displacement height. 0.0 represents the deepest possible value, while 1.0 represents the shallowest possible value. While it is possible to paint this data in Photoshop, a linear color space must be used, and far superior results will be available through other data sources. The parallax height and the surface normal must be kept in sync, which means that a third-party tool must be used to generate the surface normal from the parallax height if you are painting this map manually.

Normal Texture Example with no Alpha Channel (Parallax)

Pbrnormalmap1.jpg


Normal Texture Example with Alpha Channel (Parallax)

Pbrnormalwithalpha.jpg

Parameter

This texture is comprised of four separate channels which each form a separate data element. Linear color space (not sRGB) is used for these channels.

Pbrparametersall.jpg


R: Emissive. This causes the texture to have an internal glow, even when no external light is present. Used for phosphors, permanently-lit markings, etc. The glow color is based on the albedo. Note that this glow does not cast light upon surrounding surfaces except via the Bloom post-processing effect.


Parameters (Emissive - Red Channel) Texture Example

Pbrparametersemissivemap1.jpg

G: Roughness. Defines whether the surface reflections are shiny (0.0) or matte (1.0). See the PBR metal workflow for details.


Parameters (Roughness - Green Channel) Texture Example

Pbrparametersroughnessmap1.jpg

B: Ambient Occlusion. Defines whether the surface is exposed to ambient lighting conditions (1.0) or affected only by direct lighting (0.0).


Parameters (Ambient Occlusion - Blue Channel) Texture Example

Pbrparametersambientocclusionmap1.jpg

A: Metallicity. Defines whether the surface is metallic (1.0) with the albedo used to colorize reflected light, or dielectric (0.0) with the albedo used to colorize the surface. While intermediate values are not physically accurate, they may be used to emulate subsurfaces which are partially metallic. See the PBR metal workflow for details.


Parameters (Metallic - Alpha Channel) Texture Example

Pbrparametersmetallicmap1.jpg

Examples

The following images show this material type with a few basic configurations of roughness and metallicity, under identical environmental conditions.

M.pbrmetal-0.png M.pbrmetal-1.png M.pbrmetal-2.png M.pbrmetal-3.png


Trainz material cast iron.jpg

Example asset download:

Trainz Material - pbrmetal (cast iron)


Trainz material gloss paint.jpg

Example asset download:

Trainz Material - pbrmetal (gloss paint)


Trainz material painted metal.jpg

Example asset download:

Trainz Material - pbrmetal (painted metal)


Trainz material rubber.jpg

Example asset download:

Trainz Material - pbrmetal (rubber)


Trainz material stainless steel.jpg

Example asset download:

Trainz Material - pbrmetal (stainless steel)


Chart roughness metallic.jpg

Example asset (route + objects) download:

PBR Roughness / Metallic Chart

3ds Max Material Configuration

Texture Assignment

Pbrmetal3dsmaxtextureassignment.jpg

Blender Material Configuration

TBD

Personal tools