Item Definition
IDE Sections:
|
Item definition files, usually identified by the file extension .ide
, are used to declare many different aspects for the map system or to specify special behaviour rules for one of the aspects. They are stored in plain text format, so that they can be opened by any text editing program (like Notepad), but there are also some tools to simplify editing.
Contents
Overview
The item definition files are split up into several sections. There is no order on how you arrange the sections and sections do not need to appear in the file.
Format and syntax description
Line comments are indicated by the character #
(number sign) and empty lines are allowed. They can be placed anywhere in the file. The game reads up to a maximum of 256 characters for each line and ignores the rest if the line is longer. Each section starts with a section identifier (usually four characters long, e.g. objs
, tobj
, etc.) indicating how the content of the section gets interpreted by the game. The identifier is followed by the definition entries. Each entry takes one line and every line follows a specific format which are described in the articles handling the sections in detail (see below). The end of any section is indicated by the terminating string end
. Both the section identifier and terminating string are case sensitive. Lines within sections are always formatted in the same way differing only in the number of parameters describing the semantical content of the line. Data are usually separated by the character ,
(comma) but can be separated by
(space). Tabs and spaces anywhere in the beginning of the line, between data, or after the data are omitted by the game and can be used to improve readability for human eyes. The games' parser uses an invariant culture to parse numerical values and strings, which means strings are ASCII encrypted and the decimal separator is .
(period).
Example
# line comment objs # default style in objs section 200, ind_land101, pjs, 1, 127, 0 # valid style 200 ind_land101 pjs 1 127 0 end
Sections
The following table contains all known sections in the item definition. The supported games column lists games that support the sections but it doesn't necessarily means they're functional in the games. Mouse over the game icons to see if the games are functional.
Identifier | Supported games | Description |
---|---|---|
OBJS | Most important section: defines objects for the map. These objects can be placed into the world through the INST section of the item placement files. | |
TOBJ | Functions similarly to OBJS but has two additional parameters defining the ingame time range the object can get rendered. These objects can be placed into the world through the INST section of the item placement files. | |
HIER | Used to define objects for use in cutscenes. | |
CARS | Used to define vehicles. | |
PEDS | Used to define pedestrians (random NPC's). | |
PATH | Used to create waypoints for random NPC spawns (Paths). | |
2DFX | Used to add particle effects and simple ped behaviors to defined objects. | |
WEAP | Used to define weapons. | |
ANIM | Functions similarly to OBJS, but it has one additional parameter indicating an IFP or WAD animation file to assign an animation to the object. These objects are placed through the INST section of the item placement files. | |
TXDP | Used to virtually extend texture dictionaries. | |
TANM | Used to combine TOBJ and ANIM sections. Those objects get placed inside the INST section of the WPL. | |
TREE | – | |
VNOD | – | |
LINK | – | |
MLO | Used to create interiors. This section does also contain information about portals (previous ENEX connections) and dimensions of the interior which influences certain aspects, like the weather, for example. All objects are placed relative to an offset placed using MLO+ inside the IPL or WPL file. | |
AMAT | This is Audio Materials. Possible Used to make a sound effect at the model. Usually used for dynamic objects. | |
LODM | – | |
AGRPS | – | |
HAND | VC Xbox/Mobile | – |
IDE Flags
Flags are used in order to specify the behaviour of objects. They are interpreted as signed 32-bit integer values where each bit describes a boolean value of a different aspect. The following table shows the standard flags used for objects defined in OBJS, TOBJ and ANIM section.
Flags are used to specify the behaviour of objects. They are signed 32-bit integer values where each bit describes a boolean value of an special aspect.
Flag | Supported games | Binary | Description |
---|---|---|---|
-1 | – | 1111 1111 1111 1111 1111 1111 |
Enables all flags.[a] Never used by default. |
1 | 0000 0000 0000 0000 0000 0001 |
Wet effect (objects appear darker). | |
2 | 0000 0000 0000 0000 0000 0010 |
Do not fade the object when it is being loaded into or out of view. | |
4 | 0000 0000 0000 0000 0000 0100 |
Allow transparencies of other objects to be visible through this object. | |
8 | 0000 0000 0000 0000 0000 1000 |
Alpha transparency 2 | |
16 | 0000 0000 0000 0000 0001 0000 |
Opposite to flag 2 | |
32 | 0000 0000 0000 0000 0010 0000 |
Indicates an object to be used inside an interior. | |
64 | 0000 0000 0000 0000 0100 0000 |
Disables the shadow mesh to project a shadow; allow transparencies of other objects, shadows, and lights to be visible through this object. | |
128 | 0000 0000 0000 0000 1000 0000 |
Object surface will not be culled. | |
256 | 0000 0000 0000 0001 0000 0000 |
Disables draw distance (Only used for LOD objects with an LOD value greater than 299). | |
512 | 0000 0000 0000 0010 0000 0000 |
Object is breakable (like glass – additional parameters defined inside the object.dat file, otherwise there is no effect). | |
1024 | 0000 0000 0000 0100 0000 0000 |
Similar to flag 512: object first cracks on a strong collision, then it breaks (does also require object.dat registration). | |
2048 | 0000 0000 0000 1000 0000 0000 |
Indicates an object as an garage door (for more information see GRGE – requires object.dat registration). | |
4096 | 0000 0000 0001 0000 0000 0000 |
Indicates a multi mesh object (Object switches from mesh 2 to mesh 1 after collision – requires object.dat registration). | |
16384 | 0000 0000 0100 0000 0000 0000 |
Indicates a vegetation object (Object moves in wind). | |
32768 | 0000 0000 1000 0000 0000 0000 |
Uses object brightness from the current weather definition (See timecyc.dat – PoleShd). | |
65536 | 0000 0001 0000 0000 0000 0000 |
Object explodes after getting hit (requires object.dat registration). | |
131072 | 0000 0010 0000 0000 0000 0000 |
Unknown – apparently some flag for the Script. | |
262144 | 0000 0100 0000 0000 0000 0000 |
Unknown – only used 1 time in San Andreas. | |
1048576 | 0000 1000 0000 0000 0000 0000 |
Object will switch from mesh 2 to mesh 1 after getting sprayed by the player (graffity flag). | |
2097152 | 0001 0000 0000 0000 0000 0000 |
Disables backface culling – as an result the texture will be drawed on both sides of the model (Always enabled for GTA III and Vice City) | |
4194304 | 0010 0000 0000 0000 0000 0000 |
Unknown – apparently related into physics. | |
edit |
GTA III
Bits | Dec | Hex | Name | Description | Examples |
---|---|---|---|---|---|
0 | 1 | 0x01 | NORMAL_CULL | Cull model if player doesn't look at it. Ignored in GTA 3. | Fences |
1 | 2[1] | 0x02 | DO_NOT_FADE | Do not fade the object when it is being loaded into or out of view. | Some lampposts |
2 | 4[1] | 0x04 | DRAW_LAST | Model is transparent. Render this object after all opaque objects, allowing transparencies of other objects to be visible through this object. | Trees |
3 | 8 | 0x08 | ADDITIVE | Render with additive blending. Previous flag must be enabled too. | |
4 | 16[1] | 0x10 | IS_SUBWAY | Model is a tunnel, i.e. set the object as invisible unless the player enters cull zone flag 128. This flag works only with static models. | Tunnels, some dynamic objects |
5 | 32 | 0x20 | IGNORE_LIGHTING | Don't use static lighting, we want dynamic if it's possible. | Some lampposts and trafficlights |
6 | 64[1] | 0x40 | NO_ZBUFFER_WRITE | Model is a shadow. Disable writing to z-buffer when rendering it, allowing transparencies of other objects, shadows, and lights to be visible through this object. Not implemented in the PS2 version. | Shadow |
GTA Vice City
Bits | Dec | Hex | Name | Description | Examples |
---|---|---|---|---|---|
0 | 1 | 0x01 | IS_ROAD | Identifies objects to draw "wet reflections" on them. | Roads |
1 - 6 | 2 - 64 | 0x02 - 0x40 | - | Same as in GTA 3. | - |
7 | 128 | 0x80 | DONT_RECEIVE_SHADOWS | Do not draw shadows on this object | |
8 | 256 | 0x100 | IGNORE_DRAW_DISTANCE | Ignore draw distance for this object (sets its "level" (island id) to 0). | |
9 - 10 | 512, 1024 | 0x200, 0x400 | GLASS_TYPE | Breakable glass type : 1 - glass object changes its textures when breaking; 2 - glass object doesn't change its textures when breaking |
For flags defining different aspects of different definitions read the articles about their sections.
Difference between GTA III and GTA IV engines
GTA IV not only uses different formats to the previous games, it also does not use IDs to identify objects anymore. While GTA III era games use an ID as an index inside an array of definitions, GTA IV uses the hashes of the model name as a key inside a hash table. For more information about this see Map System.
Tools
- KEd – By JernejL
- MEd – By Tonywob
- GTAGarage: IDEditor – By Xmen
- GTAForums: IDE-IV in GTA-IV script centre – by Gforce
- FlagValue Calculator – By Aschratt - Calculates all flagvalues (even those unknown).
See also
References
- ^ GTAForums: Screenshots of flags in GTA III
External links
- GTAForums: GTAVC IDE Definitions - topic by ODIE covering specific details of IDE files in GTA VC
- GTAForums: GTA3/VC Map File Documentation and Troubleshooting - topic by Opius covering general features of IDE files in GTA3 and GTA VC
- ID Flagvalue Decoding Project - project to decode all missing flag values
Grand Theft Auto V | |
---|---|
File Formats | .awc • .dat • .gfx • .gxt2 • .ide • .meta/.ymt/.xml • .mrf • .patch • .rpf • .ybn/.ybd • .ycd • .ydd • .ydr • .yed • .yfd • .yft • .yld • .ymap • .ymf • .ynd • .ynv • .ypdb • .ysc • .ytd • .ytyp • .yvr |
Documentation | Bink Video • Native functions • Weather types |
Tools | OpenIV • GIMS Evo • CodeWalker |
Multiplayer | GTAForums: GTA Online |
Useful links | Community portal • Discussion forums • GTA V Modding Forum • GTA5-Mods • Native Functions Database (alloc8or) |
Grand Theft Auto IV | |
---|---|
File Formats | .dat • .gxt • .ide • .img • .ipl • .nod • .sco • .rpf • .rrr • .wad • .wbd/.wbn • .wdd • .wdr • .wft • .whm • .wpl • .wtd |
Documentation | Audio • Bink Video • Cryptography • Cutscenes • GXT Text • Image listing • Keycodes • Map Listing • Native functions • Paths • Radar Blips • Radio Stations • Saves • Scenarios • VTable • Weapons |
Tools | ASI Loader • ENBSeries • G-Texture • GIMS IV • Ingame WPL Editor • IV Needle • OpenIV • SparkIV • XLiveLess • WPL Manager • X Mod Installer Alice • C++ Script Hook • .NET Script Hook • Scocl |
Tutorials | Importing Textures with OpenIV • Importing Textures with SparkIV |
Modifications | GTA Connected • Gostown IV • Four Multiplayer • IV Multiplayer • CitizenMP:IV Reloaded |
Useful links | Community portal • Discussion forums • Modding forums • Mods on GTAGarage.com |