OBD:BINA/PAR3: Difference between revisions

6,724 bytes added ,  8 December 2023
m
added family to footer template call
No edit summary
m (added family to footer template call)
 
(35 intermediate revisions by 6 users not shown)
Line 1: Line 1:
{{OBD BINA Header|prev=ONIE|type=PAR3|next=SABD|name=3D Particle|onistuff=b_3d}}
{{OBD BINA Header|prev=ONIE|type=PAR3|next=SABD|name=3D Particle|onistuff=b_3d}}


The following example is the raw/sep part of '''3RAPenv_bomb_e06.BINA''' (level 0). (Another example: http://ssg.oni2.net/test.htm )
The following example is the raw/separate file part of '''3RAPenv_bomb_e06.BINA''' (level 0). (Another example: http://ssg.oni2.net/oni_b_3e.htm )


Particle dialogs: http://ssg.oni2.net/subfold/bluebox/3d-part.htm
Particle dialogs: http://ssg.oni2.net/subfold/bluebox/3d-part.htm
Line 8: Line 8:
The header takes up 780 = 0x30C bytes.
The header takes up 780 = 0x30C bytes.


http://ssg.oni2.net/images/bin_r_3h.gif
[[Image:bin_r_3h.gif]]


{{Table}}
{{Table}}
Line 16: Line 16:
{{OBDtr| 0x08 | int16      |00FF00| 9C 06      | 1692      | length again }}
{{OBDtr| 0x08 | int16      |00FF00| 9C 06      | 1692      | length again }}
{{OBDtr| 0x0A | int16      |00FF00| 12 00      | 18        | version }}
{{OBDtr| 0x0A | int16      |00FF00| 12 00      | 18        | version }}
{{OBDtr| 0x0C | int32      |00FFFF| 01 20 00 00 | 0x2001    | flags1; known flags (from left to right):
{{OBDtr| 0x0C | int32      |00FFFF| 01 20 00 00 | 0x2001    | flags1; used flags (from left to right):
:0x'''01''' 00 00 00 - decorative
:0x'''01''' 00 00 00 - decorative
:0x'''E0''' 00 00 00 - sprite mode mask (3 bits)
:0x'''08''' 00 00 00 - use separate Y scale
:0x'''E0''' 00 00 00 - sprite/contrail mode mask (3 bits, see below for possible values)
:0x00 '''01''' 00 00 - geometry
:0x00 '''01''' 00 00 - geometry
:0x00 '''02''' 00 00 - collide with walls
:0x00 '''02''' 00 00 - collide with walls
:0x00 '''04''' 00 00 - collide with chars
:0x00 '''04''' 00 00 - collide with chars
:0x00 '''08''' 00 00 - scale to velocity
:0x00 '''10''' 00 00 - has velocity
:0x00 '''10''' 00 00 - has velocity
:0x00 '''20''' 00 00 - has orientation
:0x00 '''20''' 00 00 - has orientation
:0x00 00 '''02''' 00 - decal
:0x00 '''40''' 00 00 - has position offset
:0x00 '''80''' 00 00 - has object attachment matrix
:0x00 00 '''01''' 00 - has unknown; ignored?
:0x00 00 '''02''' 00 - has decal state
:0x00 00 '''04''' 00 - has texture animation random start tick
:0x00 00 '''08''' 00 - has texture animation independent tick
:0x00 00 '''10''' 00 - has damage owner
:0x00 00 '''20''' 00 - has contrail data
:0x00 00 '''20''' 00 - has contrail data
:0x00 00 00 '''01''' - has collision cache }}
:0x00 00 '''40''' 00 - has lensflare fading state
{{OBDtr| 0x10 | int32      |00FFFF| 00 00 00 02 | 0x02000000 | flags2; known flags (from left to right):
:0x00 00 '''80''' 00 - has attractor
:0x'''01''' 00 00 00 - use special tint
:0x00 00 00 '''01''' - has collision cache  
}}
{{OBDtr| 0x10 | int32      |00FFFF| 00 00 00 02 | 0x02000000 | flags2; used flags (from left to right):
:0x'''01''' 00 00 00 - use "special" tint (color is based on the health of the character who owns the particle; see [[ONGS]])
:0x'''02''' 00 00 00 - don't attract through walls
:0x'''08''' 00 00 00 - expire on cutscene
:0x'''10''' 00 00 00 - die on cutscene
:0x'''60''' 00 00 00 - disable level mask (2 bits, 0x00 - never disable, 0x40 - disable medium detail, 0x60 - disable low detail)
:0x00 00 '''10''' 00 - draw as sky
:0x00 00 '''10''' 00 - draw as sky
:0x00 00 '''20''' 00 - decal full brightness
:0x00 00 '''80''' 00 - decal
:0x00 00 '''80''' 00 - decal
:0x00 00 00 '''01''' - initially hidden
:0x00 00 00 '''02''' - invisible
:0x00 00 00 '''02''' - invisible
:0x00 00 00 '''04''' - fade out on edge
:0x00 00 00 '''08''' - vector
:0x00 00 00 '''08''' - vector
:0x00 00 00 '''20''' - contrail
:0x00 00 00 '''10''' - lock position to link
:0x00 00 00 '''40''' - lensflare}}
:0x00 00 00 '''20''' - is contrail emitter
{{OBDtr| 0x14 | int32      |FF00FF| 00 00 00 00 | 0          | unknown; looks like garbage data; maybe thelast one (if you read it from right to left) is a bitset too}}
:0x00 00 00 '''40''' - lensflare
:0x00 00 00 '''80''' - one sided edge fade
}}
{{OBDtr| 0x14 | int32      |FF00FF| 00 00 00 00 | 0          | unused\runtine only }}
{{OBDtr| 0x18 | int16      |FF8000| 01 00      | 1          | number of variables }}
{{OBDtr| 0x18 | int16      |FF8000| 01 00      | 1          | number of variables }}
{{OBDtr| 0x1a | int16      |FF8000| 01 00      | 1          | number of events/actions }}
{{OBDtr| 0x1a | int16      |FF8000| 01 00      | 1          | number of events/actions }}
{{OBDtr| 0x1c | int16      |FF8000| 01 00      | 1          | number of emitted particles }}
{{OBDtr| 0x1c | int16      |FF8000| 01 00      | 1          | number of emitters }}
{{OBDtr| 0x1e | int16      |FF8000| 00 01      | 256        | unknown; always the same }}
{{OBDtr| 0x1e | int16      |FF8000| 00 01      | 256        | unknown; always the same }}
|}
|}


