OBD:AGQG: Difference between revisions

From OniGalore
No edit summary
m (...)
 
(33 intermediate revisions by 9 users not shown)
Line 1: Line 1:
[[Main Page]] >> [[OBD:Oni Binary Data|Oni Binary Data]] >> [[OBD:File types|File types]] >> AGQG File
{{OBD_File_Header | type=AGQG | prev=AGQC | next=AGQR | name=Gunk Quad General Array | family=Level | align=center}}




<CENTER>[[OBD:AGQC|<==]] <FONT SIZE=5>AGQG File</FONT> [[OBD:AGQR|==>]]<BR>
[[Image:agqg_a.gif]]
<FONT SIZE=2>Gunk Quad Collision Array - Level File</FONT></CENTER>




http://www.fh-eberswalde.de/user/dkriesch/onistuff/images/agqg_a.gif
{{Table}}
{{OBDth}}
{{OBDtr | 0x00 | res_id |FF0000| 01 49 02 00 | 585          | 00585-.AGQG }}
{{OBDtr | 0x04 | lev_id |FFFF00| 01 00 00 06 | 3            | level 3 }}
{{OBDtr | 0x08 |char[20]|00FF00| AD DE      | dead        | padding }}
{{OBDtr | 0x1C | uint32  |00FFFF| 15 A8 00 00 | 35349        | array size }}
{{OBDtrBK}}
{{OBDtr | 0x00 | uint32  |FFC8C8| 00 00 00 00 | 0            | [[OBD:PNTA|PNTA]] element for 1st vertex }}
{{OBDtr | 0x04 | uint32  |FFC8C8| 01 00 00 00 | 1            | [[OBD:PNTA|PNTA]] element for 2nd vertex }}
{{OBDtr | 0x08 | uint32  |FFC8C8| 02 00 00 00 | 2            | [[OBD:PNTA|PNTA]] element for 3rd vertex }}
{{OBDtr | 0x0C | uint32  |FFC8C8| 03 00 00 00 | 3            | [[OBD:PNTA|PNTA]] element for 4th vertex }}
{{OBDtr | 0x10 | uint32  |FFFFC8| F5 0F 00 00 | 4085        | [[OBD:TXCA|TXCA]] element for 1st vertex }}
{{OBDtr | 0x14 | uint32  |FFFFC8| F3 0F 00 00 | 4083        | [[OBD:TXCA|TXCA]] element for 2nd vertex }}
{{OBDtr | 0x18 | uint32  |FFFFC8| F4 0F 00 00 | 4084        | [[OBD:TXCA|TXCA]] element for 3rd vertex }}
{{OBDtr | 0x1C | uint32  |FFFFC8| F6 0F 00 00 | 4086        | [[OBD:TXCA|TXCA]] element for 4th vertex }}
{{OBDtr | 0x20 | color  |C8FFC8| 00 00 00 00 | 0, 0, 0, 0  | byte-swapped ARGB color for 1st vertex }}
{{OBDtr | 0x24 | color  |C8FFC8| 00 00 00 00 | 0, 0, 0, 0  | byte-swapped ARGB color for 2nd vertex }}
{{OBDtr | 0x28 | color  |C8FFC8| 02 07 09 00 | 2, 7, 9, 0  | byte-swapped ARGB color for 3rd vertex }}
{{OBDtr | 0x2C | color  |C8FFC8| 06 15 1E 00 | 6, 21, 30, 0 | byte-swapped ARGB color for 4th vertex }}
{{OBDtr | 0x30 |bitset32|C8FFFF| 00 00 08 02 | 0, 0, 8, 2  | flags; used values:
:0x'''01''' 00 00 00 - door frame (invisible quad that uses the TXMP_DOOR_FRAME texture)
:0x'''02''' 00 00 00 - ghost (pathfinding volume separator, see [[OBD:AKVA|AKVA]] etc)
:0x'''04''' 00 00 00 - stairs up
:0x'''08''' 00 00 00 - stairs down
:0x'''10''' 00 00 00 - stairs
:0x'''20''' 00 00 00 - (runtime only) marks quads as [[Jello-cam|jelloed]]; never used in file data
:0x'''40''' 00 00 00 - triangle (see below)
:0x'''80''' 00 00 00 - transparency (if 0 then alpha is ignored, color is just RGB shading)
:0x00 01 00 00 - unused ("draw flash")
:0x00 '''02''' 00 00 - two-sided
:0x00 04 00 00 - unused ("trigger")
:0x00 '''08''' 00 00 - no collision
:0x00 10 00 00 - unused ("flash state")
:0x00 '''20''' 00 00 - invisible
:0x00 '''40''' 00 00 - no object collision
:0x00 '''80''' 00 00 - no character collision
:0x00 00 '''01''' 00 - no occlusion
:0x00 00 '''02''' 00 - danger
:0x00 00 '''04''' 00 - (runtime only) marks quads hidden with [[env_show]]; never used in file data
:0x00 00 '''08''' 00 - vertical collision: slope < 70°
:0x00 00 '''10''' 00 - horizontal collision: slope > 70°
:0x00 00 '''20''' 00 - unused, runtime only ("breakable")
:0x00 00 '''40''' 00 - grid ignore
:0x00 00 '''80''' 00 - no decal
:0x00 00 00 '''01''' - furniture
:0x00 00 00 '''02''' - projection plan bit 0, see below
:0x00 00 00 '''04''' - projection plan bit 1, see below
:0x00 00 00 '''08''' - sound-transparent
:0x00 00 00 '''10''' - impassable
}}
{{OBDtr | 0x34 | uint32  |FFC8FF| FF FF FF FF | -1          | object ID and type to which this quad belongs (see [[ONOA]] for details); -1 if it does not belong to an object }}
{{OBDtrBK|Data fields exclusive to the PS2 implementation (4 extra bytes at the end of each AGQG array element)}}
{{OBDtr | 0x38 | int16  |FFC8FF| 00 80 | 32768 (high bit set) | unknown; always the same? }}
{{OBDtr | 0x3A | int16  |FFC8FF| 00 80 | 32768 (high bit set) | unknown; always the same? }}
|}
;Triangles
:Many quads are in fact triangles: the last two vertices have the same [[OBD:PNTA|PNTA]] and [[OBD:TXCA|TXCA]] entries, and the ARGB color is (255, 205, 205, 205) (80% gray, 100% opaque). There is also a flag specifying that.


