I don't need to test my programs. I have an error-correcting modem.

Difference between revisions of "UE3:GameInfo (UT3)"

From Unreal Wiki, The Unreal Engine Documentation Site
Jump to: navigation, search
m (PendingMatch)
m (Native functions: added missing member)
 
Line 93: Line 93:
  
 
===Native functions===
 
===Native functions===
 +
====CurrentPlayerCount====
 +
{{code|native function [[int]] '''CurrentPlayerCount''' ()}}
 +
 +
<!-- enter function description -->
 +
 
====DoNavFearCostFallOff====
 
====DoNavFearCostFallOff====
 
{{code|final native function '''DoNavFearCostFallOff''' ()}}
 
{{code|final native function '''DoNavFearCostFallOff''' ()}}

Latest revision as of 01:52, 16 August 2009

UT3 Object >> Actor >> Info >> GameInfo
Package: 
Engine
Direct subclasses:
DemoGame, UTGame
This class in other games:
RTNP, U1, UT, UT2004, UE2Runtime, U2, U2XMP, UT2003, UDK

GameInfo.

The GameInfo defines the game being played: the game rules, scoring, what actors are allowed to exist in this game type, and who may enter the game. While the GameInfo class is the public interface, much of this functionality is delegated to several classes to allow easy modification of specific game components. These classes include GameInfo, AccessControl, Mutator, BroadcastHandler, and GameRules. A GameInfo actor is instantiated when the level is initialized for gameplay (in C++ UGameEngine::LoadMap() ). The class of this GameInfo actor is determined by (in order) either the URL ?game=xxx, or the DefaultGame entry in the game's .ini file (in the Engine.Engine section), unless its a network game in which case the DefaultServerGame entry is used. The GameType used can be overridden in the GameInfo script event SetGameType(), called on the game class picked by the above process.

Copyright 1998-2008 Epic Games, Inc. All Rights Reserved.

Properties[edit]

See GameInfo properties.

Delegates[edit]

CanUnpause[edit]

delegate bool CanUnpause ()

Default delegate that provides an implementation for those that don't have special needs other than a toggle

Functions[edit]

Static events[edit]

SetGameType[edit]

static event class<GameInfoSetGameType (string MapName, string Options)


Other static functions[edit]

AllowMutator[edit]

static function bool AllowMutator (string MutatorClassName)


GetIntOption[edit]

static function int GetIntOption (string Options, string ParseString, int CurrentValue)


GetKeyValue[edit]

static function GetKeyValue (string Pair, out string Key, out string Value)


GrabOption[edit]

static function bool GrabOption (out string Options, out string Result)


HasOption[edit]

static function bool HasOption (string Options, string InKey)


ParseKillMessage[edit]

static function string ParseKillMessage (string KillerName, string VictimName, string DeathMessage)


ParseMessageString[edit]

static function string ParseMessageString (Controller Who, string Message)


ParseOption[edit]

static function string ParseOption (string Options, string InKey)


UseLowGore[edit]

static function bool UseLowGore (WorldInfo WI)


Exec functions[edit]

KillBots[edit]

exec function KillBots ()


Native functions[edit]

CurrentPlayerCount[edit]

native function int CurrentPlayerCount ()


DoNavFearCostFallOff[edit]

final native function DoNavFearCostFallOff ()

Update navigation point fear cost fall off.

GetNetworkNumber[edit]

native function string GetNetworkNumber ()


GetNextPlayerID[edit]

native final function int GetNextPlayerID ()


SwapPlayerControllers[edit]

native final function SwapPlayerControllers (PlayerController OldPC, PlayerController NewPC)

used to swap a viewport/connection's PlayerControllers when seamless travelling and the new gametype's controller class is different than the previous includes network handling

Parameters:

  • OldPC - the old PC that should be discarded
  • NewPC - the new PC that should be used for the player

Events[edit]

AcceptInventory[edit]

event AcceptInventory (Pawn PlayerPawn)


AddDefaultInventory[edit]

event AddDefaultInventory (Pawn P)


Broadcast[edit]

event Broadcast (Actor Sender, coerce string Msg, optional name Type)


BroadcastLocalized[edit]

event BroadcastLocalized (Actor Sender, class<LocalMessageMessage, optional int Switch, optional PlayerReplicationInfo RelatedPRI_1, optional PlayerReplicationInfo RelatedPRI_2, optional Object OptionalObject)


BroadcastLocalizedTeam[edit]

event BroadcastLocalizedTeam (int TeamIndex, Actor Sender, class<LocalMessageMessage, optional int Switch, optional PlayerReplicationInfo RelatedPRI_1, optional PlayerReplicationInfo RelatedPRI_2, optional Object OptionalObject)


GameEnding[edit]

event GameEnding ()


GetBeaconText[edit]

event string GetBeaconText ()


GetSeamlessTravelActorList[edit]

event GetSeamlessTravelActorList (bool bToEntry, out array<ActorActorList)