===Event groups (0x20 - 0x5F)===
Field '''0x14''':
From empiric experiments I raise a thesis this field has meaning "used physics for this particle". It corresponds with Neo's [[OBOA]] researches ( field 0x18 in [[OBOA]] ):
::0 - no pre-fabricated physics, if you want physics for this particle, create it via PAR3's actions ( see down on this site for info about actions. )
::1 - unknown, looks like it disables all physics context ( even the PAR3 action-induced one )
::2 - pre-fabricated physics type 1 - reacts on collisions, ignores gravity.
::3 - unknown, looks like it disables all physics context ( even the PAR3 action-induced one ) - maybe because this is "physics" for [[OBOA]] objects which will have [[OBAN]] animation ?
::4 - pre-fabricated physics type 2 - reacts on collisions, gravity is not ignored.
 
Judging from this discovery it seems possible that maybe there are more ONI file types which can have this "used physics" field. For example [[DOOR]], unknown field 0x18 ( is 0x 02|00|00|00 -> reacts on collisions, ignores gravity ). Maybe there are more files with this field ? --[[User:Loser|Loser]] 07:32, 16 August 2009 (UTC)
:So just checking: when you set this field, the particles suddenly had collisions\gravity and such? [[User:Gumby|Gumby]] 02:31, 17 August 2009 (UTC)
::Same question as Gumby. For all I know particles do not have "physics", only objects and characters have. As for other uses of this "physics type" thing: highly unlikely. I've said it before and I'll say it again: the physics system in Oni is simplistic. There's nothing that it can do more than it already does. Don't waste your time on it. [[User:Neo|Neo]]
 
 
 
Sprite modes:
:*0 - sprite (face camera, orient to screen)
:*1 - rotated sprite (face camera, orient to particle)
:*2 - beam (parallel, face camera)
:*3 - arrow (parallel, orient to particle)
:*4 - flat (perpendicular)
:*7 - discus (parallel, orient to particle)
 
