XML:File types

Revision as of 12:58, 6 April 2014 by Paradox-01 (talk | contribs) (test 2)
XML.png
See Modding Oni for an introduction to modding.
See XML for an introduction to XML modding.

The XML namespace is devoted to explaining Oni's data types, originally documented in a technical byte-by-byte manner at OBD, according to the more user-friendly format they appear in when exported by OniSplit as XML. Following is an overview of each data type's function, and whether it has XML documentation available.

Documentation status:

Aqua Dot-Green.png : available
Aqua Dot-Yellow.png : incomplete
Aqua Dot-Red.png : not available, but that doesn't mean you cannot mod the file type

BINA

BINA/ONIE   File name: BINAEINOimpact_effects.oni Location: global
Purpose: Oni Impact Effects. A list of all impact effects which can happen in the game. That includes weapon particles, hand-to-hand combat, and footsteps. The impact effect is selected according the type of impact (Impt) and the material (Mtrl) which is hit.
BINA/PAR3  
Particle class (the "3" referring to the Particle subsystem's version number). A list of types of particles which can be spawned in the game, used by weapons to deal damage, for lighting effects, etc. A specific instance of a PAR3 class is a PART.
BINA/SABD  
Sound Animation Binary Data. A list of the sounds to be played for each animation type, according to the character variant (ONCV) and the type of animation (TRAM) that they are playing.
BINA/TMBD  
Texture Materials Binary Data. A list of the material (Mtrl) for each texture map (TXMP). Used by ONIE.

OBJC

BINA/OBJC/CHAR  
List of characters in a specific level, containing their position, script function names, weapon, ammunition, items, team, combat, melee ID, etc.
BINA/OBJC/CMBT  
List of combat profiles for global use, containing conditions that govern the AI's melee, weapon combat, and retreat behavior, based on factors like distance and the enemy's reactions.
BINA/OBJC/CONS  
List of consoles in a specific level, containing their position, script name (ID), screen images, and script function names. Consoles are used to open doors, trigger alarms, or provide information.
BINA/OBJC/DOOR  
List of doors in a specific level, containing their conditions for when a door opens (e.g., is the action key required?), and what events are triggered by a character who opens the door.
BINA/OBJC/FLAG  
List of flags in a specific level, containing their position. Flags are used by level scripts and patrol paths.
BINA/OBJC/FURN  
List of pieces of furniture in a specific level. This file type can be used to import level objects.
BINA/OBJC/MELE  
List of melee profiles for global use. A melee profile contains a simple program that determines how the AI uses its combat moves.
BINA/OBJC/NEUT  
List of neutral character behaviors in a specific level. Every character has a melee, combat and neutral behavior ID. It determines whether a non-player character (NPC) talks to you and whether they give you a power-up.
BINA/OBJC/PART  
List of particles in a specific level, containing their position, script name and scaling.
BINA/OBJC/PATR  
List of patrol paths in a specific level, containing an ID which is used by CHAR and the scripting command "ai2_dopath".
BINA/OBJC/PWRU  
List of power-ups (items, e.g. hypo sprays) in a specific level which are spawned at level load, containing their position.
BINA/OBJC/SNDG  
List of sound groups in a specific level. Sound groups are the invisible spheres which contain ambient sounds. If you come near a machine and you hear a sound, that's because of SNDG.
BINA/OBJC/TRGV  
List of trigger volumes in a specific level. They are invisible areas which trigger functions in a script.
BINA/OBJC/TRIG  
List of laser triggers in a specific level. There are several forms of triggers, and they can trigger not only turrets (TURR), but also script functions in the level.
BINA/OBJC/TURR  
List of turrets in a specific level. Note that their pods are part of the level geometry. Spawn one manually and it might be located somewhere in the air. Determines their head's position, the weapon inside the turret head, and the team ID to target.
BINA/OBJC/WEAP  
List of weapons in a specific level, determining their spawn location at level load.

Others

AISA  
AI Spawn Array. This file type was probably in the process of being replaced by BINA/CJBO/CHAR when Oni shipped, but AISA is still used for a few cutscene characters.
AKEV  
Akira Environment. It's the 3D level model. The AKEV exports as a Collada (.dae) file, meant to be edited in a 3D modeler like Mod Tool.
CONS  
Console class.
DOOR  
Door class.
DPge  
Diary page.
FILM  
A record of a character's movements, created by a developer recording his gameplay and played back in cutscenes to make an AI perform complex actions. During playback, AIs have no AI. ^_^
HPge  
Help page.
IGHH  
In-game HUD; your health bar, compass, etc.
Impt  
Impact. This file is used to build up the hierarchy of impacts. See BINA/ONIE for more information.
IPge  
Item page. If you have created a new item, you can describe it here.
M3GM  
Geometry. Some of these 3D objects are used by OBANs and PAR3s.
Mtrl  
Material. This file is used to build up the hierarchy of materials. See BINA/ONIE for more information.
OBAN  
Object Animation. Yes, used by objects but also for moving characters and cutscene cameras.
OFGA  
Object Furniture Geometry Array. Used to import objects with no functions. (Door, consoles, etc. get imported by their object collections. See ONLV for more information.)
ONCC  
Oni Character Class. Here a type of character (Konoko, Strikers, etc.) is assigned their weapon skill, behavior ID, vision radius, jumping height, sounds, 3D model (TRBS), animation collection (TRAC), textures (TRMA), and much more.
The XML file contains also the character's body part material (CBPM), body part impacts (CBPI), and particles for animations (ONCP and ONIA).
ONCV  
Character variant. 1) It's used to create a pool of characters from which an AI can be randomly spawned, in order to create a natural variance in appearance. A flag in a CHAR determines which ONCV the character falls under. 2) It can be also used to upgrade characters on the Hard difficulty level, also determined by a flag in the CHAR.
ONGS  
Game settings (global). There you can modify the game's health bar, hypo spray strength, game difficulty, autoprompts (text messages when picking up a new kind of item), etc.
ONLD  
Level descriptor. The level name on the Load Game screen.
ONLV  
Oni Level. Holds among other things: the name of the BSL folder with the scripts for this level, and links to the AKEV, ONSK, and AISA.
ONSK  
Sky. It's essentially a box of textures that sits on the level, so you will need five images for the top, north, east, south and west. The bottom has no image.
ONVL  
Variant list of characters. It's used to randomize characters' appearances.
ONWC  
Weapon class. Describes the primary and secondary fire mode and more, and links to PAR3, a 3D model, and textures (TXMP).
OPge  
Objective page. This is the source of the text that appears in the Objective tab of the Pause screen.
OSBD  
Oni Sound Binary Data. They determine how sounds (SNDD) get played.
PSpc  
Part Specification. Oni can decorate a page (OPge, TxtC, maybe others) with images from one source. PSpc specifies the coordinates of these parts.
PSpL  
Part specification list.
PSUI  
Part Specifications UI (User Interface).
StNA  
StNA files are obsolete. However, on its page you'll find collections of flags used by TRAM.
SUBT  
Subtitle Array. This is just here for informational purposes, because SUBTs are not extracted as to .xml files, but rather to .txt.
TRAC  
Totoro Animation collection. Used to build a hierarchy of moves (TRAM) which form a weighted moveset, based on which parent TRAC(s) a character's TRAC inherits from.
TRAM  
Totoro Animation. You can create new animations with Mod Tool. But for setting Oni-specific flags, links to particles, and so on, you need to edit the XML file afterwards, or create a precursor XML beforehand.
TRAS  
Totoro Aiming Screen. Used for make characters aim with weapons.
TRBS  
Totoro Body Set, in other words the 3D model of a character. Character classes (ONCC) link to TRBS. The 3D data itself will be exported/imported as Collada (.dae) files.
TRGE  
Trigger Emitter class. This file type holds the 3D model for a laser trigger and its coordinates. Used by TRIG.
TRIG
(Laser) Trigger class.
TRMA  
Texture Map Array. Every body part of a character is covered by a texture. This file type holds the links to those textures.
TRSC  
Totoro Aiming Screen Collection. Used for make characters aim with weapons.
TXMB  
Texture Map (Big). A series of concatenated TXMPs, used for creating splash screens, like the Main Menu background and level intro/win/loss screens.
TXMP  
Texture Map. Well, this type covers all images in Oni (except the ones larger than 256x256, which are TXMB).
TxtC  
Text (Console).
WMCL  
Window Manager Cursor List. Mouse pointer(s).
WMDD  
Window Manager Dialog Data. It shapes pages like TxtC and WPge. However, new button functions would require engine modding.
WMM  
Window Manager Menu.
WPge  
Weapon Page. This is the source for the text and images that appear in the Weapons tab of the pause screen.