;Ghost, Stairs up, Stairs down
:These flags are used for BNV adjacencies, see [[AKAA]]. Stairs up/down are used instead of Ghost when the quad is placed at the bottom/top of the stairs. These quads are not visibile. The script variable env_show_ghostgqs is intended to control the visibility of such quads but it requires "debug" level files.


<TABLE BORDER=1 WIDTH=100% CELLPADDING=2 CELLSPACING=0 BGCOLOR="#000000">
:There are a couple of ghost quads that aren't referenced from [[AKAA]]. It's likely that those quads are useless.
<TR ALIGN=CENTER BGCOLOR="#FFDDBB"><TD WIDTH=15%><B>Hex</B></TD><TD WIDTH=15%><B>Translation</B></TD><TD WIDTH=70%><B>Meaning</B></TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FF0000">01 49 02 00</TD><TD>585</TD><TD ALIGN=LEFT>00585-.AGQG</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFFF00">01 00 00 06</TD><TD>3</TD><TD ALIGN=LEFT>level 3</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#00FF00">AD DE</TD><TD>dead</TD><TD ALIGN=LEFT>not used</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#00FFFF">15 A8 00 00</TD><TD>35349</TD><TD ALIGN=LEFT>35349 packages follow (one package is edged in black)</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#000000"><TD COLSPAN=3><FONT SIZE=2 COLOR="#FFFFFF">Below follows the first package.</FONT></TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFC8C8">00 00 00 00</TD><TD>0</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFC8C8">01 00 00 00</TD><TD>1</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFC8C8">02 00 00 00</TD><TD>2</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFC8C8">03 00 00 00</TD><TD>3</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFFFC8">F5 0F 00 00</TD><TD>4085</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFFFC8">F3 0F 00 00</TD><TD>4083</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFFFC8">F4 0F 00 00</TD><TD>4084</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#FFFFC8">F6 0F 00 00</TD><TD>4086</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">00 00</TD><TD>0</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">00 00</TD><TD>0</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">00 00</TD><TD>0</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">00 00</TD><TD>0</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">02 07</TD><TD>1794</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">09 00</TD><TD>9</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">06 15</TD><TD>5382</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">1E 00</TD><TD>30</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">00 00</TD><TD>0</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">08 02</TD><TD>520</TD><TD ALIGN=LEFT>unknown</TD></TR>
<TR ALIGN=CENTER VALIGN=TOP BGCOLOR="#FFEEDD"><TD BGCOLOR="#C8FFC8">FF FF FF FF</TD><TD>unknown</TD><TD ALIGN=LEFT>unknown</TD></TR>
</TABLE>