Contrail modes:
:*5 - contrail (orient to particle)
:*6 - contrail (face camera)
 
HasX flags:
:For each HasX flags that is set space will be allocated in the particle to hold the respective value. For example:
:*"has velocity" - allocates space for the velocity vector (3 floats = 12 bytes)
:*"has orientation" - allocates space for a 3x3 matrix (9 floats = 36 bytes)
:*"has object attachment matrix" - allocates space for a pointer to an "object" transform matrix (pointer = 4 bytes)
:*"has damage owner" - allocates space for an int32 that indicates who owns the particle (typically the owner is a character or a turret)
:The creator of a particle is responsable for properly initializing these values.
:In the specific case of particle emitters the newly emitted particle can inherit these values from the emitting particle. A value is inherited if:
:*both the emitting particle and emitted particle have the coresponding HasX flag set
:*the emitter itself doesn't calculate another value (orientation, velocity etc.)
 
===Event groups===
Here we have 16 4-byte slots, which correspond to the following 16 particle event types :
Here we have 16 4-byte slots, which correspond to the following 16 particle event types :
{|border=1 cellspacing=0
{|border=1 cellspacing=0
Line 63: Line 121:
:*actions {7,8} will be triggered by a '''hit_char''' event
:*actions {7,8} will be triggered by a '''hit_char''' event
:*action {9} will be triggered by a '''lifetime''' event
:*action {9} will be triggered by a '''lifetime''' event
;Back to the silly 3RAPenv_bomb_e06.BINA...


{{Table}}
{{Table}}
Line 97: Line 154:
{{OBDtr| 0x84 |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x84 |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|Others}}
{{OBDtrBK|Others}}
{{OBDtr| 0x98 | float    |FFC800| 00 00 00 00 | 0.000000    | unknown (AI dodge radius ?) }}
{{OBDtr| 0x98 | float    |FFC800| 00 00 00 00 | 0.000000    | AI dodge radius }}
{{OBDtr| 0x9C | float    |FFC800| 00 00 00 00 | 0.000000    | unknown (AI alert radius ?)}}
{{OBDtr| 0x9C | float    |FFC800| 00 00 00 00 | 0.000000    | AI alert radius }}
{{OBDtr| 0xA0 | char[16] |FFC800| 00          | ""          | flyby sound name }}
{{OBDtr| 0xA0 | char[16] |FFC800| 00          | ""          | flyby sound name }}
|}
===Particle Appearance===
{{Table}}
{{OBDth}}
{{OBDtrBK|float property Scale }}
{{OBDtrBK|float property Scale }}
{{OBDtr| 0xB0 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0xB0 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
Line 128: Line 190:
{{OBDtr| 0x164 |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x164 |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|color property Tint }}
{{OBDtrBK|color property Tint }}
{{OBDtr| 0x178 | int32    |FFFFC8| 07 00 00 00 | 3           | value type: color }}
{{OBDtr| 0x178 | int32    |FFFFC8| 07 00 00 00 | 7           | value type: color }}
{{OBDtr| 0x17C | float    |C8FFC8| FF FF FF FF | white      | value }}
{{OBDtr| 0x17C | float    |C8FFC8| FF FF FF FF | white      | value }}
{{OBDtr| 0x180 |          |C8FFC8|            |            | not used for color values }}
{{OBDtr| 0x180 |          |C8FFC8|            |            | not used for color values }}
Line 150: Line 212:
{{OBDtr| 0x204 | int16    |C87C64| 00 00      | 0          | fade in frames }}
{{OBDtr| 0x204 | int16    |C87C64| 00 00      | 0          | fade in frames }}
{{OBDtr| 0x206 | int16    |C87C64| 00 00      | 0          | fade out frames }}
{{OBDtr| 0x206 | int16    |C87C64| 00 00      | 0          | fade out frames }}
{{OBDtr| 0x208 |          |C87C64| 64 00      | 100        | unknown }}
{{OBDtr| 0x208 |          |C87C64| 64 00      | 100        | max decals }}
{{OBDtr| 0x20A |          |C87C64| 3C 00      | 60          | unknown }}
{{OBDtr| 0x20A |          |C87C64| 3C 00      | 60          | decal fade frames }}
{{OBDtrBK|float property Decal Wrap Angle (min value used: 20, max value used: 120) }}
{{OBDtrBK|float property Decal Wrap Angle (min value used: 20, max value used: 120) }}
{{OBDtr| 0x20C | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x20C | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x210 | float    |C8FFC8| 00 00 70 42 | 60.0        | value }}
{{OBDtr| 0x210 | float    |C8FFC8| 00 00 70 42 | 60.0        | value }}
{{OBDtr| 0x214 |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x214 |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|Others}}
|}
 
===Particle Attractor===
{{Table}}
{{OBDth}}
{{OBDtr| 0x228 | int32    |B0C3D4| 00 00 00 00 | none        | particle attractor type
{{OBDtr| 0x228 | int32    |B0C3D4| 00 00 00 00 | none        | particle attractor type
: 0 - none
: 0 - none
Line 171: Line 237:
: 1 - angle }}
: 1 - angle }}
{{OBDtr| 0x230 |          |B0C3D4| 00 00 00 00 | 0          | runtime only }}
{{OBDtr| 0x230 |          |B0C3D4| 00 00 00 00 | 0          | runtime only }}
{{OBDtr| 0x234 | char[64] |B0C3D4| 00          | ""          | unknown; name of a particle }}
{{OBDtr| 0x234 | char[64] |B0C3D4| 00          | ""          | [[OBD:BINA/OBJC/PART|particle]] name (when attractor type is 3) or particle class name (when attractor type is 2) }}
{{OBDtrBK|float property Unknown Property 1 (min value used: 12, max value used: 2000) }}
{{OBDtrBK|float property Attractor Max Distance (min value used: 12, max value used: 2000) }}
{{OBDtr| 0x274 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x274 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x278 | float    |C8FFC8| 00 00 16 43 | 150.0      | value }}
{{OBDtr| 0x278 | float    |C8FFC8| 00 00 16 43 | 150.0      | value }}
{{OBDtr| 0x27C |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x27C |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|float property Unknown Property 2 (min value used: 15, max value used: 180) }}
{{OBDtrBK|float property Attractor Max Angle (min value used: 15, max value used: 180) }}
{{OBDtr| 0x290 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x290 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x294 | float    |C8FFC8| 00 00 F0 41 | 30.0        | value }}
{{OBDtr| 0x294 | float    |C8FFC8| 00 00 F0 41 | 30.0        | value }}
{{OBDtr| 0x298 |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x298 |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|float property Unknown Property 3 (min value used: 3, max value used: 180) }}
{{OBDtrBK|float property Attractor Angle Select Min (min value used: 3, max value used: 180) }}
{{OBDtr| 0x2AC | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x2AC | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x2B0 | float    |C8FFC8| 00 00 40 40 | 3.0        | value }}
{{OBDtr| 0x2B0 | float    |C8FFC8| 00 00 40 40 | 3.0        | value }}
{{OBDtr| 0x2B4 |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x2B4 |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|float property Unknown Property 4 (min value used: 20, max value used: 180) }}
{{OBDtrBK|float property Attractor Angle Select Max (min value used: 20, max value used: 180) }}
{{OBDtr| 0x2C8 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x2C8 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x2CC | float    |C8FFC8| 00 00 A0 41 | 20.0        | value }}
{{OBDtr| 0x2CC | float    |C8FFC8| 00 00 A0 41 | 20.0        | value }}
{{OBDtr| 0x2D0 |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x2D0 |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|float property Unknown Property 5 (min value used: 1, max value used: 100) }}
{{OBDtrBK|float property Attractor Angle Select Weight (min value used: 1, max value used: 100) }}
{{OBDtr| 0x2E4 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x2E4 | int32    |FFFFC8| 03 00 00 00 | 3          | value type: float }}
{{OBDtr| 0x2E8 | float    |C8FFC8| 00 00 40 40 | 3.0        | value }}
{{OBDtr| 0x2E8 | float    |C8FFC8| 00 00 40 40 | 3.0        | value }}
{{OBDtr| 0x2EC |          |C8FFC8|            |            | not used for float values }}
{{OBDtr| 0x2EC |          |C8FFC8|            |            | not used for float values }}
{{OBDtrBK|Others}}
{{OBDtrBK|Runtime only}}
{{OBDtr| 0x300 |          |E7CEA5| AC 22 81 0B | 0B 81 22 AC | runtime pointer to variables }}
{{OBDtr| 0x300 |          |E7CEA5| AC 22 81 0B | 0B 81 22 AC | runtime pointer to variables }}
{{OBDtr| 0x304 |          |E7CEA5| E0 22 81 0B | 0B 81 22 E0 | runtime pointer to events/actions}}
{{OBDtr| 0x304 |          |E7CEA5| E0 22 81 0B | 0B 81 22 E0 | runtime pointer to events/actions}}
{{OBDtr| 0x308 |          |E7CEA5| 88 24 81 0B | 0B 81 24 88 | runtime pointer to emissions }}
{{OBDtr| 0x308 |          |E7CEA5| 88 24 81 0B | 0B 81 24 88 | runtime pointer to emissions }}
|}
|}
;Value types:
;Value types:
:0 - variable
:0 - variable; variable name follows
:1 - int16
:1 - none (action parameters use this to indicate an unused parameter)
:2 - random int16:
:3 - float; constant; 1 float value follows
:3 - float
:4 - float; random; 2 float values follow (min, max)
:4 - random float (2 floats, range, min and max value)
:5 - float; bell curve; 2 float values follow (mean, stddev)
:5 - random float (normal distribution;)
:6 - instance; instance name follows
:6 - instance name
:7 - color; constant; 1 color follows
:7 - color
:8 - color; random; 2 color follow (min, max)
:8 - random color
:9 - color; bell curve; 2 color follow (mean, stddev)
:9 - random color (normal distribution)
:10 - int32; constant; int32 follows
:10 - int32
:11 - time cycle; 2 float values follow (cycle length, scale)
:11 - time
--------
--------


