DialogueTrigger¶
A zone where a SetText call starts in dialogue mode using a map dialogue line id. It can either unconditionally trigger as a one shot call on the first Update cycle or trigger via OnTriggerStay that starts the call when the player collides with it with the option to destroy the NPCControl after.
Data Arrays¶
data[0]
: The map dialogue line id to call SetText in dialogue mode when triggereddata[1]
: If not 0 or doesn't exist, the object is destroyed after triggering it, only applicable ifdata[2]
doesn't exist or isn't 1data[2]
: If 1, the SetText call is unconditionally started on the first Update cycle before destroying this NPCControl making it a one shot call. This is optional, if it doesn't exist, this feature is disabled.
Additional data¶
regionalflag
: If it's positive, it's the regionalflag slot that is set to true when the player collides with this object.activationflag
: If it's above 0, the flag slot that is set to true when the player collides with this object. It is not possible to specify 0 and will be treated the same as not providing a value.
Setup¶
A few adjustements occurs:
- The entity.
alwaysactive
is set to true - The gameObject's isStatic is set to true
- The entity.
rigid
is placed in kinematic mode without gravity nointeract
is set to true- The layer is set to 0 (default)
- The
scol
is disabled
Update¶
Updates are disabled if data[2]
doesn't exist or isn't -1 or we are in pause
, minipause
or inevent
. All Update does is manage the unconditional one shot trigger feature.
If the above is fufilled:
- CancelAction is called on the player
- SetText is called in dialogue mode using the map dialogue line id
data[0]
:- fonttype of 0 (
BubblegumSans
) - Standard messagebreak as
linebreak
- No
tridimensional
- No local
position
change, nocamoffset
change orsize
change - This transform as the
parent
- No
caller
- fonttype of 0 (
If the current map supports the global commands system, the map's currentline
is set to data[0]
.
Finally, this object gets destroyed.
OnTriggerStay¶
This does nothing if any of the following is true:
- The other gameObject isn't the player
- We are
inevent
- We are in a
pause
hit
is true
The regionalflag slot at regionalflags
and the flag slot at activationflag
are set to true.
If we aren't in a minipause
, a WaitForEvent coroutine starts which does the following:
hit
is set to true (this prevents a second trigger)- We enter a
minipause
- Yield frames until
switchcooldown
expires - Yield another additional frame
- Call CancelAction on the player
- Yield a frame
- Calls SetText in dialogue mode with the input string being the one resolved by the dialogue line id contained in
data[0]
:BubblegumSans
as the fonttype- The default
messagebreak
as the linebreak - No tridimensional
- No position and camera offsets
- Size of Vector3.one
- This as the parent
- No caller
hit
is set to false- If
data[1]
isn't 0 or doesn't exist, the object is destroyed