;Door frame
:This appears to be another type of "ghost" quad (its visibility is controlled by the same env_show_ghostgqs variable). Sometimes it is used together with the Ghost flag but not always. Only the door frames that also have the Ghost flag are used as adjacencies so it's unclear if the rest of the door frames serve any purpose. In fact it appears that this flag has no effect other than making the quad invisible.


Maybe an interesting fact: The 3D-model of level 3 (the lab) has 70698 faces. 35349 is the half of it.<BR>IRF_Oni says, that this file contains the lighting informatons of the level.
;Stairs
:This is applied to the invisible ramp quad that covers the stairs. In general this flag is also applied to the visible stairs geometry but there are some exceptions (errors? see level 19 stairs).


;No occlusion
:This flag tells the octtree raycaster to ignore the quad when doing ray/quad intersections. This is tipically used for small quads that are unlikely to affect the overall environment visibility.


<HR>
;Projection plane flags
<CENTER>[[OBD:AGQC|<==]] <B>AGQG File</B> [[OBD:AGQR|==>]]</CENTER>
:These 2 flags can be 00, 01, 10 and 11. That means the values 0,1,2 and 3 which have the following meanings:
<HR>
:*0 - No projection plane specified. One can be computed if needed. Never used in files, may slow down the game if used.
:*1 - Project quad on XY plane.
:*2 - Project quad on XZ plane.
:*3 - Project quad on YZ plane.
:The projection plane is used to determine if a point is in a quad (this point is usually the result of an intersection between a ray and the quad plane).


;Grid ignore
:Appears to be unused. Its likely purpose is to mark quads that don't count as obstacles in the pathfinding grid.


[[Main Page]] >> [[OBD:Oni Binary Data|Oni Binary Data]] >> [[OBD:File types|File types]] >> AGQG File
;Danger
:Appears to be unused. Its likely purpose is to create danger areas in the pathfinding grids. Usually there's a trigger volume nearby that hurts/kills the character. This quads are always invisible.
 
;Invisible
:Invisible quads have a couple of different uses:
:* block player access to some parts of the environment
:* stairs ramp
:* collision geometry (used by some "complex" furniture)
:* danger quads (see above)
:* some other apparently useless quads
 
;Furniture
:Set for all quads that belong to a furniture object. It doesn't appear to be used. It is also redundant since all the furniture quads have an object id.
 
;No decal
:Prevents the creation of decals on the quad. Set for door quads because the decals would disappear when the door opens. That's why shooting a door doesn't leave a mark.
 
{{OBD_File_Footer | type=AGQG | prev=AGQC | next=AGQR | name=Gunk Quad General Array | family=Level}}
 
{{OBD}}

Latest revision as of 11:04, 12 May 2025

ONI BINARY DATA
AGQC << Other file types >> AGQR
AGQG : Gunk Quad General Array
switch to XML:AGQG page
Overview @ Oni Stuff
OBD.png


Agqg a.gif