Line 215: Line 281:
Every variable takes up 52=0x34 bytes. The number of variables is specified at 0x18 in the header.
Every variable takes up 52=0x34 bytes. The number of variables is specified at 0x18 in the header.


http://ssg.oni2.net/images/bin_r_31.gif
For each variable space is allocated then a particle is created. Variables can be modified by some actions like "linear change", "random change" etc.  
 
[[Image:bin_r_31.gif]]


{{Table}}
{{Table}}
Line 221: Line 289:
{{OBDtr| 0x00 | char[16] |C8FFC8|            | "rotate" | name of the variable }}
{{OBDtr| 0x00 | char[16] |C8FFC8|            | "rotate" | name of the variable }}
{{OBDtr| 0x10 | int32    |C8FFFF| 02 00 00 00 | 2  | storage type: float }}
{{OBDtr| 0x10 | int32    |C8FFFF| 02 00 00 00 | 2  | storage type: float }}
{{OBDtr| 0x14 | int32    |FFC8FF| 30 00 00 00 | 48 | storaget offset (incremented by the storage type size for every next variable) }}
{{OBDtr| 0x14 | int32    |FFC8FF| 30 00 00 00 | 48 | runtime: storaget offset (incremented by the storage type size for every next variable) }}
{{OBDtrBK|Initial value }}
{{OBDtrBK|Initial value }}
{{OBDtr| 0x18 | int32    |FFFFC8| 04 00 00 00 | 4          | value type: random }}
{{OBDtr| 0x18 | int32    |FFFFC8| 04 00 00 00 | 4          | value type: random }}
Line 231: Line 299:
|}
|}


