Cogito, ergo sum

Legacy:TeamVehicleFactory

From Unreal Wiki, The Unreal Engine Documentation Site
Revision as of 21:36, 31 January 2006 by Moofed (Talk)

Jump to: navigation, search
UT2004 :: Actor >> SVehicleFactory >> TeamVehicleFactory (custom)

This custom actor really duplicates much of the functionality of the ONSVehicleFactory subclasses, but the big feature is that nearly any vehicle class can be spawned. Although this actor cannot display the selected vehicle class in the editor, it does offer added controls that mappers for VCTF or other vehicle gametypes might want.

Features

  • NEW! The ability to spawn random vehicles from a list of vehicle classes
  • The ability to spawn nearly any vehicle class in gametypes that allow vehicles
  • The ability to trigger PreSpawn and (Post)Spawn events
  • The option to allow the vehicle to spawn over and crush other actors
  • The option to use this as either a triggerable or an automatic (timed) vehicle factory.
  • Greater control over spawn timing

Notes

  • If you use a TeamVehicleFactory "as is" in your custom map, please credit me in the readme file of the map. (SuperApe)
  • You have to supply spawning effects and sounds, via ScriptedTrigger, Emitter and the like. This is meant to allow flexibilty in the ways you want vehicles to spawn. An example VCTF map posted on this UP Forum thread gives my suggestion for spawning particles and sound. (It appears similar to pickup spawning.)
  • Turrets that are spawned automatically get an AIController. They are auto turrets; firing at enemies, or if set to neutral (team 255), firing at any non-neutral controlled pawn it detects.
  • The AS Spacefighters are spawned with a minimum velocity that makes them impractical to use. However, a custom launcher for these is easy to make with a TryToDrive() function.
  • This has a slightly larger bBlocked check radius than ONSVehicleFactory. ( 1.33 : 1.25 )

Properties

Main

int TeamNum 
Team Number to be set on spawn. 0= red, 1= blue, 255= neutral / none
bool bPlayerControl 
Only player instigators can trigger.
bool bAutoSpawn 
Will spawn at regular intervals. The triggering ability is disabled.
int RespawnTime 
Interval to wait before AutoSpawning.
name PreSpawnEvent 
Event to trigger before spawn.
int PreSpawnTime 
Time before spawn to trigger event. Will begin event this many seconds before the factory is set to AutoSpawn.
name SpawnEvent 
Event to trigger after spawn. A post spawn event.
bool bCrushable 
Allow spawning over colliding actors. Note: Turrets will normally spawn in collision with other actors, spawned vehicles will generally move out of the way.
int RetrySpawnTime 
Interval to wait if bBlocked.
bool bRandomFlip 
Neutral vehicles may face backwards.
bool bRandomSpawn 
Will spawn random vehicle class.
struct class<Vehicle> SpawnedVehicle 
Selected random vehicle class.
array<SpawnedVehicle> RandomVehicles 
List for random vehicle spawn.

Hidden

bool bWaiting 
Waiting to spawn.
int FactoryTime 
Time last spawn. (in Level.TimeSeconds)
bool bPreSpawn 
Should trigger PreSpawnEvent next.

Code

//==================================================================================
// TeamVehicleFactory.
// Spawn any Vehicle or Turret, set Team, pre & post spawn Events, timing, and more.
// Glenn 'SuperApe' Storm -- June 2004 -- Updated: July 2005
//==================================================================================
class TeamVehicleFactory extends SVehicleFactory
	placeable;
 
var()	int			TeamNum ;			// 0= red, 1= blue, 255= neutral / none
var()	bool		bPlayerControl ; 	// Only player instigators can trigger
 
var()	bool		bAutoSpawn ;		// Will spawn at regular intervals
var()	int			RespawnTime ;		// Interval to wait before AutoSpawning
 
var		bool		bWaiting ;			// About to spawn
var		int			FactoryTime	;		// Time last spawn
 
var()	name		PreSpawnEvent ;		// Event to trigger before spawn
var()	int			PreSpawnTime ; 		// Time before spawn to trigger event
var		bool		bPreSpawn ;			// Should trigger PreSpawnEvent next
var()	name		SpawnEvent ;		// Event to trigger after spawn
 
