2012-02-08 22:56:50 +00:00
|
|
|
README.materials
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
This README describes the materials.xml file format. It is targeted at those
|
2012-02-08 22:56:50 +00:00
|
|
|
wanting to change the appearance of the scenery in FlightGear.
|
|
|
|
|
2019-06-07 13:49:02 +01:00
|
|
|
The materials file used by FlightGear is set in the /sim/rendering/materials-files
|
|
|
|
property. It is read on startup, and can be reloaded in-sim from the
|
|
|
|
"Reload Materials" item in the Debug menu.
|
2012-02-08 22:56:50 +00:00
|
|
|
|
2019-06-07 13:49:02 +01:00
|
|
|
The materials file consists of one or more <region> elements. Each <region>
|
|
|
|
contains one or more geographical <area> elements, defining a rectangle
|
|
|
|
(lat1/lon1, lat2/lon2), and a set of <material> elements which describes a
|
|
|
|
single visually distinct terrain material in the FG world which will be used to
|
|
|
|
render one of more scenery landclasses (for example Grass or Town). When determining
|
|
|
|
the material to use for a given landclass at a given lat/lon, the <region> elements
|
|
|
|
are checked in order and the <condition> element of the materials evaluated. The
|
|
|
|
_last_ matching material definition is used. So more specific regions and materials
|
|
|
|
definitions should be put towards the bottom of the materials file.
|
2012-02-08 22:56:50 +00:00
|
|
|
|
|
|
|
The rest of this document describes the children tags of the <material> entry.
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
name : Scenery type names that map to this material. These are typically taken
|
2012-02-08 22:56:50 +00:00
|
|
|
from landclass definitions created by TerraGear. Multiple scenery types
|
|
|
|
may map to a single material. This is recommended to minimize texture
|
|
|
|
memory usage.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2012-02-08 22:56:50 +00:00
|
|
|
condition : A condition statement used to activate the material. Note that this
|
|
|
|
if evaluated once at start-up.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
texture : A relative path to an SGI RGB, PNG or DDS file containing a texture
|
2012-02-08 22:56:50 +00:00
|
|
|
for the material. RGB and PNG are recommended for platform compatibility.
|
|
|
|
You may define more than one <texture> element, in which case the scenery
|
2013-06-20 23:02:17 +01:00
|
|
|
loader will choose one texture for each contiguous set of scenery
|
2012-02-08 22:56:50 +00:00
|
|
|
triangles.
|
|
|
|
|
|
|
|
texture-set : If using an effect (see below), it may be necessary to define more
|
|
|
|
than one texture. The texture-set element has multiple <texture> element
|
2013-06-20 23:02:17 +01:00
|
|
|
children which may then be referenced by the effect. You may define more
|
|
|
|
than one <texture-set> element, in which case the scenery loader will
|
2012-02-08 22:56:50 +00:00
|
|
|
choose one texture for each contiguous set of scenery triangles.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
object-mask : An optional bitmap file used to control random placement of lights,
|
2012-02-08 22:56:50 +00:00
|
|
|
buildings and vegetation on the terrain. The green channel mask is used
|
|
|
|
for random vegetation placement, the blue channel for buildings and lights.
|
|
|
|
and the red channel controls the rotation of buildings (0.0 is North, 0.5
|
2013-06-20 23:02:17 +01:00
|
|
|
is South). Fractional colour values can be used to give a probability of
|
2012-02-08 22:56:50 +00:00
|
|
|
placement. Multiple object-masks may be defined to match up with <texture>
|
|
|
|
or <texture-set> elements.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
effect : The effect to be used for this material. (default:
|
2012-02-08 22:56:50 +00:00
|
|
|
Effects/terrain-default)
|
|
|
|
|
|
|
|
ambient, diffuse, specular, emissive, and shininess are copied into the
|
|
|
|
parameter section of the effect created for this material.
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
parameters : Additional parameters to be used in the effect. See README.effects
|
|
|
|
for format information.
|
2012-08-01 21:08:42 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
wrapu : True if the texture should repeat horizontally over a surface, false if
|
2012-02-08 22:56:50 +00:00
|
|
|
it should not repeat (default: true).
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
wrapv : True if the texture should repeat vertically over a surface, false if
|
2012-02-08 22:56:50 +00:00
|
|
|
it should not repeat (default: true).
|
|
|
|
|
|
|
|
mipmap : True if the texture should be mipmapped, false otherwise. (default: true).
|
|
|
|
|
|
|
|
xsize : The horizontal size of a single texture repetition, in meters.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2012-02-08 22:56:50 +00:00
|
|
|
ysize : the vertical size of a single texture repetition, in meters
|
|
|
|
|
|
|
|
light-coverage : The coverage of a single point of light in m^2. 0 indicates no
|
|
|
|
lights at all. Minimum value is 1000m^2. May be masked by the blue channel
|
|
|
|
of an object-mask. Lights are all generated 3m above the surface, and
|
|
|
|
have random colour (50% yellow, 35% white, 10% orange, 5% red)
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
ambient : The ambient light colour for the material, specified as separate
|
2012-02-08 22:56:50 +00:00
|
|
|
r, g, b, a components (default: all color components 0.2, alpha 1.0).
|
|
|
|
|
|
|
|
diffuse : The diffuse light colour for the material, specified as separate
|
|
|
|
r, g, b, a components (default: all color components 0.8, alpha 1.0).
|
|
|
|
|
|
|
|
specular : The specular light colour for the material, specified as separate
|
|
|
|
r, g, b, a components (default: all color components 0.0, alpha 1.0).
|
|
|
|
|
|
|
|
emissive : The emissive light colour for the material, specified as separate
|
|
|
|
r, g, b, a components (default: all color components 0.0, alpha 1.0).
|
|
|
|
|
|
|
|
solid : Whether the surface is solid from an FDM perspective. If it is not
|
|
|
|
solid, it is assumed that the material models a fluid (water) surface.
|
|
|
|
(default: true).
|
|
|
|
|
|
|
|
friction-factor : The friction factor for that material. The normalized
|
|
|
|
factor can be used by a FDM to post-multiply all contact friction forces
|
2013-06-20 23:02:17 +01:00
|
|
|
with that factor. That is the more slippery a material is the smaller
|
|
|
|
this value should be. (default: 1.0 for Dry concrete/Asphalt).
|
2012-02-08 22:56:50 +00:00
|
|
|
|
|
|
|
rolling-friction : the gear rolling rolling-friction coefficient for this
|
|
|
|
particular material. (default: 0.02 for Dry concrete/Asphalt).
|
|
|
|
|
|
|
|
bumpiness : normalized bumpiness factor for this particular terrain.
|
|
|
|
(default: 0.0 for a smooth surface).
|
|
|
|
|
|
|
|
load-resistance : a pressure value how much force per surface area this
|
|
|
|
surface can carry without deformation. The value should be in N/m^2
|
|
|
|
(default: 1e30).
|
|
|
|
|
|
|
|
glyph : group that defines one letter/digit/symbol in a font texture
|
|
|
|
sub-entries: name, left (default: 0.0), right (default: 1.0)
|
|
|
|
(left and right describe the horizontal position in the texture.)
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
wood-coverage : The coverage of trees in areas marked as woodland in
|
|
|
|
m^2. A lower number means a higher density of trees. A value of
|
2012-02-08 22:56:50 +00:00
|
|
|
0 indicates no woods. May be masked by the green channel of an
|
|
|
|
object-mask. (default: 0)
|
|
|
|
|
|
|
|
tree-range-m : The range at which trees become visible. Note that this
|
|
|
|
is not absolute, as trees are loaded in blocks. A lower number means
|
|
|
|
trees will not become visible until you are closer.
|
|
|
|
|
2013-04-20 21:09:03 +01:00
|
|
|
tree-texture : A texture to use for the trees. Typically this will contain around
|
|
|
|
8 different trees in a row, duplicate 4 times. From bottom to top, the
|
|
|
|
rows contain
|
|
|
|
* summer textures
|
2013-05-19 21:45:42 +01:00
|
|
|
* summer snow texture
|
2013-04-20 21:09:03 +01:00
|
|
|
* winter texture
|
|
|
|
* winter snow texture
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2013-05-19 21:45:42 +01:00
|
|
|
Each tree must have space at the top. For a 512x512 texture sheet, this
|
2013-06-20 23:02:17 +01:00
|
|
|
should be 8 pixels. Otherwise subsequent rendering results in "top hats"
|
|
|
|
above trees in the distance where the trunk of the tree above in the
|
|
|
|
textures sheet bleeds downwards when the mipmaps are generated.
|
2012-02-08 22:56:50 +00:00
|
|
|
|
|
|
|
tree-varieties : The number of different trees defined in the tree-texture
|
|
|
|
horizontally. (default: 1)
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
tree-height-m : The average height of the trees. Actual tree height will
|
2012-02-08 22:56:50 +00:00
|
|
|
vary by +/- 50%. (default: 0)
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
tree-width-m : The average width of the tree cover. Actual tree width will
|
2012-02-08 22:56:50 +00:00
|
|
|
vary by +/- 50%. (default 0)
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2012-10-05 22:00:51 +01:00
|
|
|
tree-max-density-angle-deg : The slope angle at which trees begin to thin out
|
2013-06-20 23:02:17 +01:00
|
|
|
as the slope is too steep to support the full coverage. Shallower
|
2012-10-05 22:00:51 +01:00
|
|
|
slopes have maximum wood-coverage. Steeper slopes have fewer trees.
|
|
|
|
(default : 45)
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
tree-zero-density-angle-deg : The angle at which the slope is too steep to
|
|
|
|
support significant vegetation. Steeper slopes have no trees.
|
2012-10-05 22:00:51 +01:00
|
|
|
(default : 60)
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
object-max-density-angle-deg : The angle at which objects and buildings become
|
2012-10-05 22:00:51 +01:00
|
|
|
less dense due to a steep slope. (default : 20)
|
|
|
|
|
|
|
|
object-zero-density-angle-deg : The angle at which the slope is too steep to build
|
|
|
|
on. No object/buildings will be placed on slopes steeper than this.
|
|
|
|
(default : 30)
|
2012-02-08 22:56:50 +00:00
|
|
|
|
|
|
|
object-group : A group of random objects to be placed on the surface. Contains
|
2012-10-05 22:00:51 +01:00
|
|
|
<range-m> and one or more <object> children.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
range-m : The distance at which objects within this object-group become
|
2012-02-08 22:56:50 +00:00
|
|
|
visible. Note that for realism, 60% of the objects will become visible
|
2013-06-20 23:02:17 +01:00
|
|
|
at <range-m>, 30% at 1.5*<range-m>, and 10% at 2*<range-m>.
|
2012-02-08 22:56:50 +00:00
|
|
|
(default: 2000)
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2012-02-08 22:56:50 +00:00
|
|
|
object : A set of random objects to be placed. Contains <coverage-m2>, <path>
|
|
|
|
and <heading> children.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2012-02-08 22:56:50 +00:00
|
|
|
coverage-m2 : The coverage of a single object in m2. Lower values mean a higher
|
|
|
|
density. Minimum value is 1000.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2012-02-08 22:56:50 +00:00
|
|
|
spacing-m : The minimum space between this object and any other on the surface in
|
|
|
|
meters. This helps to avoid objects being placed ontop of each other.
|
|
|
|
(default 20)
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
path : Path relative to FG_ROOT to a model definition, usually .ac or .xml file.
|
2012-02-08 22:56:50 +00:00
|
|
|
More than one <path> may be included within the <object> tag, in which
|
|
|
|
case a single <path> is chosen at random for each individual object
|
|
|
|
placement.
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
heading-type : Indicator of how the heading of the random objects should be
|
|
|
|
determined. Valid values are:
|
2012-02-08 22:56:50 +00:00
|
|
|
fixed - Objects all point North. Default.
|
|
|
|
random - Objects are assigned an individual random heading
|
|
|
|
mask - Rotation is taken from the red channel of the object-mask
|
|
|
|
billboard - Object is always rotated to face camera - expensive
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
|
2012-04-24 21:55:37 +01:00
|
|
|
Random Buildings
|
|
|
|
================
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
Random Buildings come in three sizes, with individual constraints.
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
Small buildings. These have different textures on the sides compared to the front
|
|
|
|
and back. Small buildings are never deeper than they are wide.
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2012-05-04 21:14:23 +01:00
|
|
|
Medium buildings, which are never taller than they are wide.
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2012-05-04 21:14:23 +01:00
|
|
|
Large buildings. There are no constraints on their width, depth or height.
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
building-coverage : The coverage of random buildings in areas marked for random
|
|
|
|
objects in m^2. A lower number means a higher density of buildings. A
|
|
|
|
value of 0 indicates no buildings. May be masked by the blue channel of an
|
|
|
|
object-mask. (default: 0)
|
|
|
|
|
2012-04-24 21:55:37 +01:00
|
|
|
building-spacing-m : The minimum spacing between random buildings and other buildings
|
2013-06-20 23:02:17 +01:00
|
|
|
or random objects. This helps avoid objects being placed on top of each
|
|
|
|
other. (default: 5)
|
|
|
|
|
2012-04-24 21:55:37 +01:00
|
|
|
building-small-ratio: Ratio of small buildings. These buildings are 1-3 stories
|
|
|
|
in height, and may have a pitched roof. Fraction of small buildings is
|
|
|
|
(<building-ratio-small> / (<building-ratio-small> + <building-ratio-medium>
|
|
|
|
+ <building-ratio-large>). (default: 0.8)
|
2013-06-20 23:02:17 +01:00
|
|
|
|
|
|
|
building-medium-ratio : Ratio of medium buildings. These buildings are 3-6 stories
|
|
|
|
in height, and have a flat roof. (default: 0.15)
|
|
|
|
|
|
|
|
building-large-ratio : Ratio of large buildings. These buildings are 5-10 stories in
|
2012-04-24 21:55:37 +01:00
|
|
|
height, and have a flat roof. (default 0.05)
|
2013-06-20 23:02:17 +01:00
|
|
|
|
2012-04-24 21:55:37 +01:00
|
|
|
building-small-pitch : Fraction of small buildings with pitched roofs. (default 0.8)
|
|
|
|
building-medium-pitch : Fraction of small buildings with pitched roofs. (default 0.2)
|
|
|
|
building-large-pitch : Fraction of small buildings with pitched roofs. (default 0.1)
|
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-small-min-floors : Min. number of floors for a small building. (default 1)
|
|
|
|
building-small-max-floors : Max. number of floors for a small building. (default 3)
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-medium-min-floors : Min. number of floors for a medium building. (default 3)
|
|
|
|
building-medium-max-floors : Max. number of floors for a medium building. (default 8)
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-large-min-floors : Min. number of floors for a medium building. (default 5)
|
|
|
|
building-large-max-floors : Max. number of floors for a medium building. (default 20)
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-small-min-width-m : Min. width of small buildings. (default 15)
|
|
|
|
building-small-max-width-m : Max. width of small buildings. (default 60)
|
|
|
|
building-small-min-depth-m : Min. depth of small buildings. (default 10)
|
|
|
|
building-small-max-depth-m : Max. depth of small buildings. (default 20)
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-medium-min-width-m : Min. width of medium buildings. (default 25)
|
|
|
|
building-medium-max-width-m : Max. width of medium buildings. (default 50)
|
|
|
|
building-medium-min-depth-m : Min. depth of medium buildings. (default 20)
|
|
|
|
building-medium-max-depth-m : Max. depth of medium buildings. (default 50)
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-large-min-width-m : Min. width of large buildings. (default 50)
|
|
|
|
building-large-max-width-m : Max. width of large buildings. (default 75)
|
|
|
|
building-large-min-depth-m : Min. depth of large buildings. (default 50)
|
|
|
|
building-large-max-depth-m : Max. depth of large buildings. (default 75)
|
2012-04-24 21:55:37 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-texture : The texture used for all buildings. See Docs/buildings.png for
|
|
|
|
details. (default Texture/buildings.png)
|
2012-05-04 21:14:23 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-lightmap: Emissive texture for all buildings, which is faded in at night to
|
|
|
|
provide illusion of lit windows. Same texture coordinates and
|
|
|
|
format at building-texture above.
|
2013-04-20 21:09:03 +01:00
|
|
|
|
2013-06-20 23:02:17 +01:00
|
|
|
building-range-m: Range at which all buildings are visible. Beyond this point fewer
|
|
|
|
and fewer buildings are rendered, with no buildings rendered at
|
|
|
|
2*building-range-m (default 10000)
|