;Storage types
;Storage types used for variables
:1 - int16 (storage size: 2)
:0x0002 (0x02 00 00 00) - float (storage size: 4)
:2 - float (storage size: 4)
:0x0008 (0x08 00 00 00) - color (storage size: 4)
:4 - string? (storage size: 16)
:0x1000 (0x00 10 00 00) - pingpong state (storage size: 4)
:8 - color (storage size: 4)
 
:4096 - pingpong state (storage size: 4)
;Other storage types
:4112 - action index (storage size: 4)
 
:4128 - emitter (storage size: 4)
These storage types are never used for variables. They might work but since there are no actions that can output such values it doesn't make much sense to declare variables using these types.
:4144 - blast falloff (storage size: 4)
 
:4160 - coord frame (storage size: 4)
:0x0001 (0x01 00 00 00) - int16 (storage size: 2) (never used)
:4176 - collision orient (storage size: 4)
:0x0004 (0x04 00 00 00) - impact name (storage size: 16)
:4192 - boolean (storage size: 4)
:0x1010 (0x10 10 00 00) - action index (storage size: 4)
:4208 - ambient sound (storage size: 4)
:0x1020 (0x20 10 00 00) - emitter (storage size: 4)
:4224 - impulse sound (storage size: 4)
:0x1030 (0x30 10 00 00) - blast falloff (storage size: 4)
:4240 - impact modifier (storage size: 4)
:0x1040 (0x40 10 00 00) - coord frame (storage size: 4)
:4256 - damage type (storage size: 4)
:0x1050 (0x50 10 00 00) - collision orient (storage size: 4)
:0x1060 (0x60 10 00 00) - boolean (storage size: 4)
:0x1070 (0x70 10 00 00) - ambient sound (storage size: 4) (never used)
:0x1080 (0x80 10 00 00) - impulse sound (storage size: 4) (never used)
:0x1090 (0x90 10 00 00) - impact modifier (storage size: 4)
:0x10A0 (0xA0 10 00 00) - damage type (storage size: 4)
:*0 - normal
:*0 - normal
:*1 - minor stun
:*1 - minor stun
Line 254: Line 327:
:*5 - blownup
:*5 - blownup
:*6 - pickup
:*6 - pickup
:8192 - string? (storage size: 16)
:0x10B0 (0xB0 10 00 00) - direction (storage size: 4)
:16384 - string? (storage size: 16)
:0x2000 (0x00 20 00 00) - ambient sound name (storage size: 16)
:0x4000 (0x00 40 00 00) - impulse sound name (storage size: 16)


