XML:BINA/OBJC/NEUT: Difference between revisions

m
link fixes
m (linking to LSI)
m (link fixes)
 
(4 intermediate revisions by the same user not shown)
Line 1: Line 1:
{{XML_OBJC_Header | type=NEUT | prev=MELE | next=PART | name=Neutral behavior list }}
{{XML_OBJC_Header | prev=MELE | type=NEUT | next=PART | name=Neutral}}


__TOC__
__TOC__


==General information==
* The XML on this page is based on OniSplit '''v0.9.61.0'''.
* BINACJBONeutral is level-specific (level''x''_Final.dat).
* Press the action key to talk with a character (if possible). The interaction depends on what ID that character has.


===general information===
==File structure==
* The xml code on this page is based on onisplit '''v0.9.61.0'''
* '''BINACJBONeutral.oni''' is level specific. (It can be found in AE/AEInstaller/vanilla/level'''X'''_Final.dat)
* Press control to talk with a character (if possible). The interaction depends on what id that character has.
 
 
===file structure===
  <?xml version="1.0" encoding="utf-8"?>
  <?xml version="1.0" encoding="utf-8"?>
  <Oni>
  <Oni>
Line 18: Line 16:
  </Oni>
  </Oni>


'''''[...]''''' means at least one neutral behavior block. Paste all a behavior data into there (this includes <NEUT Id="..."> and </NEUT> tag).
'''''[...]''''' means at least one neutral behavior block. Paste all your behavior data into there (this includes the <NEUT Id="..."> and </NEUT> tag).
 
'''example'''


'''Example'''
         <NEUT Id="1853">
         <NEUT Id="1853">
             <Header>
             <Header>
Line 70: Line 67:
         </NEUT>
         </NEUT>


 