var()	bool		bCrushable ;		// Allow spawning over colliding actors
var()	int			RetrySpawnTime ;	// Interval to wait if bBlocked
 
var()	bool		bRandomFlip ;		// Neutral vehicles may face backwards
 
var()	bool					bRandomSpawn ;		// Spawn random vehicle class
struct SpawnedVehicle
{
	var()	class<Vehicle>		SpawnVehicle;		// Selected random vehicle class
};
var()	array<SpawnedVehicle>	RandomVehicles ; 	// List for random vehicle spawn
 
 
simulated function PostBeginPlay()
{
	Super.PostBeginPlay();
 
	if ( bAutoSpawn )
		bWaiting = true;
		bPreSpawn = true;
		if ( RespawnTime > 0 )
			FactoryTime = Level.TimeSeconds - RespawnTime + PreSpawnTime;
		else
			FactoryTime = Level.TimeSeconds - PreSpawnTime;
}
 
simulated event Trigger( Actor Other, Pawn EventInstigator )
{
	if ( bAutoSpawn )
		// bAutoSpawn overrides Trigger
		return;
 
	if ( !EventInstigator.IsA('UnrealPawn') && bPlayerControl )
		return;
 
	if ( VehicleCount >= MaxVehicleCount )
		return;
 
	if ( VehicleClass == None || ( bRandomSpawn && RandomVehicles.length > 0 ) )
	{
		Log("TeamVehicleFactory:"@self@"has no VehicleClass");
		return;
	}
 
	bWaiting = true;
	bPreSpawn = true;
	if ( RespawnTime > 0 )
		FactoryTime = Level.TimeSeconds - RespawnTime + PreSpawnTime;
	else
		FactoryTime = Level.TimeSeconds - PreSpawnTime;
}
 
simulated function SpawnItNow()
{
	local 	Vehicle		CreatedVehicle;
	local	bool		bBlocked;
	local	Pawn		P;
	local	float		SV;
 
	bBlocked = false;
 
	if ( VehicleClass != None || ( bRandomSpawn && RandomVehicles.length > 0 ) )
	{
		if ( bRandomSpawn && RandomVehicles.length > 0 )
			VehicleClass = RandomVehicles[ int( FRand() * RandomVehicles.length ) ].SpawnVehicle;
 	    foreach CollidingActors(class'Pawn', P, VehicleClass.default.CollisionRadius * 1.33)
			bBlocked = true;
	}
	else
	{
		Log("TeamVehicleFactory:"@self@"has no VehicleClass");
		return;
	}
 
    if ( bBlocked && !bCrushable )
	{
		bWaiting = true;
		bPreSpawn = true;
		if ( RespawnTime > 0 )
			FactoryTime = Level.TimeSeconds - RespawnTime + RetrySpawnTime + PreSpawnTime;
		else
			FactoryTime = Level.TimeSeconds - RetrySpawnTime + PreSpawnTime;
		return;
	}
    else
		{
			if ( TeamNum == 255 )
			{
				if ( bRandomFlip && Rand(2) == 1 )
					CreatedVehicle = spawn(VehicleClass, , , Location, Rotation + rot(0,32768,0));
				else
					CreatedVehicle = spawn(VehicleClass, , , Location, Rotation);
				// Unlock neutral vehicles
				CreatedVehicle.bTeamLocked = false;
			}
			else
				CreatedVehicle = spawn(VehicleClass, , , Location, Rotation);
			if ( CreatedVehicle != None )
			{
				VehicleCount++;
				CreatedVehicle.Event = Tag;
				CreatedVehicle.ParentFactory = self;
				CreatedVehicle.SetTeamNum(TeamNum);
				TriggerEvent(SpawnEvent, self, None);				
			}
		}
}
 
event VehicleDestroyed(Vehicle V)
{
	Super.VehicleDestroyed(V);
 
	if ( bAutoSpawn )
	{
		bWaiting = true;
		bPreSpawn = true;
		FactoryTime = Level.TimeSeconds;
	}
}
 