-------
-------
Line 262: Line 336:
Every action takes up 424=0x1A8 bytes. The number of actions is specified at 0x1A in the header.
Every action takes up 424=0x1A8 bytes. The number of actions is specified at 0x1A in the header.


http://ssg.oni2.net/images/bin_r_32.gif
[[Image:bin_r_32.gif]]


{{Table}}
{{Table}}
Line 268: Line 342:
{{OBDtr| 0x00 | int32 |FFC8C8| 22 00 00 00 | 34 | [[OBD:BINA/PAR3/Actions|Action type]]: Rotate Y }}
{{OBDtr| 0x00 | int32 |FFC8C8| 22 00 00 00 | 34 | [[OBD:BINA/PAR3/Actions|Action type]]: Rotate Y }}
{{OBDtr| 0x04 | int32 |FFFFC8| 00 00 00 00 | 0  | unknown }}
{{OBDtr| 0x04 | int32 |FFFFC8| 00 00 00 00 | 0  | unknown }}
{{OBDtrBK|First variable reference}}
{{OBDtrBK|First output paramter (reference to a variable which the action can modify) }}
{{OBDtr| 0x00 | char[16] |C8FFC8| 00          | ""  | variable name, if empty this block is not used }}
{{OBDtr| 0x00 | char[16] |C8FFC8| 00          | ""  | variable name, if empty this block is not used }}
{{OBDtr| 0x10 | int32    |C8FFFF| 00 00 00 00 | 0  | runtime: storage type }}
{{OBDtr| 0x10 | int32    |C8FFFF| 00 00 00 00 | 0  | runtime: storage type }}
{{OBDtr| 0x14 | int32    |FFC8FF| 00 00 00 00 | 0  | runtime: storage offset }}
{{OBDtr| 0x14 | int32    |FFC8FF| 00 00 00 00 | 0  | runtime: storage offset }}
{{OBDtrBK|First action parameter}}
{{OBDtrBK|First input parameter}}
{{OBDtr| 0x00 | int32    |FFFFC8| 0A 00 00 00 | 10     | value type: int32 }}
{{OBDtr| 0x00 | int32    |FFFFC8| 0A 00 00 00 | 10 | value type: int32 }}
{{OBDtr| 0x04 | int32    |C8FFC8| 01 00 00 00 | 1       | value (rotation space)}}
{{OBDtr| 0x04 | int32    |C8FFC8| 01 00 00 00 | 1   | value (rotation coordinate space)}}
{{OBDtr| 0x08 |          |C8FFC8|            |         | not used for int32 values }}
{{OBDtr| 0x08 |          |C8FFC8|            |     | not used for int32 values }}
{{OBDtr| 0x14 |          |C8FFFF|            |         | not used for int32 values }}
{{OBDtr| 0x14 |          |C8FFFF|            |     | not used for int32 values }}
{{OBDtr| 0x18 |          |FFC8FF|            |         | not used for int32 values }}
{{OBDtr| 0x18 |          |FFC8FF|            |     | not used for int32 values }}
|}
|}


