OBD:BINA/OBJC: Difference between revisions
< OBD:BINA
					
					
					|  (clarified that unknown flags don't matter because they're runtime flags for Tool mode; updated some terminology to current practices) | m (...) | ||
| (One intermediate revision by one other user not shown) | |||
| Line 15: | Line 15: | ||
| {{OBDth}} | {{OBDth}} | ||
| {{OBDtr|0x00|char[4]|FF0000|43 4A 42 4F|OBJC|tag}} | {{OBDtr|0x00|char[4]|FF0000|43 4A 42 4F|OBJC|tag}} | ||
| {{OBDtr|0x04| | {{OBDtr|0x04|uint32  |FFFF00|18 02 00 00|536|size to end of object list from 0x08, in bytes}} | ||
| {{OBDtr|0x08| | {{OBDtr|0x08|uint32  |00FF00|27 00 00 00|39|object format version}} | ||
| {{OBDtr|0x0C| | {{OBDtr|0x0C|uint32  |00FFFF|28 00 00 00|40|size of next object (black outline)}} | ||
| {{OBDtrBK|0x10 - 0x37 : first object (40 bytes)}} | {{OBDtrBK|0x10 - 0x37 : first object (40 bytes)}} | ||
| {{OBDtr|0x38| | {{OBDtr|0x38|uint32  |FFFFFF|28 00 00 00|40|size of next object}} | ||
| {{OBDtrBK|0x3C - ... : second object (40 bytes), etc.}} | {{OBDtrBK|0x3C - ... : second object (40 bytes), etc.}} | ||
| |} | |} | ||
| Line 34: | Line 34: | ||
| {{OBDth}} | {{OBDth}} | ||
| {{OBDtr| 0x00 | char[4]  |FFC8C8| 52 52 57 50 | PWRU       | object type }} | {{OBDtr| 0x00 | char[4]  |FFC8C8| 52 52 57 50 | PWRU       | object type }} | ||
| {{OBDtr| 0x04 |  | {{OBDtr| 0x04 | uint32    |FFFFC8| AC 1C 00 00 | 7340       | object ID }} | ||
| {{OBDtr| 0x08 | bitset32 |C8FFC8| 00 00 00 00 | 0x00       | object flags, only used at runtime in [[Tool mode]]}} | {{OBDtr| 0x08 | bitset32 |C8FFC8| 00 00 00 00 | 0x00       | object flags, only used at runtime in [[Tool mode]]}} | ||
| {{OBDtr| 0x0C | float    |C8FFFF| E8 92 77 44 | 990.254    | x position }} | {{OBDtr| 0x0C | float    |C8FFFF| E8 92 77 44 | 990.254    | x position }} | ||
| Line 86: | Line 86: | ||
| |} | |} | ||
| {{OBD BINA Footer|prev=TMBD|type=OBJC|next=ONIE|name=Objects}} | {{OBD BINA Footer|prev=TMBD|type=OBJC|next=ONIE|name=Objects|family=General}} | ||
| {{OBD}} | {{OBD}} | ||
Latest revision as of 11:36, 12 May 2025
| 
 |  |   | 
Introduction
"OBJC" is short for "Objects", which refers to lists of files which are stored in the separate file when available (Windows demo, Mac) or in the raw file otherwise (Windows). OBJC is registered as a tag (and is also a sub-tag of BINA), but it serves as a wrapper for other tags. OBJCs are lists composed of a standard wrapper with a little header data and then elements of specific data types which have their own tags. Objects listed in OBJCs could be edited in-game by the developers using the GUI which was discovered by fans in the European Mac releases of Oni. Screenshots of the editing interface are shown on the pages of each type which the interface could edit.
File description
- Example file
- BINACJBOPowerUp from level3
- Offsets
- Offsets are given with respect to the start of the raw file's data part.
| Offset | Type | Raw Hex | Value | Description | 
|---|---|---|---|---|
| 0x00 | char[4] | 43 4A 42 4F | OBJC | tag | 
| 0x04 | uint32 | 18 02 00 00 | 536 | size to end of object list from 0x08, in bytes | 
| 0x08 | uint32 | 27 00 00 00 | 39 | object format version | 
| 0x0C | uint32 | 28 00 00 00 | 40 | size of next object (black outline) | 
| 0x10 - 0x37 : first object (40 bytes) | ||||
| 0x38 | uint32 | 28 00 00 00 | 40 | size of next object | 
| 0x3C - ... : second object (40 bytes), etc. | ||||
- General layout
- The list's header (first 16 bytes) and layout is common to all 16 OBJC types (see below).
- The size of the whole list is announced at 0x04 (int32), followed by the list.
- Unlike ONIE and TMBD (which are arrays), OBJC announces the size of every object (int32).
- After the last object, the end of the list is signaled by a null next object size.
 
- Object header
- All objects start with the following header:
| Offset | Type | Raw Hex | Value | Description | 
|---|---|---|---|---|
| 0x00 | char[4] | 52 52 57 50 | PWRU | object type | 
| 0x04 | uint32 | AC 1C 00 00 | 7340 | object ID | 
| 0x08 | bitset32 | 00 00 00 00 | 0x00 | object flags, only used at runtime in Tool mode | 
| 0x0C | float | E8 92 77 44 | 990.254 | x position | 
| 0x10 | float | 00 00 D8 41 | 27.000000 | y position | 
| 0x14 | float | 71 DD 98 43 | 305.73 | z position | 
| 0x18 | float | 00 00 00 00 | 0.000000 | rotation on the x axis in degrees | 
| 0x1C | float | 00 00 00 00 | 0.000000 | rotation on the y axis in degrees | 
| 0x20 | float | 00 00 00 00 | 0.000000 | rotation on the z axis in degrees | 
OBJC types
A given list can only hold objects of one type, which can be:
| 
 | 
| ONI BINARY DATA | 
|---|
| AKVA << Other file types >> CBPI | 
| BINA : Binary data | 
| TMBD << Other BINA >> ONIE | 
| OBJC : Objects | 
| General file | 