simulated function Tick(float DeltaTime)
{
	if ( bWaiting )
	{
		if ( Level.TimeSeconds - FactoryTime < RespawnTime - PreSpawnTime )
			return;
 
		if ( VehicleCount < MaxVehicleCount )
			if ( !bPreSpawn )
			{		
				if ( Level.TimeSeconds - FactoryTime >= RespawnTime )
				{
					bWaiting = false;
					FactoryTime = Level.TimeSeconds;
					SpawnItNow();
				}
			}
			else
			{
				bPreSpawn = false;
				TriggerEvent(PreSpawnEvent, self, None);
			}
	}
}
 
simulated function Reset()
{
    local Vehicle V;
 
    if ( VehicleCount > 0 )
        forEach AllActors ( class 'Vehicle', V )
            if ( V.ParentFactory == self )
                V.Destroy();
 
    Super.Reset();
}

Related Topics

Discussion

SuperApe: Originally this actor included a bForceAllow option that overrode the Level.bAllowVehicles setting. Since the latest patch to UT2004 moved that check up to SVehicle, that will not work anymore. Alas, that very cool option to include vehicles in any gametype would have to be left out. :( Now, I offer it as simply a way to get any vehicle class into gametypes which *do* allow vehicles. Enjoy! :)

MythOpus: Why couldn't you just set the bAllowVehicles property through the code?

SuperApe: You mean like this?

if ( !Level.Game.bAllowVehicles && bForceAllow )
    Level.Game.bAllowVehicles = true;

MythOpus: Yes, something like that :P :) Good luck.

SuperApe: No luck. I believe the new patch for 2k4 moved many of the bAllowVehicle checks either higher in the actor heirarchy, or like into SVehicle itself.

SuperApe: A request has been made by a mapper for Red Orchestra to include a Reset() function for this actor. If you have a triggered version of this factory and the map is reset, any outstanding vehicles are still there. Working...

SuperApe: I've added the Reset() function that should work fine. In fact, I had difficulty duplicating the problem of a stranded vehicle after map reset. Nevertheless, this Reset() function won't hurt and it may solve the problem for the Red Orchestra mapper.

SuperApe: Thanks to a suggestion by ZedMaestro on the BUF, I've added a feature for spawning random vehicle classes. Just set bRandomSpawn = true and the list of possible vehicle classes in RandomVehicles. Also, in relation to the above discussion about forcing to allow vehicles in any gametype, there is a SuperVehicleFactory in testing on the UnrealPlayground forums.

VitalOverdose: when i got cut offline i took a whole buch of the most difficult problems from atari forums and wiki and decided to crack each one as i was gonna be ofline for atleast 4months.your teamvehiclefactory idea was on i decided to have a go at.As far as i can see it does everything you specified in the orignal design spec. i was thinking between us we could come up with an ultimate solution but if not np.

SuperApe: I think I understand the confusion. The TeamVehicleFactory is not a problem which I am trying to find a solution for, it is a custom actor I've posted on the wiki after testing thoroughly and developing somewhere else. I post it here for others to use at their discretion, as a Third-Party component. If you would like to take the code, use it in a custom map, or even expand on it and modify it for specific purposes, that's fine by me. That's why I posted it here. Just remember, the normal etiquette is to give credit for the source in those situations, either in the map's readme file or the code's initial comment block, or both. If you would like help finding a solution to a problem you're having with your own code, I suggest posting (in brief) the problem's details on the Help Desk. Personally, I wasn't at all clear what you wanted help with. But at any rate, that code didn't belong here in the Discussion of this page. Thanks for moving it. :)

Moofed: I noticed the first vehicle that is spawned from a TeamVehicleFactory doesn't have a HeadlightProjector, but all vehicles afterwards do. Not sure what's causing it. :-/

SuperApe: Hmm. I'm not seeing that bug. Headlights are spawned from the vehicle (ONSVehicle) during PostNetBeginPlay(). Can't think of why your first vehicle wouldn't have them when you jump in.

Moofed: Fixed by setting PreSpawnTime=2. I think bDropDetail gets set (and the coronas and projectors not spawned) because the computer is bogged down by the level loading, which happens to be at the same time as the vehicles are spawning when using bAutoSpawn.