==Tags==
===tags===
{| class="wikitable" width="100%"
{| class="wikitable" width="100%"
!width=150px| XML tag
!width=150px| XML tag
!width=120px| content type
!width=120px| Content type
! description
! Description
|-
| <?xml version="1.0" encoding="utf-8"?>
| flag, float
| Don't change this.
|-
|valign=top| <Oni>
| -
|
|-
|-
|valign=top| <ObjectCollection>
|valign=top| <ObjectCollection>
Line 91: Line 79:
|valign=top| <NEUT Id="1853">
|valign=top| <NEUT Id="1853">
| integer
| integer
| Id doesn't matter here.
| The ID here doesn't matter.
|-
|-
| <Header>
| <Header>
Line 108: Line 96:
| <Position>
| <Position>
| float x3
| float x3
| x y z position, useless here
| XYZ position, unused
|-
|-
| <Rotation>
| <Rotation>
| float x3
| float x3
| x y z rotation, useless here
| XYZ rotation, unused
|-
|-
| <OSD>
| <OSD>
Line 120: Line 108:
| <Name>
| <Name>
| char[32]
| char[32]
| A name of the NEUT profile. Used by a [[BSL]] command '''ai2_neutralbehavior'''
| The name of the NEUT profile. Used by [[BSL]] command '''ai2_neutralbehavior'''.
|-
|-
| <NeutralId>
| <NeutralId>
| integer
| integer
| used by [[XML:BINA/OBJC/CHAR|BINA/OBJC/CHAR]] and [[XML:BINA/OBJC/MELE|BINA/CJBO/MELE]]
| Used by [[XML:BINA/OBJC/CHAR|BINA/OBJC/CHAR]] and [[XML:BINA/OBJC/MELE|BINA/OBJC/MELE]].
|-
|-
|valign=top| <Flags>
|valign=top| <Flags>
|valign=top| flag  
|valign=top| flag  
|
|
*'''None''' - no flags utilized
*'''None''' - No flags utilized
*'''NoResume''' - if the conversation is interrupted, NEUT behavior terminates. Conversation cannot be reinitaitated.
*'''NoResume''' - If the conversation is interrupted, NEUT behavior terminates. Conversation cannot be re-initiated.
*'''NoResumeAfterGive''' - interrupted conversation can be reinitiated, but only if so far no executed dialog line had the flag "GiveItems", otherwise NEUT behavior terminates.<BR>Also, if some dialog line is interrupted AFTER the dialog line with "GiveItems" flag, then the sound file of the interrupted dialog line is fully played (is not stopped by the conversation interruption). Maybe a bug?
*'''NoResumeAfterGive''' - Interrupted conversation can be re-initiated, as long as we have not reached a line of dialogue which had the flag "GiveItems". Also, if a line of dialogue is interrupted AFTER the line with the "GiveItems" flag, then the sound file of the interrupted dialogue line is fully played (is not stopped by the conversation interruption). Maybe a bug?
*'''Uninterruptible''' - probably should disable player's option to interrupt the conversation by some offensive action (punch, kick), but tests are negative. Maybe defunct?
*'''Uninterruptible''' - Running, crouching or jumping will not be able to interrupt the conversation; only attacking the NPC will.
|-
|-
| <Ranges>
| <Ranges>
Line 140: Line 128:
| <Trigger>
| <Trigger>
| float
| float
| A distance between the AI2 character and the player character when the NEUT behavior mechanics kick in.<BR>
| The distance between the AI and the player character when the NEUT behavior mechanics kick in.
Outside of this distance, NEUT behavior of the given AI2 character does not execute.
|-
|-
| <Talk>
| <Talk>
Line 147: Line 134:
|
|
A threshold distance for approaching the player character:
A threshold distance for approaching the player character:
*If '''"distance to player" > "Talk range"''' then NEUT driven AI2 character keeps approaching the player character.
*If '''"distance to player" > "Talk range"''' then the NEUT-driven AI keeps approaching the player character.
*If  '''"distance to player" =< "Talk range"''' then NEUT driven AI2 character stands still, attempts to rotate in order to keep looking at the player character and keeps repeating the TRAM animType=230 (0xE6, Hail) + Speech "Trigger" (see tag below) in a 5 second interval.
*If  '''"distance to player" <= "Talk range"''' then the NEUT-driven AI stands still, rotates in order to keep looking at the player, and keeps repeating the "Hail" anim type and playing the <Trigger> speech line (see below) at a 5 second interval.
*If  '''"distance to player" =< "Talk range"''' AND also '''"distance to player" =< 35 game world units''' (empiric obesrvation), then the conversation can be triggered by facing the NEUT driven AI2 character and pressing the action key.
*If  '''"distance to player" <= "Talk range"''' AND '''"distance to player" <= 35 game world units''' (based on observation), then the conversation can be triggered by facing the NEUT-driven AI and pressing the action key.
|-
|-
| <Follow>
| <Follow>
| float
| float
|  
|  
An allowed "travel distance" for the NEUT driven AI2 character, starting from the moment player entered the '''Trigger range'''.<BR>NEUT driven AI2 character is allowed to translocate only this specified distance from its pre-trigger location before it gives up on chasing the player character.<BR>
An "allowed travel" distance for the NEUT-driven AI, starting from the moment the player entered the <Trigger> range (see above). The NEUT-driven AI is allowed to travel only this far from its pre-trigger location before it gives up on chasing the player character. When the <Follow> distance is expended, the NEUT behavior for the given character is terminated and control over the character is handed to some other AI2 system (for example the Patrol Path system). Of course if the player again enters the <Trigger> range, the NEUT mechanics kick in again (with a reset <Follow> distance to expend).
When '''Follow distance''' is depleted, NEUT behavior for given AI2 character is terminated and control over AI2 character is handed to some other AI2 system (for example the Patrol Path system).<BR>Of course if the player character again enters the '''Trigger range''', then NEUT mechanics kick in again (with fresh Follow distance to deplete).
|-
|-
| <Enemy>
| <Enemy>
| float
| float
|  
|  
A range in which NEUT driven AI2 character will react on present enemies, even those which are behind its back. Who is considered "enemy" is defined according to Oni team affiliations.<BR>
The range within which the NEUT-driven AI will react to the presence of enemies (even those behind its back!). Who is considered an "enemy" is defined according to Oni's team affiliations.<BR>
*If some enemy is present within the '''Enemy range''' prior to the conversation, then conversation cannot be triggered till the enemy is either outside of '''Enemy range''' or neutralized.
*If an enemy is within the <Enemy> range prior to the conversation, then the conversation cannot begin till the enemy is either outside of that range or neutralized.
*If some enemy gets inside the '''Enemy range''' while the conversation is running, then the conversation is stopped and the '''Speech Enemy''' (see tag below) is played.
*If an enemy gets inside the <Enemy> range while the conversation is occurring, the conversation is stopped and the <Enemy> speech sound (see below) is played.


The further reaction of the NEUT driven AI2 character on enemy differs acording to [[CHAR]] setup - it can start cowering in fear (NonCombatant flag is set) or go attack the enemy (default setup).
The further reaction of the NEUT-driven AI to the enemy depends on their [[CHAR]] settings — it can start cowering in fear (NonCombatant flag is set) or go attack the enemy (default setup).
|-
|-
| <Speech>
| <Speech>
Line 172: Line 158:
|valign=top| <Trigger>
|valign=top| <Trigger>
|valign=top| char[32]
|valign=top| char[32]
|valign=top| Speech sound for hailing the player.
|valign=top| Speech sound for hailing the player. If  '''"distance to player" <= "Talk range"''' then the NEUT-driven AI stands still, rotates in order to keep looking at the player, and keeps repeating the Hail anim type and playing the speech sound specified in this <Trigger> tag at a 5 second interval.
If  '''"distance to player" =< "Talk range"''' then NEUT driven AI2 character stands still, attempts to rotate in order to keep looking at the player character and keeps repeating the TRAM animType=230 (0xE6, Hail) + this '''Speech "Trigger"''' in a 5 second interval.<BR>
 
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
examples of such OSBD amb files:
 
Examples of such OSBD .amb files:
: civfem_trigger
: civfem_trigger
: hey_konoko
: hey_konoko
Line 184: Line 171:
|valign=top| <Abort>
|valign=top| <Abort>
|valign=top| char[32]
|valign=top| char[32]
|valign=top| Speech sound for the player interruption of the conversation.<BR>
|valign=top| Speech sound for when player interrupts the conversation. This sound is played when the player aborts the conversation by performing some offensive action such as a punch/kick or by breaking away in the middle of the conversation with a movement.
This sound is played when the player aborts the conversation by preforming some offensive action (punch, kick) in the middle of the conversation.<BR>
 
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
examples of such OSBD amb files:
 
Examples of such OSBD .amb files:
: civfem_abort
: civfem_abort
: see_you_later
: see_you_later
Line 196: Line 184:
|valign=top| <Enemy>
|valign=top| <Enemy>
|valign=top| char[32]
|valign=top| char[32]
|valign=top| Speech sound for conversation interruption because of some enemy is present within the '''Enemy range'''.<BR>
|valign=top| Speech sound to play when conversation is interrupted due to an enemy entering the <Enemy> range.
This sound is played if some enemy gets inside the '''Enemy range''' in the middle of the conversation.<BR>
 
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
examples of such OSBD amb files:
 
Examples of such OSBD .amb files:
: civfem_enemy
: civfem_enemy
: what_the
: what_the
Line 212: Line 201:
| <AfterTalk>
| <AfterTalk>
| char[32]
| char[32]
| A name of a BSL function. The function will will be executed after the conversation is finished.<BR>
| A name of a BSL function. The function will will be executed after the conversation is finished. The function in BSL can have an optional parameter of type ''string'' which receives the name of the NEUT-driven AI.
The function in BSL has an optional parameter ('''string''' type) - name of the NEUT driven AI2 character.
|-
|-
| <Rewards>
| <Rewards>
| -
| -
| You can get rewards for saving people. A reward can be a weapon, ammo, cells, hypos, shield, phase cloak, and [[LSI]].
| You can get rewards for saving people. A reward can be a weapon, ballistic ammo, energy cells, hypos, a shield, a phase cloak, or an [[LSI]].
|-
|-
| <WeaponClass>
| <WeaponClass>
| char[32]
| char[32]
| Any weapon, filename without prefix ONWC and suffix .oni; for example "w6_vdg"
| Any weapon. Filename without prefix ONWC and suffix .oni, for example "w6_vdg".
|-
|-
| <Ammo>
| <Ammo>
Line 237: Line 225:
|valign=top| <Other>
|valign=top| <Other>
|valign=top| flag
|valign=top| flag
|valign=top| Combinations of flags are possible. Flags:
|valign=top| These flags can be combined:
*Shield
*Shield
*Invisibility
*Invisibility
Line 248: Line 236:
| <DialogLine>
| <DialogLine>
| -
| -
| There can be multiple dialog lines.
| There can be multiple dialogue lines.
|-
|-
|valign=top| <Flags>
|valign=top| <Flags>
|valign=top| flag
|valign=top| flag
| Combinations of flags are possible. Flags:
| These flag can be combined:
*'''None''' - no special flags.
*'''None''' - No special flags.
*'''IsPlayer''' - reverses roles of Anim and OtherAnim - now Anim is applied on the player character and OtherAnim is applied on the NEUT driven AI2 character.
*'''IsPlayer''' - Reverses the subjects of Anim and OtherAnim now Anim is applied to the player character and OtherAnim is applied to the NEUT-driven AI.
*'''GiveItems''' - will make conversation participants play respective give and take animations AND will add item(s) to the player character's inventory. This exchange cannot be interrupted by player's input.
*'''GiveItems''' - Will make the conversation participants play their respective give and take animations AND will add item(s) to the player's inventory. This exchange cannot be interrupted by player's input.
*'''AnimOnce''' - NEUT driven AI2 character will play its prescribed animType only once during the dialog line.
*'''AnimOnce''' - NEUT-driven AIs will play their prescribed anim type only once during the dialogue line.
*'''OtherAnimOnce''' - player character will play its prescribed animType only once during the dialog line.
*'''OtherAnimOnce''' - player character will play its prescribed anim type only once during the dialogue line.
|-
|-
|valign=top| [[XML:StNA#animation_types|<Anim>]]
|valign=top| [[XML:StNA#Animation_types|<Anim>]]
|valign=top| integer
|valign=top| integer
| AnimType ID of the TRAM applied on NEUT driven AI2 character during this dialog line.<BR>Any TRAM which has animState="Standing" and is present in a NEUT driven AI2 character's [[TRAC]] should be valid.
| The anim type ID of the TRAM applied to the NEUT-driven AI during this dialogue line. Any TRAM which has the anim state "Standing" and is present in a NEUT-driven AI's [[TRAC]] should be valid.
: 0 (None)
: 0 (None)
: 200 (Act_No)
: 200 (Act_No)
Line 269: Line 257:
: 204 (Act_Shout)
: 204 (Act_Shout)
|-
|-
| [[XML:StNA#animation_types|<OtherAnim>]]
| [[XML:StNA#Animation_types|<OtherAnim>]]
| integer
| integer
| AnimType ID of the TRAM applied on the player character during this dialog line.<BR>Any TRAM which has animState="Standing" and is present in the player character's [[TRAC]] should be valid.
| Anim type ID of the TRAM applied to the player character during this dialogue line. Any TRAM which has the anim state "Standing" and is present in the player character's [[TRAC]] should be valid.
|-
|-
|valign=top| <SpeechName>
|valign=top| <SpeechName>
|valign=top| char[32]
|valign=top| char[32]
|The actual sound played during the dialog line. Length of this sound file defines length of the dialog line.
|The actual sound played during the dialogue line. The length of this sound file determines the length of the dialogue line's effect in-game.
 
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
<font style="color:#777777">OSBD</font>file<font style="color:#777777">.amb.oni</font> (without file pre-/suffix)
for example:
 
For example:
: talking
: talking
: civfem_gift_weapon
: civfem_gift_weapon