called on server during seamless level transitions to get the list of Actors that should be moved into the new level PlayerControllers, Role < ROLE_Authority Actors, and any non-Actors that are inside an Actor that is in the list (i.e. Object.Outer == Actor in the list) are all autmoatically moved regardless of whether they're included here only dynamic (!bStatic and !bNoDelete) actors in the PersistentLevel may be moved (this includes all actors spawned during gameplay) this is called for both parts of the transition because actors might change while in the middle (e.g. players might join or leave the game)

Parameters:

  • bToEntry - true if we are going from old level -> entry, false if we are going from entry -> new level
  • ActorList - out) list of actors to maintain

See: also PlayerController::GetSeamlessTravelActorList() (the function that's called on clients)

HandleSeamlessTravelPlayer[edit]

event HandleSeamlessTravelPlayer (out Controller C)

handles reinitializing players that remained through a seamless level transition called from C++ for players that finished loading after the server

Parameters:

  • C - the Controller to handle

InitGame[edit]

event InitGame (string Options, out string ErrorMessage)


KickIdler[edit]

event KickIdler (PlayerController PC)


Login[edit]

event PlayerController Login (string Portal, string Options, out string ErrorMessage)


MatineeCancelled[edit]

event MatineeCancelled ()

Called when this PC is in cinematic mode, and its matinee is cancelled by the user.

PostBeginPlay[edit]

event PostBeginPlay ()

Overrides: Actor.PostBeginPlay


PostCommitMapChange[edit]

event PostCommitMapChange ()

Called from C++'s CommitMapChange after unloading previous level and loading new level+sublevels

PostLogin[edit]

event PostLogin (PlayerController NewPlayer)


PostSeamlessTravel[edit]

event PostSeamlessTravel ()

called after a seamless level transition has been completed on the *new* GameInfo used to reinitialize players already in the game as they won't have *Login() called on them

PreBeginPlay[edit]

event PreBeginPlay ()

Overrides: Actor.PreBeginPlay


PreCommitMapChange[edit]

event PreCommitMapChange (string PreviousMapName, string NextMapName)

Called from C++'s CommitMapChange before unloading previous level

Parameters:

  • PreviousMapName - Name of the previous persistent level
  • NextMapName - Name of the persistent level being streamed to

PreExit[edit]

event PreExit ()

Engine is shutting down.

PreLogin[edit]

event PreLogin (string Options, string Address, out string ErrorMessage)


Reset[edit]

event Reset ()

Overrides: Actor.Reset


Timer[edit]

event Timer ()

Overrides: Actor.Timer


Other instance functions[edit]

See GameInfo instance functions.

States[edit]

PendingMatch[edit]

This state is used to change the flow of start/end match to handle arbitration.

Basic flow of events:

  • Server prepares to start the match and tells all clients to register arbitration
  • Clients register with arbitration and tell the server when they are done
  • Server checks for all clients to be registered and kicks any clients if they don't register in time.
  • Server registers with arbitration and the match begins
  • Match ends and the server tells connected clients to write arbitrated stats
  • Clients write stats and notifies server of completion
  • Server writes stats and ends the match

Modifiers: auto

PendingMatch.EndState[edit]

event EndState (name NextStateName)

Overrides: Object.EndState (global)

Called immediately before going out of the current state, while within the GotoState() call that caused the state change, and before BeginState() is called within the new state.

PendingMatch.ArbitrationRegistrationComplete[edit]

function ArbitrationRegistrationComplete (bool bWasSuccessful)

Overrides: ArbitrationRegistrationComplete (global)

Callback from the server that starts the match if the registration was successful. If not, it goes back to the menu

Parameters:

  • bWasSuccessful - whether the registration worked or not

PendingMatch.ArbitrationTimeout[edit]

function ArbitrationTimeout ()

Handles kicking any clients that haven't completed handshaking

PendingMatch.MatchIsInProgress[edit]

function bool MatchIsInProgress ()

Overrides: MatchIsInProgress (global)


PendingMatch.ProcessClientRegistrationCompletion[edit]

function ProcessClientRegistrationCompletion (PlayerController PC, bool bWasSuccessful)

Overrides: ProcessClientRegistrationCompletion (global)

Removes the player controller from the pending list. Kicks that PC if it failed to register for arbitration. Starts the match if all clients have completed their registration

Parameters:

  • PC - the player controller to mark as done
  • bWasSuccessful - whether the PC was able to register for arbitration or not

PendingMatch.RegisterServerForArbitration[edit]

function RegisterServerForArbitration ()

Overrides: RegisterServerForArbitration (global)

Does the registration for the server. This must be done last as it includes all the players info from their registration

PendingMatch.StartArbitratedMatch[edit]

function StartArbitratedMatch ()

Overrides: StartArbitratedMatch (global)

Empty implementation of the code that starts an arbitrated match

PendingMatch.StartArbitrationRegistration[edit]

function StartArbitrationRegistration ()

Overrides: StartArbitrationRegistration (global)

Kicks off the async tasks of having the clients register with arbitration before the server does. Sets a timeout for when all slow to respond clients get kicked

PendingMatch.StartMatch[edit]

function StartMatch ()

Overrides: StartMatch (global)

Tells all of the currently connected clients to register with arbitration. The clients will call back to the server once they have done so, which will tell this state to see if it is time for the server to register with arbitration.