Wartbed:Files/Formats

From Dark Omen Wiki

(Difference between revisions)
Jump to: navigation, search
Line 105: Line 105:
<div style="border:1px solid gray; background:rgb(215,225,215);">
<div style="border:1px solid gray; background:rgb(215,225,215);">
<div style="float:right;text-align:right;padding:0.5em;background:grey;color:rgb(225,225,225);width:25%;">''spritename''.'''sprite'''</div>
<div style="float:right;text-align:right;padding:0.5em;background:grey;color:rgb(225,225,225);width:25%;">''spritename''.'''sprite'''</div>
-
<div style="padding:1em; color:rgb(0,32,0);"><tt>'''frames.desc''' (1)<br>
+
<div style="padding:1em; ">
-
spritesheet.bmp|jpg|png<br></tt></div>
+
{| style="font-family:courier;color:rgb(0,32,0);background:rgb(215,225,215);align:left;" |
 +
|style="padding-right:8em;"|'''sprite.desc''' ||text ||(1)
 +
|-
 +
|''spritesheet''.bmp/jpg/png ||bitmap ||(2)
 +
|-
 +
|}
 +
</div>
</div>
</div>

Revision as of 10:59, 7 September 2008

Description of WARTBED file formats

Contents

Geometry

.ZIP archive with .model extension. Archive containing the following file types and extensions (can conatin any number of all file types except meshes.desc).

modelname.model
meshes.desc text (1)
filename.vertices text (2)
filename.indices text (3)
filename.bmp/jpg/png bitmap
filename.skeleton ???
filename.animation ???


Model description

1: meshes.desc
Mesh_name

{
    vertices : filename.vertices;
    indices : filename.vertices;
    offset : [x,y,z];
}

Mesh_2_name
{
    ...

}


Vertices

Space, tab, '[', ']' and ',' are all valid separators and can be exchanged for reabability. Separators should be able to follow each other (cross your fingers).

The first block is identified by the keyword "definition" (of rather, any character sequence starting with "def") and details the components are their order in a vertex. Valid tokens are "xy" for a two-float dataype, "xyz" for a three-float , "xyzw" for a four-float; and "argb", "bgra" and "rgba" for four-byte colours.

Valid field names are "position", "normal", "diffuse", "specular", "emissive" and "texture coordinate". There can be multiple fields of the same type in a vertex, however, it is not yet defined how WARTBED handles this.

The second block is identified as "vertices" (or "vtx"). Every vertex is numbered (though item identifiers are actually ignored when parsing). Multiple vertex blocks are appended into one consecutive vertex buffer (regardless of vertex numbering).

2: filename.vertices
definition

{
    xyz : position;
    xyz : normal;
    argb : diffuse;
    argb : specular;
    argb : emissive;
    xy : texture coordinates;
}

vertices
{
    0 : [1,2,3] [0,1,0] 0xFFFFFFFF, 0xF0F0F0F0, 0x10101010 [0,0];
    1 : [4,5,6] [1,0,0] 0xFFFFFFFF, 0xF0F0F0F0, 0x10101010 [1,1];

}


Indices

As for vertices. space, tab, '[', ']' and ',' are all valid separators and can be exchanged for readability, and separators should be able to follow each other.

Each faces block is created in a new index buffer, depending on parsing parameters.

3: filename.indices

textures
{
    0 : texture1.png;
    1 : texture2.jpg;
}

definition
{
    123 : indices;
    xyz : normal;
    id : texture;
}

faces
{
    0 : 1,2,3 [0,1,0] 0;
    1 : 2,3,5 [0,0,1] 1;
}

faces //requesting creation in new index buffer
{
    ...

}

Sprites

spritename.sprite
sprite.desc text (1)
spritesheet.bmp/jpg/png bitmap (2)

Map

mapname.map
map.desc (1)

placeholder line

placeholder line

Army

placeholder line

Mission

placeholder line

Personal tools
communication