Offset Type Raw Hex Value Description
0x00 res_id 01 49 02 00 585 00585-.AGQG
0x04 lev_id 01 00 00 06 3 level 3
0x08 char[20] AD DE dead padding
0x1C uint32 15 A8 00 00 35349 array size
First element (black outline)
0x00 uint32 00 00 00 00 0 PNTA element for 1st vertex
0x04 uint32 01 00 00 00 1 PNTA element for 2nd vertex
0x08 uint32 02 00 00 00 2 PNTA element for 3rd vertex
0x0C uint32 03 00 00 00 3 PNTA element for 4th vertex
0x10 uint32 F5 0F 00 00 4085 TXCA element for 1st vertex
0x14 uint32 F3 0F 00 00 4083 TXCA element for 2nd vertex
0x18 uint32 F4 0F 00 00 4084 TXCA element for 3rd vertex
0x1C uint32 F6 0F 00 00 4086 TXCA element for 4th vertex
0x20 color 00 00 00 00 0, 0, 0, 0 byte-swapped ARGB color for 1st vertex
0x24 color 00 00 00 00 0, 0, 0, 0 byte-swapped ARGB color for 2nd vertex
0x28 color 02 07 09 00 2, 7, 9, 0 byte-swapped ARGB color for 3rd vertex
0x2C color 06 15 1E 00 6, 21, 30, 0 byte-swapped ARGB color for 4th vertex
0x30 bitset32 00 00 08 02 0, 0, 8, 2 flags; used values:
0x01 00 00 00 - door frame (invisible quad that uses the TXMP_DOOR_FRAME texture)
0x02 00 00 00 - ghost (pathfinding volume separator, see AKVA etc)
0x04 00 00 00 - stairs up
0x08 00 00 00 - stairs down
0x10 00 00 00 - stairs
0x20 00 00 00 - (runtime only) marks quads as jelloed; never used in file data
0x40 00 00 00 - triangle (see below)
0x80 00 00 00 - transparency (if 0 then alpha is ignored, color is just RGB shading)
0x00 01 00 00 - unused ("draw flash")
0x00 02 00 00 - two-sided
0x00 04 00 00 - unused ("trigger")
0x00 08 00 00 - no collision
0x00 10 00 00 - unused ("flash state")
0x00 20 00 00 - invisible
0x00 40 00 00 - no object collision
0x00 80 00 00 - no character collision
0x00 00 01 00 - no occlusion
0x00 00 02 00 - danger
0x00 00 04 00 - (runtime only) marks quads hidden with env_show; never used in file data
0x00 00 08 00 - vertical collision: slope < 70°
0x00 00 10 00 - horizontal collision: slope > 70°
0x00 00 20 00 - unused, runtime only ("breakable")
0x00 00 40 00 - grid ignore
0x00 00 80 00 - no decal
0x00 00 00 01 - furniture
0x00 00 00 02 - projection plan bit 0, see below
0x00 00 00 04 - projection plan bit 1, see below
0x00 00 00 08 - sound-transparent
0x00 00 00 10 - impassable
0x34 uint32 FF FF FF FF -1 object ID and type to which this quad belongs (see ONOA for details); -1 if it does not belong to an object
Data fields exclusive to the PS2 implementation (4 extra bytes at the end of each AGQG array element)
0x38 int16 00 80 32768 (high bit set) unknown; always the same?
0x3A int16 00 80 32768 (high bit set) unknown; always the same?
Triangles
Many quads are in fact triangles: the last two vertices have the same PNTA and TXCA entries, and the ARGB color is (255, 205, 205, 205) (80% gray, 100% opaque). There is also a flag specifying that.
Ghost, Stairs up, Stairs down
These flags are used for BNV adjacencies, see AKAA. Stairs up/down are used instead of Ghost when the quad is placed at the bottom/top of the stairs. These quads are not visibile. The script variable env_show_ghostgqs is intended to control the visibility of such quads but it requires "debug" level files.
There are a couple of ghost quads that aren't referenced from AKAA. It's likely that those quads are useless.
Door frame
This appears to be another type of "ghost" quad (its visibility is controlled by the same env_show_ghostgqs variable). Sometimes it is used together with the Ghost flag but not always. Only the door frames that also have the Ghost flag are used as adjacencies so it's unclear if the rest of the door frames serve any purpose. In fact it appears that this flag has no effect other than making the quad invisible.
Stairs
This is applied to the invisible ramp quad that covers the stairs. In general this flag is also applied to the visible stairs geometry but there are some exceptions (errors? see level 19 stairs).
No occlusion
This flag tells the octtree raycaster to ignore the quad when doing ray/quad intersections. This is tipically used for small quads that are unlikely to affect the overall environment visibility.
Projection plane flags
These 2 flags can be 00, 01, 10 and 11. That means the values 0,1,2 and 3 which have the following meanings:
  • 0 - No projection plane specified. One can be computed if needed. Never used in files, may slow down the game if used.
  • 1 - Project quad on XY plane.
  • 2 - Project quad on XZ plane.
  • 3 - Project quad on YZ plane.
The projection plane is used to determine if a point is in a quad (this point is usually the result of an intersection between a ray and the quad plane).
Grid ignore
Appears to be unused. Its likely purpose is to mark quads that don't count as obstacles in the pathfinding grid.
Danger
Appears to be unused. Its likely purpose is to create danger areas in the pathfinding grids. Usually there's a trigger volume nearby that hurts/kills the character. This quads are always invisible.
Invisible
Invisible quads have a couple of different uses:
  • block player access to some parts of the environment
  • stairs ramp
  • collision geometry (used by some "complex" furniture)
  • danger quads (see above)
  • some other apparently useless quads
Furniture
Set for all quads that belong to a furniture object. It doesn't appear to be used. It is also redundant since all the furniture quads have an object id.
No decal
Prevents the creation of decals on the quad. Set for door quads because the decals would disappear when the door opens. That's why shooting a door doesn't leave a mark.
ONI BINARY DATA
AGQC << Other file types >> AGQR
AGQG : Gunk Quad General Array
Level file