Line 283: Line 357:
----
----


==Emitted particles==
==Emitters==
Every emitted particle takes up 444=0x1BC bytes. The number of emitted particles is specified at 0x1C in the header.
Every emitter takes up 444=0x1BC bytes. The number of emitters is specified at 0x1C in the header. Each emitter has space for 12 parameters but it appears that the last 2 are never used.


http://ssg.oni2.net/images/bin_r_33.gif
[[Image:bin_r_33.gif]]


{{Table}}
{{Table}}
Line 292: Line 366:
{{OBDtr| 0x00 | char[64] |FF0000| |"env_bomb_p09"        | name of the particle to emit (3RAPenv_bomb_p09.BINA) }}
{{OBDtr| 0x00 | char[64] |FF0000| |"env_bomb_p09"        | name of the particle to emit (3RAPenv_bomb_p09.BINA) }}
{{OBDtr| 0x40 | int32    |FFFF00| C0 92 62 00 |          | runtime pointer to emitted particle class }}
{{OBDtr| 0x40 | int32    |FFFF00| C0 92 62 00 |          | runtime pointer to emitted particle class }}
{{OBDtr| 0x44 | int32    |00FF00| 47 00 00 00 | 71        | flags (from 0 to 775) }}
{{OBDtr| 0x44 | int32    |00FF00| 47 00 00 00 | 0x47      | flags; used values:
{{OBDtr| 0x48 | int16    |00FFFF| 04 00      | 4        | unknown (from 0 to 100) }}
:0x'''01''' 00 00 00 - initially on
:0x'''02''' 00 00 00 - increase particle count
:0x'''04''' 00 00 00 - turn off at treshold
:0x'''10''' 00 00 00 - emit with parent velocity
:0x'''20''' 00 00 00 - ignored?
:0x'''40''' 00 00 00 - orient to velocity
:0x'''80''' 00 00 00 - inherit tint
:0x00 '''01''' 00 00 - one per attractor
:0x00 '''02''' 00 00 - at least one
:0x00 '''04''' 00 00 - cycle attractors }}
{{OBDtr| 0x48 | int16    |00FFFF| 04 00      | 4        | turn off treshold }}
{{OBDtr| 0x4A | uint16  |00FFFF| FF FF      | 65535    | emit probability (scaled by 65535) }}
{{OBDtr| 0x4A | uint16  |00FFFF| FF FF      | 65535    | emit probability (scaled by 65535) }}
{{OBDtr| 0x4C | float    |FF00FF| 00 00 20 41 | 10.000000 | amount of (sprite) copies }}
{{OBDtr| 0x4C | float    |FF00FF| 00 00 20 41 | 10.000000 | amount of (sprite) copies }}
{{OBDtr| 0x50 | int32    |FFC8C8| 00 00 00 00 | 0        | unknown }}
{{OBDtr| 0x50 | int32    |FFC8C8| 00 00 00 00 | 0        | link to:
{{OBDtr| 0x54 | int32    |FFC8C8| 00 00 00 00 | 0        | emit rate; can use elements 1 and 2; possible values (in dec):
:0 - nothing
:1 - this particle
:2-9 - to the particle last emitted by emitter 0-7
:10 - this particle's link
}}
{{OBDtr| 0x54 | int32    |FFC8C8| 00 00 00 00 | 0        | emit rate; can use parameters 1 and 2; possible values (in dec):
:0 - continuous (emit interval)
:0 - continuous (emit interval)
:1 - random (min interval, max interval)
:1 - random (min interval, max interval)
Line 303: Line 392:
:3 - distance (distance)
:3 - distance (distance)
:4 - attractor (recharge time, check interval) }}
:4 - attractor (recharge time, check interval) }}
{{OBDtr| 0x58 | int32    |FFC8C8| 00 00 00 00 | 0        | position; can use elements 3, 4 and 5; possible values (in dec):
{{OBDtr| 0x58 | int32    |FFC8C8| 00 00 00 00 | 0        | position; can use parameters 3, 4 and 5; possible values (in dec):
:0 - point
:0 - point
:1 - line (radius)
:1 - line (radius)
Line 309: Line 398:
:3 - sphere (inner radius, outer radius)
:3 - sphere (inner radius, outer radius)
:4 - offset (x, y, z)
:4 - offset (x, y, z)
:5 - cylinder (heigt, inner radius, outer radius)
:5 - cylinder (height, inner radius, outer radius)
:6 - body-surface (offset radius)
:6 - body-surface (offset radius)
:7 - body-bones (offset radius)}}
:7 - body-bones (offset radius)}}
{{OBDtr| 0x5C | int32    |FFC8C8| 03 00 00 00 | 3        | direction; can use elements 6, 7 and 8; possible values (in dec):
{{OBDtr| 0x5C | int32    |FFC8C8| 03 00 00 00 | 3        | direction; can use parameters 6, 7 and 8; possible values (in dec):
:0 - straight
:0 - straight
:1 - random
:1 - random
Line 320: Line 409:
:5 - inaccurate (base angle, inaccuracy, center bias)
:5 - inaccurate (base angle, inaccuracy, center bias)
:6 - attractor}}
:6 - attractor}}
{{OBDtr| 0x60 | int32    |FFC8C8| 00 00 00 00 | 0        | speed; can use elements 9 and 10; possible values (in dec):
{{OBDtr| 0x60 | int32    |FFC8C8| 00 00 00 00 | 0        | speed; can use parameters 9 and 10; possible values (in dec):
:0 - uniform (speed)
:0 - uniform (speed)
:1 - stratified (speed 1, speed 2)}}
:1 - stratified (speed 1, speed 2)}}
{{OBDtr| 0x64 | int32    |FFC8C8| 0C 00 00 00 | 12        | orientation dir; can use element 11?; possible values (in dec):
{{OBDtr| 0x64 | int32    |FFC8C8| 0C 00 00 00 | 12        | orientation dir; possible values (in dec):
:0 - parent +X
:0 - parent +X
:1 - parent -X
:1 - parent -X
Line 340: Line 429:
:14 - towards-emitter
:14 - towards-emitter
:15 - awayfrom-emitter}}
:15 - awayfrom-emitter}}
{{OBDtr| 0x68 | int32    |FFC8C8| 04 00 00 00 | 4        | orientation up; can use element 12? same possible values as for orientation dir }}
{{OBDtr| 0x68 | int32    |FFC8C8| 04 00 00 00 | 4        | orientation up; same possible values as for orientation dir }}
{{OBDtrBK}}
{{OBDtrBK|First emitter parameter }}
{{OBDtr| 0x00 | int32    |FFFFC8| 04 00 00 00 | 4        | value type: random float }}
{{OBDtr| 0x00 | int32    |FFFFC8| 04 00 00 00 | 4        | value type: random float }}
{{OBDtr| 0x04 | float    |C8FFC8| 00 00 00 3E | 0.125000  | attractor - recharge time min value }}
{{OBDtr| 0x04 | float    |C8FFC8| 00 00 00 3E | 0.125000  | attractor - recharge time min value }}
Line 350: Line 439:
|}
|}


;Direction type Inaccurate vs. Cone
:The Inaccurate type was designed for standard ballistic weapons which will have a cone of fire expanding out from the point of origin, therefore it works identically to the Cone type except with an additional factor, "inaccuracy". The "angle" supplied is now a base angle, which is added to by the inaccuracy setting. The "center bias" for Cone and Inaccurate emitters can be positive to pull the dispersion of particles towards the center of the vector, or negative to push them towards the edges of the cone.
:The inaccuracy setting is only used if the originating character is an AI or turret. The AI's or turret's shooting skill is looked up and multiplied by the difficulty setting's weapon inaccuracy multiplier (see [[ONGS]]), then added to the base angle. With the bias taken into account, and some randomization added by the conical dispersion function, this determines the exact trajectory of the bullet coming from the gun.


----
----
----
----
{{OBD BINA Footer|prev=ONIE|type=PAR3|next=SABD|name=3D Particle|onistuff=b_3d}}
{{OBD BINA Footer|prev=ONIE|type=PAR3|next=SABD|name=3D Particle|onistuff=b_3d|family=Level}}
 
{{OBD}}