1
0
KF2-Dev-Scripts/Engine/Classes/SeqAct_ActorFactory.uc

128 lines
3.5 KiB
Ucode
Raw Normal View History

2020-12-13 18:01:13 +03:00
/**
* Copyright 1998-2013 Epic Games, Inc. All Rights Reserved.
*/
class SeqAct_ActorFactory extends SeqAct_Latent
native(Sequence);
cpptext
{
virtual void PostEditChangeProperty(FPropertyChangedEvent& PropertyChangedEvent);
virtual void Activated();
virtual UBOOL UpdateOp(FLOAT DeltaTime);
virtual void DeActivated();
virtual void Spawned(UObject *NewSpawn);
/**
* Checks any of the bEnabled inputs and sets the new value.
*/
void CheckToggle()
{
if (InputLinks(1).bHasImpulse)
{
bEnabled = TRUE;
}
else
if (InputLinks(2).bHasImpulse)
{
bEnabled = FALSE;
}
else
if (InputLinks(3).bHasImpulse)
{
bEnabled = !bEnabled;
}
}
};
enum EPointSelection
{
/** Try each spawn point in a linear method */
PS_Normal,
/** Pick the first available randomly selected point */
PS_Random,
/** PS_Normal, but in reverse */
PS_Reverse,
};
/** Is this factory enabled? */
var() bool bEnabled;
/** Is this factory currently in the process of spawning? */
var bool bIsSpawning;
/** Type of actor factory to use when creating the actor */
var() export editinline ActorFactory Factory;
/** Method of spawn point selection */
var() EPointSelection PointSelection;
/** Set of points where Objects will be spawned */
var() array<Actor> SpawnPoints;
/** The position where Objects will be spawned, if SpawnPoints is empty */
var() array<vector> SpawnLocations;
/** The orientation of spawned Objects, if SpawnPoints is empty */
var() array<vector> SpawnOrientations;
/** Number of actors to create */
var() int SpawnCount;
/** Delay applied after creating an actor before creating the next one */
var() float SpawnDelay;
/** Prevent spawning at locations with bBlockActors */
var() bool bCheckSpawnCollision;
/** Last index used to spawn at, for PS_Normal/PS_Reverse */
var int LastSpawnIdx;
/** Current index used to spawn at */
var int CurrentSpawnIdx;
/** Number of actors spawned so far */
var int SpawnedCount;
/** Remaining time before attempting the next spawn */
var float RemainingDelay;
/**
* Return the version number for this class. Child classes should increment this method by calling Super then adding
* a individual class version to the result. When a class is first created, the number should be 0; each time one of the
* link arrays is modified (VariableLinks, OutputLinks, InputLinks, etc.), the number that is added to the result of
* Super.GetObjClassVersion() should be incremented by 1.
*
* @return the version number for this specific class.
*/
static event int GetObjClassVersion()
{
return Super.GetObjClassVersion() + 0;
}
defaultproperties
{
ObjName="Actor Factory"
ObjCategory="Actor"
InputLinks(0)=(LinkDesc="Spawn Actor")
InputLinks(1)=(LinkDesc="Enable")
InputLinks(2)=(LinkDesc="Disable")
InputLinks(3)=(LinkDesc="Toggle")
VariableLinks.Empty
VariableLinks(0)=(ExpectedType=class'SeqVar_Object',LinkDesc="Spawn Point",PropertyName=SpawnPoints)
VariableLinks(1)=(ExpectedType=class'SeqVar_Object',LinkDesc="Spawned",MinVars=0,bWriteable=true)
VariableLinks(2)=(ExpectedType=class'SeqVar_Int',LinkDesc="Spawn Count",PropertyName=SpawnCount)
VariableLinks(3)=(ExpectedType=class'SeqVar_Vector',LinkDesc="Spawn Location",PropertyName=SpawnLocations)
VariableLinks(4)=(ExpectedType=class'SeqVar_Vector',LinkDesc="Spawn Direction",PropertyName=SpawnOrientations)
SpawnCount=1
SpawnDelay=0.5f
bCheckSpawnCollision=TRUE
LastSpawnIdx=-1
CurrentSpawnIdx=-1
bEnabled=TRUE
}