Data Types
Basic types
Type | Description |
---|---|
long, int64, S64 | 64-bit signed integer |
ulong, uint64, U64 | 64-bit unsigned integer |
int, int32, S32 | 32-bit signed integer |
uint, uint32, U32 | 32-bit unsigned integer |
short, int16, S16 | 16-bit signed integer |
ushort, uint16, U16 | 16-bit unsigned integer |
byte, int8, S8 | 8-bit signed integer |
ubyte, uint8, U8 | 8-bit unsigned integer |
char | 8-bit unsigned ASCII integer |
float, F32 | IEEE 754 floating point number |
Structs
AssetID
Asset ID is a type derived from uint32 (EvilEngine) or uint64 (GoodEngine). It is considered its own type due to how the game uses Asset IDs to uniquely identify an asset and manage communication between them.
Type | Description |
---|---|
uint | 32-bit unsigned integer |
ulong | 64-bit unsigned integer |
EvilEngine
To calculate the asset ID for the original game's assets, the game runs the BKDR hash algorithm on the asset's name converted to upper case. This is specially important to know when editing RWTX assets; to be able to refer to them from MODL, BSP and JSP assets, the game calculates the hash at runtime and finds the textures based on that.
This is HipHopTool's implementation of the algorithm in C#:
public static uint BKDRHash(string str) { str = str.ToUpper(); uint seed = 131; uint hash = 0; int length = str.Length; if (length > 31) length = 31; for (int i = 0; i < length; i++) hash = (hash * seed) + str[i]; return hash; }
xVec2
xVec2 is a set of 2 floats, which usually represent a 2D vector on the world; it is used mostly for texture coordinates.
Source code: xMath2.h
struct xVec2
{
F32 x;
F32 y;
};
Type | Description |
---|---|
float | X - The X coordinate of this vector |
float | Y - The Y coordinate of this vector |
xVec3
xVec3 is a set of 3 floats, which usually represent a 3D vector on the world, be it position, rotation or scale.
Source code: xVec3.h
struct xVec3
{
F32 x;
F32 y;
F32 z;
};
Type | Description |
---|---|
float | X - The X coordinate of this vector |
float | Y - The Y coordinate of this vector |
float | Z - The Z coordinate of this vector |
xVec4
xVec4 is a set of 4 floats. They can represent a vector in 4D space, and also a color with R, G, B, A components ranging from 0 to 1.
Source code: xMath3.h
struct xVec4
{
F32 x;
F32 y;
F32 z;
F32 w;
};
Type | Description |
---|---|
float | X - The X coordinate of this vector |
float | Y - The Y coordinate of this vector |
float | Z - The Z coordinate of this vector |
float | W - The W coordinate of this vector |
xColor
xColor is a set of 4 bytes, which represent a 32 bit color with red, blue, green and alpha components.
In the source code, xColor is a typedef for iColor_tag, which can be different per platform (usually not though).
Source code: iColor.h
struct iColor_tag
{
uint8 r;
uint8 g;
uint8 b;
uint8 a;
};
Type | Description |
---|---|
byte | R - red (0-255) |
byte | G - green (0-255) |
byte | B - blue (0-255) |
byte | A - alpha (0-255) |
Motion
Motion is a 0x30-byte structure (0x3C in TSSM) used in several asset types (PLAT and BUTN) which contains some settings defining how the object should move.
Source code: xEntMotion.h
Offset | Type | Variable | Description |
---|---|---|---|
0x00 | byte | type |
|
0x01 | byte | use_banking | Unknown, always 0 |
0x02 | ushort | flags |
|
Extend/Retract only | |||
0x04 | Vector3 | ret_pos | Retract Position - Start position |
0x10 | Vector3 | ext_dpos | Extend Delta Position - Distance to move from start position |
0x1C | float | ext_tm | Extend Time - Move forward time |
0x20 | float | ext_wait_tm | Extend Wait Time - Wait time after moving forward |
0x24 | float | ret_tm | Retract Time - Move backward time |
0x28 | float | ret_wait_tm | Retract Wait Time - Wait time after moving backward |
0x2C | byte[4] | - | null (Padding) |
Orbit only | |||
0x04 | Vector3 | center | Point to move around |
0x10 | float | w | Width - X scale of orbit |
0x14 | float | h | Height - Z scale of orbit |
0x18 | float | period | Time it takes to complete one orbit |
0x1C | byte[0x14] | - | null (Padding) |
Spline only (Scooby/BFBB) | |||
0x04 | int | unknown | Yes, this field is actually called "unknown" |
0x08 | byte[0x28] | - | null (Padding) |
Spline only (TSSM) | |||
0x04 | AssetID | spline_id | Spline AssetID |
0x08 | float | speed | |
0x0C | float | lean_modifier | |
Move Point only | |||
0x04 | uint | flags | Always 0 |
0x08 | AssetID | mp_id | MovePoint AssetID - Move Point to start at |
0x0C | float | speed | Speed to move at, in units per second |
0x10 | byte[0x20] | - | null (Padding) |
Mechanism only (Scooby/BFBB) | |||
0x04 | byte | type |
All other values default to Rotate only |
0x05 | byte | flags | Movement Loop Mode Flags
|
0x06 | byte | sld_axis | Slide Axis
|
0x07 | byte | rot_axis | Rotate Axis
|
0x08 | float | sld_dist | Slide Distance |
0x0C | float | sld_tm | Slide Time |
0x10 | float | sld_acc_tm | Slide Accel Time - Ease in time |
0x14 | float | sld_dec_tm | Slide Decel Time - Ease out time |
0x18 | float | rot_dist | Rotate Distance - In degrees |
0x1C | float | rot_tm | Rotate Time |
0x20 | float | rot_acc_tm | Rotate Accel Time - Ease in time |
0x24 | float | rot_dec_tm | Rotate Decel Time - Ease out time |
0x28 | float | ret_delay | Return Delay - Wait time after moving forward |
0x2C | float | post_ret_delay | Post-Return Delay - Wait time after moving backward |
Mechanism only (TSSM) | |||
0x04 | byte | type |
All other values default to Rotate only |
0x05 | byte | flags |
|
0x06 | byte | sld_axis | Slide Axis
|
0x07 | byte | rot_axis | Rotate Axis
|
0x08 | byte | scale_axis | |
0x09 | byte[3] | - | null (Padding) |
0x0C | float | sld_dist | Slide Distance |
0x10 | float | sld_tm | Slide Time |
0x14 | float | sld_acc_tm | Slide Accel Time - Ease in time |
0x18 | float | sld_dec_tm | Slide Decel Time - Ease out time |
0x1C | float | rot_dist | Rotate Distance - In degrees |
0x20 | float | rot_tm | Rotate Time |
0x24 | float | rot_acc_tm | Rotate Accel Time - Ease in time |
0x28 | float | rot_dec_tm | Rotate Decel Time - Ease out time |
0x2C | float | ret_delay | Return Delay - Wait time after moving forward |
0x30 | float | post_ret_delay | Post-Return Delay - Wait time after moving backward |
0x34 | float | scale_amount | |
0x38 | float | scale_duration | |
Pendulum only | |||
0x04 | byte | flags | |
0x05 | byte | plane | Unknown |
0x06 | byte[2] | pad | null (Padding) |
0x08 | float | len | Length - The height of the pivot point |
0x0C | float | range | The amount (in radians) the pendulum swings on each side |
0x10 | float | period | The time one full swing takes |
0x14 | float | phase | Start swing offset (in radians), e.g. 6.28 = 1 full swing |
0x18 | byte[0x18] | - | null (Padding) |
None only | |||
0x04 | byte[0x2C] | - | null (Padding) |