This is an automatically generated listing of the Lua map scripting API for version Alpha-310 of OpenRA.
OpenRA allows custom maps and missions to be scripted using Lua 5.1. These scripts run in a sandbox that prevents access to unsafe functions (e.g. OS or file access), and limits the memory and CPU usage of the scripts.
You can access this interface by adding the LuaScript trait to the world actor in your map rules (note, you must replace the spaces in the snippet below with a single tab for each level of indentation):
Rules:
World:
LuaScript:
Scripts: myscript.lua
Map scripts can interact with the game engine in three ways:
- Global tables provide functions for interacting with the global world state, or performing general helper tasks.
They exist in the global namespace, and can be called directly using
<table name>.<function name>
. - Individual actors expose a collection of properties and commands that query information or modify their state.
- Some commands, marked as queued activity, are asynchronous. Activities are queued on the actor, and will run in sequence until the queue is empty or the Stop command is called. Actors that are not performing an activity are Idle (actor.IsIdle will return true). The properties and commands available on each actor depends on the traits that the actor specifies in its rule definitions.
- Individual players expose a collection of properties and commands that query information or modify their state. The properties and commands available on each actor depends on the traits that the actor specifies in its rule definitions.
For a basic guide about map scripts see the Map Scripting
wiki page.
Function | Description |
---|---|
int BuildTime(string type, string queue = nil) | Returns the build time (in ticks) of the requested unit type. An optional second value can be used to exactly specify the producing queue type. |
int Cost(string type) | Returns the cost of the requested unit given by the Valued trait. |
Actor Create(string type, bool addToWorld, LuaTable initTable) | Create a new actor. initTable specifies a list of key-value pairs that defines the initial parameters for the actor's traits. |
int CruiseAltitude(string type) | Returns the cruise altitude of the requested unit type (zero if it is ground-based). |
Function | Description |
---|---|
WAngle East { get; } | 768 units = 90 degrees |
WAngle New(int a) | Create an arbitrary angle. 1024 units = 360 degrees. North is 0. Units increase counter clockwise. Comparison given to degrees increasing clockwise. |
WAngle North { get; } | 0/1024 units = 0/360 degrees |
WAngle NorthEast { get; } | 896 units = 45 degrees |
WAngle NorthWest { get; } | 128 units = 315 degrees |
WAngle South { get; } | 512 units = 180 degrees |
WAngle SouthEast { get; } | 640 units = 135 degrees |
WAngle SouthWest { get; } | 384 units = 225 degrees |
WAngle West { get; } | 256 units = 270 degrees |
Function | Description |
---|---|
void New(Player owner, WPos position, int duration = 750, bool showRadarPings = True) | Creates a new beacon that stays for the specified time at the specified WPos. Does not remove player set beacons, nor gets removed by placing them. Requires the 'PlaceBeacon' trait on the player actor. |
Function | Description |
---|---|
WPos Position { get; set; } | The center of the visible viewport. |
Function | Description |
---|---|
Color Aqua { get; } | FromHex("00FFFF") |
Color Black { get; } | FromHex("000000") |
Color Blue { get; } | FromHex("0000FF") |
Color Brown { get; } | FromHex("A52A2A") |
Color Cyan { get; } | FromHex("00FFFF") |
Color DarkBlue { get; } | FromHex("00008B") |
Color DarkCyan { get; } | FromHex("008B8B") |
Color DarkGray { get; } | FromHex("A9A9A9") |
Color DarkGreen { get; } | FromHex("006400") |
Color DarkOrange { get; } | FromHex("FF8C00") |
Color DarkRed { get; } | FromHex("8B0000") |
Color FromHex(string value) | Create a new color with the specified red/green/blue/[alpha] hex string (rrggbb[aa]). |
Color FromRGB(int red, int green, int blue, int alpha = 255) | Create a new color with the specified red/green/blue/[alpha] values. |
Color Fuchsia { get; } | FromHex("FF00FF") |
Color Gold { get; } | FromHex("FFD700") |
Color Gray { get; } | FromHex("808080") |
Color Green { get; } | FromHex("008000") |
Color LawnGreen { get; } | FromHex("7CFC00") |
Color LightBlue { get; } | FromHex("ADD8E6") |
Color LightCyan { get; } | FromHex("E0FFFF") |
Color LightGray { get; } | FromHex("D3D3D3") |
Color LightGreen { get; } | FromHex("90EE90") |
Color LightYellow { get; } | FromHex("FFFFE0") |
Color Lime { get; } | FromHex("00FF00") |
Color LimeGreen { get; } | FromHex("32CD32") |
Color Magenta { get; } | FromHex("FF00FF") |
Color Maroon { get; } | FromHex("800000") |
Color Navy { get; } | FromHex("000080") |
Color New(int hue, int saturation, int luminosity) | Create a new color with the specified hue/saturation/luminosity. |
Color Olive { get; } | FromHex("808000") |
Color Orange { get; } | FromHex("FFA500") |
Color OrangeRed { get; } | FromHex("FF4500") |
Color Purple { get; } | FromHex("800080") |
Color Red { get; } | FromHex("FF0000") |
Color Salmon { get; } | FromHex("FA8072") |
Color SkyBlue { get; } | FromHex("87CEEB") |
Color Teal { get; } | FromHex("008080") |
Color White { get; } | FromHex("FFFFFF") |
Color Yellow { get; } | FromHex("FFFF00") |
Function | Description |
---|---|
CPos New(int x, int y) | Create a new CPos with the specified coordinates on the ground (layer = 0). |
CPos NewWithLayer(int x, int y, Byte layer) | Create a new CPos with the specified coordinates on the specified layer. The ground is layer 0, other layers have a unique ID. Examples include tunnels, underground, and elevated bridges. |
CPos Zero { get; } | The cell coordinate origin. |
Function | Description |
---|---|
CVec New(int x, int y) | Create a new CVec with the specified coordinates. |
CVec Zero { get; } | The cell zero-vector. |
Function | Description |
---|---|
int CurrentDay { get; } | Get the current day (1-31). |
int CurrentHour { get; } | Get the current hour (0-23). |
int CurrentMinute { get; } | Get the current minute (0-59). |
int CurrentMonth { get; } | Get the current month (1-12). |
int CurrentSecond { get; } | Get the current second (0-59). |
int CurrentYear { get; } | Get the current year (1-9999). |
int GameTime { get; } | Get the current game time (in ticks). |
True on the 31st of October. Deprecated: Use CurrentMonth and CurrentDay instead. |
|
int Minutes(int minutes) | Converts the number of minutes into game time (ticks). |
int Seconds(int seconds) | Converts the number of seconds into game time (ticks). |
int TimeLimit { get; set; } | Return or set the time limit (in ticks). When setting, the time limit will count from now. Setting the time limit to 0 will disable it. |
string TimeLimitNotification { get; set; } | The notification string used for custom time limit warnings. See the TimeLimitManager trait documentation for details. |
Function | Description |
---|---|
Double Ambient { get; set; } | Strength of the lighting (0-1). |
Double Blue { get; set; } | Blue component (0-1). |
void Flash(string type = nil, int ticks = -1) | Controls the FlashPostProcessEffect trait. |
Double Green { get; set; } | Green component (0-1). |
Double Red { get; set; } | Red component (0-1). |
Function | Description |
---|---|
Actor[] ActorsInBox(WPos topLeft, WPos bottomRight, LuaFunction filter = nil) | Returns a table of all actors within the requested rectangle, filtered using the specified function. |
Actor[] ActorsInCircle(WPos location, WDist radius, LuaFunction filter = nil) | Returns a table of all actors within the requested region, filtered using the specified function. |
Actor[] ActorsInWorld { get; } | Returns a table of all the actors that are currently on the map/in the world. |
Actor[] ActorsWithTag(string tag) | Returns a table of all actors tagged with the given string. |
Returns the location of the bottom-right corner of the map (assuming zero terrain height). Deprecated: This function will be removed in future versions. Use Map.ActorsInWorld instead. |
|
WPos CenterOfCell(CPos cell) | Returns the center of a cell in world coordinates. |
CPos ClosestEdgeCell(CPos givenCell) | Returns the closest cell on the visible border of the map from the given cell. |
CPos ClosestMatchingEdgeCell(CPos givenCell, LuaFunction filter) | Returns the first cell on the visible border of the map from the given cell, matching the filter function called as function(cell: cpos):boolean. |
bool IsNamedActor(Actor actor) | Returns true if actor was originally specified in the map file. |
bool IsPausedShellmap { get; } | Returns true if this is a shellmap and the player has paused animations. |
bool IsSinglePlayer { get; } | Returns true if there is only one human player. |
string LobbyOption(string id) | Returns the value of a ScriptLobbyDropdown selected in the game lobby. |
string LobbyOptionOrDefault(string id, string fallback) | Returns the value of a ScriptLobbyDropdown selected in the game lobby or fallback to a default value. |
Actor NamedActor(string actorName) | Returns the actor that was specified with a given name in the map file (or nil, if the actor is dead or not found). |
Actor[] NamedActors { get; } | Returns a table of all the actors that were specified in the map file. |
CPos RandomCell() | Returns a random cell inside the visible region of the map. |
CPos RandomEdgeCell() | Returns a random cell on the visible border of the map. |
string TerrainType(CPos cell) | Returns the type of the terrain at the target cell. |
Returns the location of the top-left corner of the map (assuming zero terrain height). Deprecated: This function will be removed in future versions. Use Map.ActorsInWorld instead. |
Function | Description |
---|---|
void Debug(string format) | Displays a debug message to the player, if "Show Map Debug Messages" is checked in the settings. |
void DisplayMessage(string text, string prefix = Mission, Color? color = nil) | Display a text message to all players. |
void DisplayMessageToPlayer(Player player, string text, string prefix = Mission, Color? color = nil) | Display a text message only to this player. |
void DisplaySystemMessage(string text, string prefix = nil) | Display a system message to the player. If 'prefix' is nil the default system prefix is used. |
void FloatingText(string text, WPos position, int duration = 30, Color? color = nil) | Display a text message at the specified location. |
void PlayMovieFullscreen(string videoFileName, LuaFunction onPlayComplete = nil) | Play a video fullscreen. File name has to include the file extension. |
void PlayMovieInRadar(string videoFileName, LuaFunction onPlayComplete = nil) | Play a video in the radar window. File name has to include the file extension. |
void PlayMusic(string track = nil, LuaFunction onPlayComplete = nil) | Play track defined in music.yaml or map.yaml, or keep track empty for playing a random song. |
void PlaySound(string file) | Play a sound file |
void PlaySoundNotification(Player player, string notification) | Play a sound listed in notifications.yaml |
void PlaySpeechNotification(Player player, string notification) | Play an announcer voice listed in notifications.yaml |
void SetBackgroundMusic(string track = nil) | Play track defined in music.yaml or map.yaml as background music. If music is already playing use Media.StopMusic() to stop it and the background music will start automatically. Keep the track empty to disable background music. |
void StopMusic() | Stop the current song. |
Function | Description |
---|---|
Player GetPlayer(string name) | Returns the player with the specified internal name, or nil if a match is not found. |
Player[] GetPlayers(LuaFunction filter) | Returns a table of players filtered by the specified function. |
Function | Description |
---|---|
void Ping(Player player, WPos position, Color color, int duration = 750) | Creates a new radar ping that stays for the specified time at the specified WPos. |
Function | Description |
---|---|
Actor[] Reinforce(Player owner, String[] actorTypes, CPos[] entryPath, int interval = 25, LuaFunction actionFunc = nil) | Send reinforcements consisting of multiple units. Supports ground-based, naval and air units. The first member of the entryPath array will be the units' spawnpoint, while the last one will be their destination. If actionFunc is given, it will be executed once a unit has reached its destination. actionFunc will be called as actionFunc(a: actor). Returns a table containing the deployed units. |
LuaTable ReinforceWithTransport(Player owner, string actorType, String[] cargoTypes, CPos[] entryPath, CPos[] exitPath = nil, LuaFunction actionFunc = nil, LuaFunction exitFunc = nil, int dropRange = 3) | Send reinforcements in a transport. A transport can be a ground unit (APC etc.), ships and aircraft. The first member of the entryPath array will be the spawnpoint for the transport, while the last one will be its destination. The last member of the exitPath array is be the place where the transport will be removed from the game. When the transport has reached the destination, it will unload its cargo unless a custom actionFunc has been supplied. Afterwards, the transport will follow the exitPath and leave the map, unless a custom exitFunc has been supplied. actionFunc will be called as actionFunc(transport: actor, cargo: actor[]). exitFunc will be called as exitFunc(transport: actor). dropRange determines how many cells away the transport will try to land if the actual destination is blocked (if the transport is an aircraft). Returns a table in which the first value is the transport, and the second a table containing the deployed units. |
Function | Description |
---|---|
void AfterDelay(int delay, LuaFunction func) | Call a function after a specified delay. The callback function will be called as func(). |
void Clear(Actor actor, string triggerName) | Removes the specified trigger from this actor. Note that the removal will only take effect at the end of a tick, so you must not add new triggers at the same time that you are calling this function. |
void ClearAll(Actor actor) | Removes all triggers from this actor. Note that the removal will only take effect at the end of a tick, so you must not add new triggers at the same time that you are calling this function. |
void OnAddedToWorld(Actor actor, LuaFunction func) | Call a function when this actor is added to the world. The callback function will be called as func(self: actor). |
void OnAllKilled(Actor[] actors, LuaFunction func) | Call a function when all of the actors in a group are killed. The callback function will be called as func(). |
void OnAllKilledOrCaptured(Actor[] actors, LuaFunction func) | Call a function when all of the actors in a group have been killed or captured. The callback function will be called as func(). |
void OnAllRemovedFromWorld(Actor[] actors, LuaFunction func) | Call a function when all of the actors in a group have been removed from the world. The callback function will be called as func(). |
void OnAnyKilled(Actor[] actors, LuaFunction func) | Call a function when one of the actors in a group is killed. The callback function will be called as func(killed: actor). |
void OnAnyProduction(LuaFunction func) | Call a function when any actor produces another actor. The callback function will be called as func(producer: actor, produced: actor, productionType: string). |
void OnCapture(Actor actors, LuaFunction func) | Call a function when this actor is captured. The callback function will be called as func(self: actor, captor: actor, oldOwner: player, newOwner: player). |
void OnDamaged(Actor actor, LuaFunction func) | Call a function when the actor is damaged. The callback function will be called as func(self: actor, attacker: actor, damage: integer). |
void OnDiscovered(Actor actor, LuaFunction func) | Call a function when this actor is discovered by an enemy or a player with a Neutral stance. The callback function will be called as func(discovered: actor, discoverer: player). The player actor needs the 'EnemyWatcher' trait. The actors to discover need the 'AnnounceOnSeen' trait. |
int OnEnteredFootprint(CPos[] cells, LuaFunction func) | Call a function when a ground-based actor enters this cell footprint. Returns the trigger ID for later removal using RemoveFootprintTrigger(id: integer). The callback function will be called as func(a: actor, id: integer). |
int OnEnteredProximityTrigger(WPos pos, WDist range, LuaFunction func) | Call a function when an actor enters this range. Returns the trigger ID for later removal using RemoveProximityTrigger(id: integer). The callback function will be called as func(a: actor, id: integer). |
int OnExitedFootprint(CPos[] cells, LuaFunction func) | Call a function when a ground-based actor leaves this cell footprint. Returns the trigger ID for later removal using RemoveFootprintTrigger(id: integer). The callback function will be called as func(a: actor, id: integer). |
int OnExitedProximityTrigger(WPos pos, WDist range, LuaFunction func) | Call a function when an actor leaves this range. Returns the trigger ID for later removal using RemoveProximityTrigger(id: integer). The callback function will be called as func(a: actor, id: integer). |
void OnIdle(Actor actor, LuaFunction func) | Call a function each tick that the actor is idle. The callback function will be called as func(self: actor). |
void OnInfiltrated(Actor actor, LuaFunction func) | Call a function when this actor is infiltrated. The callback function will be called as func(self: actor, infiltrator: actor). |
void OnKilled(Actor actor, LuaFunction func) | Call a function when the actor is killed. The callback function will be called as func(self: actor, killer: actor). |
void OnKilledOrCaptured(Actor actor, LuaFunction func) | Call a function when this actor is killed or captured. The callback function will be called as func(). |
void OnObjectiveAdded(Player player, LuaFunction func) | Call a function when this player is assigned a new objective. The callback function will be called as func(p: player, objectiveId: integer). |
void OnObjectiveCompleted(Player player, LuaFunction func) | Call a function when this player completes an objective. The callback function will be called as func(p: player, objectiveId: integer). |
void OnObjectiveFailed(Player player, LuaFunction func) | Call a function when this player fails an objective. The callback function will be called as func(p: player, objectiveId: integer). |
void OnPassengerEntered(Actor actor, LuaFunction func) | Call a function for each passenger when it enters a transport. The callback function will be called as func(transport: actor, passenger: actor). |
void OnPassengerExited(Actor actor, LuaFunction func) | Call a function for each passenger when it exits a transport. The callback function will be called as func(transport: actor, passenger: actor). |
void OnPlayerDiscovered(Player discovered, LuaFunction func) | Call a function when this player is discovered by an enemy or neutral player. The callback function will be called as func(discovered: player, discoverer: player, discoveredActor: actor).The player actor needs the 'EnemyWatcher' trait. The actors to discover need the 'AnnounceOnSeen' trait. |
void OnPlayerLost(Player player, LuaFunction func) | Call a function when this player fails any primary objective. The callback function will be called as func(p: player). |
void OnPlayerWon(Player player, LuaFunction func) | Call a function when this player completes all primary objectives. The callback function will be called as func(p: player). |
void OnProduction(Actor actors, LuaFunction func) | Call a function when this actor produces another actor. The callback function will be called as func(producer: actor, produced: actor). |
void OnRemovedFromWorld(Actor actor, LuaFunction func) | Call a function when this actor is removed from the world. The callback function will be called as func(self: actor). |
void OnSold(Actor actor, LuaFunction func) | Call a function when this actor is sold. The callback function will be called as func(self: actor). |
void OnTimerExpired(LuaFunction func) | Call a function when the game timer expires. The callback function will be called as func(). |
void RemoveFootprintTrigger(int id) | Removes a previously created footprint trigger. |
void RemoveProximityTrigger(int id) | Removes a previously created proximity trigger. |
Function | Description |
---|---|
string GetFluentMessage(string key, LuaTable args = nil) | Formats a language string for a given string key defined in the language files (*.ftl). Args can be passed to be substituted into the resulting message. |
void SetMissionText(string text, Color? color = nil) | Displays a text message at the top center of the screen. |
Function | Description |
---|---|
bool All(LuaValue[] collection, LuaFunction func) | Returns true if func returns true for all elements in a collection. |
bool Any(LuaValue[] collection, LuaFunction func) | Returns true if func returns true for any element in a collection. |
LuaTable Concat(LuaValue[] firstCollection, LuaValue[] secondCollection) | Concatenates two Lua tables into a single table. |
void Do(LuaValue[] collection, LuaFunction func) | Calls a function on every element in a collection. |
CPos[] ExpandFootprint(CPos[] footprint, bool allowDiagonal) | Expands the given footprint one step along the coordinate axes, and (if requested) diagonals. |
string FormatTime(int ticks, bool leadingMinuteZero = True) | Returns the ticks formatted to HH:MM:SS. |
LuaValue Random(LuaValue[] collection) | Returns a random value from a collection. |
int RandomInteger(int low, int high) | Returns a random integer x in the range low <= x < high. |
LuaValue[] Shuffle(LuaValue[] collection) | Returns the collection in a random order. |
LuaTable Skip(LuaTable table, int numElements) | Skips over the first numElements members of a table and return the rest. |
LuaValue[] Take(int n, LuaValue[] source) | Returns the first n values from a collection. |
LuaTable Where(LuaValue[] collection, LuaFunction func) | Returns the original collection filtered with the func. |
Function | Description |
---|---|
WDist FromCells(int numCells) | Create a new WDist by cell distance. |
WDist New(int r) | Create a new WDist. |
Function | Description |
---|---|
WPos New(int x, int y, int z) | Create a new WPos with the specified coordinates. |
WPos Zero { get; } | The world coordinate origin. |
Function | Description |
---|---|
WVec New(int x, int y, int z) | Create a new WVec with the specified coordinates. |
WVec Zero { get; } | The world zero-vector. |
Function | Description |
---|---|
bool CanCapture(Actor target) | Checks if the target actor can be captured. Requires Trait: CaptureManager |
void Capture(Actor target) | Captures the target actor. Requires Trait: CaptureManager |
void DeliverCarryable(CPos target) Queued Activity |
Drop the actor being carried at the target location. Requires Trait: Carryall |
void DeliverCash(Actor target) Queued Activity |
Deliver cash to the target actor. Requires Traits: IMove, DeliversCash |
void DeliverExperience(Actor target) Queued Activity |
Deliver experience to the target actor. Requires Traits: IMove, DeliversExperience |
void DisguiseAs(Actor target) | Disguises as the target actor. Requires Trait: Disguise |
void DisguiseAsType(string actorType, Player newOwner) | Disguises as the target type with the specified owner. Requires Trait: Disguise |
void Infiltrate(Actor target) | Infiltrate the target actor. Requires Trait: Infiltrates |
void InstantlyRepair(Actor target) Queued Activity |
Enter the target actor to repair it instantly. Requires Traits: IMove, InstantlyRepairs |
void PickupCarryable(Actor target) Queued Activity |
Pick up the target actor. Requires Trait: Carryall |
Function | Description |
---|---|
int AmmoCount(string poolName = primary) | Returns the count of the actor's specified ammopool. Requires Trait: AmmoPool |
int MaximumAmmoCount(string poolName = primary) | Returns the maximum count of ammo the actor can load. Requires Trait: AmmoPool |
void Reload(string poolName = primary, int amount = 1) | Adds the specified amount of ammo to the specified ammopool. (Use a negative amount to remove ammo.) Requires Trait: AmmoPool |
Function | Description |
---|---|
bool IsCloaked { get; } | Returns true if the actor is cloaked. Requires Trait: Cloak |
Function | Description |
---|---|
void Attack(Actor targetActor, bool allowMove = True, bool forceAttack = False) | Attack the target actor. The target actor needs to be visible. Requires Trait: AttackBase |
void AttackMove(CPos cell, int closeEnough = 0) Queued Activity |
Move to a cell, but stop and attack anything within range on the way. closeEnough defines an optional range (in cells) that will be considered close enough to complete the activity. Requires Traits: AttackBase, IMove |
bool CanTarget(Actor targetActor) | Checks if the targeted actor is a valid target for this actor. Requires Trait: AttackBase |
void Demolish(Actor target) Queued Activity |
Demolish the target actor. Requires Traits: IMove, Demolition |
void Guard(Actor targetActor) Queued Activity |
Guard the target actor. Requires Traits: Guard, IMove |
void Hunt() Queued Activity |
Ignoring visibility, find the closest hostile target and attack move to within 2 cells of it. Requires Traits: AttackBase, IMove |
void Patrol(CPos[] waypoints, bool loop = True, int wait = 0) Queued Activity |
Patrol along a set of given waypoints. The action is repeated by default, and the actor will wait for wait ticks at each waypoint.Requires Traits: AttackBase, IMove |
void PatrolUntil(CPos[] waypoints, LuaFunction func, int wait = 0) Queued Activity |
Patrol along a set of given waypoints until a condition becomes true. The actor will wait for wait ticks at each waypoint. The callback function will be called as func(self: actor):boolean.Requires Traits: AttackBase, IMove |
Function | Description |
---|---|
bool CanGainLevel { get; } | Returns true if the actor can gain a level. Requires Trait: GainsExperience |
int Experience { get; } | The actor's amount of experience. Requires Trait: GainsExperience |
void GiveExperience(int amount, bool silent = False) | Gives the actor experience. If 'silent' is true, no animation or sound will be played if the actor levels up. Requires Trait: GainsExperience |
void GiveLevels(int numLevels, bool silent = False) | Gives the actor level(s). If 'silent' is true, no animation or sound will be played. Requires Trait: GainsExperience |
int Level { get; } | The actor's level. Requires Trait: GainsExperience |
int MaxLevel { get; } | The actor's maximum possible level. Requires Trait: GainsExperience |
Function | Description |
---|---|
bool AcceptsCondition(string condition) | Check whether this actor accepts a specific external condition. Requires Trait: ExternalCondition |
bool AddTag(string tag) | Add a tag to the actor. Returns true on success, false otherwise (for example the actor may already have the given tag). |
void CallFunc(LuaFunction func) Queued Activity |
Run an arbitrary Lua function. |
WPos CenterPosition { get; } | The actor position in world coordinates. Requires Trait: IOccupySpace |
void Deploy() Queued Activity |
Queue a new transformation. Requires Trait: Transforms |
void Destroy() Queued Activity |
Remove the actor from the game, without triggering any death notification. |
Player EffectiveOwner { get; } | The effective owner of the actor. |
WAngle Facing { get; } | The direction that the actor is facing. Requires Trait: IFacing |
void Flash(Color color, int count = 2, int interval = 2, int delay = 0) | Render a target flash on the actor. |
int GrantCondition(string condition, int duration = 0) | Grant an external condition on this actor and return the revocation token. Conditions must be defined on an ExternalConditions trait on the actor. If duration > 0 the condition will be automatically revoked after the defined number of ticks. Requires Trait: ExternalCondition |
bool HasProperty(string name) | Test whether an actor has a specific property. |
bool HasTag(string tag) | Specifies whether or not the actor has a particular tag. |
int Health { get; set; } | Current health of the actor. Requires Trait: IHealth |
bool IsDead { get; } | Specifies whether the actor is alive or dead. |
bool IsIdle { get; } | Specifies whether the actor is idle (not performing any activities). |
bool IsInWorld { get; set; } | Specifies whether the actor is in the world. |
bool IsTaggable { get; } | Specifies whether or not the actor supports 'tags'. |
void Kill(Object damageTypes = nil) | Kill the actor. damageTypes may be omitted, specified as a string, or as table of strings. Requires Trait: IHealth |
CPos Location { get; } | The actor position in cell coordinates. Requires Trait: IOccupySpace |
int MaxHealth { get; } | Maximum health of the actor. Requires Trait: IHealth |
Player Owner { get; set; } | The player that owns the actor. |
bool RemoveTag(string tag) | Remove a tag from the actor. Returns true on success, false otherwise (tag was not present). |
void RevokeCondition(int token) | Revoke a condition using the token returned by GrantCondition. Requires Trait: ExternalCondition |
void Sell() | Start selling the actor. Requires Trait: Sellable |
string Stance { get; set; } | Current actor stance. Returns nil if this actor doesn't support stances. |
void StartBuildingRepairs(Player repairer = nil) | Start repairs on this building. repairer can be an allied player.Requires Trait: RepairableBuilding |
void Stop() | Attempt to cancel any active activities. |
void StopBuildingRepairs(Player repairer = nil) | Stop repairs on this building. repairer can be an allied player.Requires Trait: RepairableBuilding |
void Teleport(CPos cell) Queued Activity |
Instantly moves the actor to the specified cell. |
string TooltipName { get; } | The actor's tooltip name. Returns nil if the actor has no tooltip. |
string Type { get; } | The type of the actor (e.g. "e1"). |
void Wait(int ticks) Queued Activity |
Wait for a specified number of game ticks (25 ticks = 1 second). |
Function | Description |
---|---|
void EnterTransport(Actor transport) Queued Activity |
Move to and enter the transport. Requires Trait: Mobile |
void FindResources() Queued Activity |
Search for nearby resources and begin harvesting. Requires Trait: Harvester |
bool IsMobile { get; } | Whether the actor can move (false if immobilized). Requires Trait: Mobile |
void Land(Actor landOn) Queued Activity |
Queues a landing activity on the specified actor. Requires Trait: Aircraft |
void Move(CPos cell) Queued Activity |
Fly within the cell grid. Requires Trait: Aircraft |
void Move(CPos cell, int closeEnough = 0) Queued Activity |
Moves within the cell grid. closeEnough defines an optional range (in cells) that will be considered close enough to complete the activity. Requires Trait: Mobile |
void MoveIntoWorld(CPos cell) Queued Activity |
Moves from outside the world into the cell grid. Requires Trait: Mobile |
void Panic() Queued Activity |
Makes the unit automatically run around and become faster. Requires Trait: ScaredyCat |
void Resupply() Queued Activity |
Starts the resupplying activity when being on a host building. Requires Trait: Aircraft |
void ReturnToBase(Actor destination = nil) Queued Activity |
Return to the base, which is either the destination given, or an auto-selected one otherwise. Requires Trait: Aircraft |
void Scatter() Queued Activity |
Leave the current position in a random direction. Requires Trait: Mobile |
void ScriptedMove(CPos cell) Queued Activity |
Moves within the cell grid, ignoring lane biases. Requires Trait: Mobile |
Function | Description |
---|---|
int Power { get; } | Returns the power drained/provided by this actor. Requires Trait: Power |
Function | Description |
---|---|
bool Build(String[] actorTypes, LuaFunction actionFunc = nil) | Build the specified set of actors using a TD-style (per building) production queue. The function will return true if production could be started, false otherwise. If an actionFunc is given, it will be called as actionFunc(actors: actor[]) once production of all actors has been completed. The actors array is guaranteed to only contain alive actors. Requires Traits: ProductionQueue, ScriptTriggers |
bool IsPrimaryBuilding { get; set; } | Query or set the factory's primary building status. Requires Trait: PrimaryBuilding |
bool IsProducing(string actorType) | Check whether the factory's production queue that builds this type of actor is currently busy. Note: it does not check whether this particular type of actor is being produced. Requires Traits: ProductionQueue, ScriptTriggers |
void Produce(string actorType, string factionVariant = nil, string productionType = nil) Queued Activity |
Build a unit, ignoring the production queue. The activity will wait if the exit is blocked. If productionType is nil or unavailable, then an exit will be selected based on 'Buildable.BuildAtProductionType'. If 'Buildable.BuildAtProductionType' is not set either, a random exit will be selected. Requires Trait: Production |
CPos RallyPoint { get; set; } | Query or set a factory's rally point. Requires Trait: RallyPoint |
Function | Description |
---|---|
void ActivateIonCannon(CPos target) | Activate the actor's IonCannonPower. Requires Trait: IonCannonPower |
void ActivateNukePower(CPos target) | Activate the actor's NukePower. Requires Trait: NukePower |
void Chronoshift(LuaTable unitLocationPairs, int duration = 0, bool killCargo = False) | Chronoshift a group of actors. A duration of 0 will teleport the actors permanently. Requires Trait: ChronoshiftPower |
Actor[] TargetAirstrike(WPos target, WAngle? facing = nil) | Activate the actor's Airstrike Power. Returns the aircraft that will attack. Requires Trait: AirstrikePower |
Actor[] TargetParatroopers(WPos target, WAngle? facing = nil) | Activate the actor's Paratroopers Power. Returns the aircraft that will drop the reinforcements. Requires Trait: ParatroopersPower |
Function | Description |
---|---|
bool HasPassengers { get; } | Specifies whether transport has any passengers. Requires Trait: Cargo |
void LoadPassenger(Actor a) | Teleport an existing actor inside this transport. Requires Trait: Cargo |
void Paradrop(CPos cell) Queued Activity |
Command transport to paradrop passengers near the target cell. Requires Traits: Cargo, ParaDrop |
int PassengerCount { get; } | Specifies the amount of passengers. Requires Trait: Cargo |
Actor[] Passengers { get; } | Returns references to passengers inside the transport. Requires Trait: Cargo |
Actor UnloadPassenger(Actor a = nil) | Remove an existing actor (or first actor if none specified) from the transport. This actor is not added to the world. Requires Trait: Cargo |
void UnloadPassengers(CPos? cell = nil, int unloadRange = 5) Queued Activity |
Command transport to unload passengers. Requires Trait: Cargo |
Function | Description |
---|---|
bool IsAlliedWith(Player targetPlayer) | Returns true if the player is allied with the other player. |
Function | Description |
---|---|
int AddObjective(string description, string type = Primary, bool required = True) Queued Activity |
Add a mission objective for this player. The function returns the ID of the newly created objective, so that it can be referred to later. Requires Trait: MissionObjectives |
int AddPrimaryObjective(string description) Queued Activity |
Add a primary mission objective for this player. The function returns the ID of the newly created objective, so that it can be referred to later. Requires Trait: MissionObjectives |
int AddSecondaryObjective(string description) Queued Activity |
Add a secondary mission objective for this player. The function returns the ID of the newly created objective, so that it can be referred to later. Requires Trait: MissionObjectives |
string GetObjectiveDescription(int id) Queued Activity |
Returns the description of an objective. Requires Trait: MissionObjectives |
string GetObjectiveType(int id) Queued Activity |
Returns the type of an objective. Requires Trait: MissionObjectives |
bool HasNoRequiredUnits() Queued Activity |
Returns true if this player has lost all units/actors that have the MustBeDestroyed trait (according to the short game option). Requires Trait: MissionObjectives |
bool IsObjectiveCompleted(int id) Queued Activity |
Returns true if the objective has been successfully completed, false otherwise. Requires Trait: MissionObjectives |
bool IsObjectiveFailed(int id) Queued Activity |
Returns true if the objective has been failed, false otherwise. Requires Trait: MissionObjectives |
void MarkCompletedObjective(int id) Queued Activity |
Mark an objective as completed. This needs the objective ID returned by AddObjective as argument. When this player has completed all primary objectives, (s)he has won the game. Requires Trait: MissionObjectives |
void MarkFailedObjective(int id) Queued Activity |
Mark an objective as failed. This needs the objective ID returned by AddObjective as argument. Secondary objectives do not have any influence whatsoever on the outcome of the game. Requires Trait: MissionObjectives |
Function | Description |
---|---|
bool AcceptsCondition(string condition) | Check whether this player actor accepts a specific external condition. |
int BuildingsKilled { get; } | The total number of buildings killed by this player. Requires Trait: PlayerStatistics |
int BuildingsLost { get; } | The total number of buildings lost by this player. Requires Trait: PlayerStatistics |
Color Color { get; } | The player's color. |
int DeathsCost { get; } | The combined value of all units lost by this player. Requires Trait: PlayerStatistics |
int Experience { get; set; } | Get or set the current experience. Requires Trait: PlayerExperience |
string Faction { get; } | The player's faction. |
Actor[] GetActors() | Returns all living actors staying inside the world for this player. |
Actor[] GetActorsByType(string type) | Returns all living actors of the specified type of this player. |
Actor[] GetActorsByTypes(String[] types) | Returns all living actors of the specified types of this player. |
Actor[] GetGroundAttackers() | Returns an array of actors representing all ground attack units of this player. |
int GrantCondition(string condition, int duration = 0) | Grant an external condition on the player actor and return the revocation token. Conditions must be defined on an ExternalConditions trait on the player actor. If duration > 0 the condition will be automatically revoked after the defined number of ticks. |
int Handicap { get; } | The player's handicap level. |
bool HasPrerequisites(String[] type) | Check if the player has these prerequisites available. |
CPos HomeLocation { get; } | The player's home/starting location. |
string InternalName { get; } | The player's internal name. |
bool IsBot { get; } | Returns true if the player is a bot. |
bool IsLocalPlayer { get; } | Returns true if the player is the local player. |
bool IsNonCombatant { get; } | Returns true if the player is non combatant. |
int KillsCost { get; } | The combined value of units killed by this player. Requires Trait: PlayerStatistics |
string Name { get; } | The player's name. |
void RevokeCondition(int token) | Revoke a condition using the token returned by GrantCondition. |
int Spawn { get; } | The player's spawnpoint ID. |
int Team { get; } | The player's team ID. |
int UnitsKilled { get; } | The total number of units killed by this player. Requires Trait: PlayerStatistics |
int UnitsLost { get; } | The total number of units lost by this player. Requires Trait: PlayerStatistics |
Function | Description |
---|---|
bool PlayLowPowerNotification { get; set; } | Whether the player should receive a notification when low on power. Requires Trait: PowerManager |
int PowerDrained { get; } | Returns the power used by the player. Requires Trait: PowerManager |
int PowerProvided { get; } | Returns the total of the power the player has. Requires Trait: PowerManager |
string PowerState { get; } | Returns the player's power state ("Normal", "Low" or "Critical"). Requires Trait: PowerManager |
void TriggerPowerOutage(int ticks) | Triggers low power for the chosen amount of ticks. Requires Trait: PowerManager |
Function | Description |
---|---|
bool Build(String[] actorTypes, LuaFunction actionFunc = nil) | Build the specified set of actors using classic (RA-style) production queues. The function will return true if production could be started, false otherwise. If an actionFunc is given, it will be called as actionFunc(actors: actor[]) once production of all actors has been completed. The actors array is guaranteed to only contain alive actors. Note: This function will fail to work when called during the first tick. Requires Traits: ClassicProductionQueue, ScriptTriggers |
bool IsProducing(string actorType) | Check whether the production queue that builds this type of actor is currently busy. Note: it does not check whether this particular type of actor is being produced. Requires Traits: ClassicProductionQueue, ScriptTriggers |
Function | Description |
---|---|
int Cash { get; set; } | The amount of cash held by the player. Requires Trait: PlayerResources |
int ResourceCapacity { get; } | The maximum resource storage of the player. Requires Trait: PlayerResources |
int Resources { get; set; } | The amount of harvestable resources held by the player. Requires Trait: PlayerResources |