-
Notifications
You must be signed in to change notification settings - Fork 17
Board
This page describes functions of Board
that have been added or changed as part of modding API.
For a page about the Board
class as defined in vanilla version of the game, see [Vanilla] Board
- GetHighlighted
- IsHighlighted
- GetSelectedPawn
- GetSelectedPawnId
- IsMissionBoard
- IsTipImage
- MovePawnsFromTile
- RestorePawnsToTile
- SetFire
- SetShield
- ipairs
- GetTiles
- GetTile
Signature: Point GetHighlighted()
Returns the current tile being highlighted by the mouse cursor.
Returns nil
if no tile is highlighted.
Signature: boolean IsHighlighted(Point)
Argument name | Type | Description |
---|---|---|
loc |
Point | The tile we want to check |
Returns true if the specified tile is currently highlighted by the mouse cursor. false
otherwise.
Signature: Pawn GetSelectedPawn()
Returns the currently selected pawn on this board, or nil is no pawn is selected.
Signature: int GetSelectedPawnId()
Returns the currently selected pawn's id on this board, or nil is no pawn is selected.
Signature: boolean IsMissionBoard(table)
Argument name | Type | Description |
---|---|---|
mission |
table | Optional argument. If provided, the function will check whether this instance is the board used in the specified mission. Defaults to currently active mission. |
Returns true
if this Board
is the main board used in the specified mission. false
otherwise, or when no mission is currently active.
Signature: boolean IsTipImage()
Returns true if this board is part of a tip image. false
otherwise.
Signature: table MovePawnsFromTile(Point)
Argument name | Type | Description |
---|---|---|
loc |
Point | The location to move the pawns from |
Moves all pawns on the specified tile off the board. Returns a list of all pawns that have been moved, in reverse order in which they have been placed on the tile
Use in conjunction with RestorePawnsToTile
Example:
local loc = Point(2,2)
local fx = SkillEffect()
fx:AddScript(string.format([[
local loc = %s
local pawnstack = Board:MovePawnsFromTile(loc)
Board:DamageSpace(SpaceDamage(loc, 1))
-- Tile will be damaged, but no pawns will be harmed
Board:RestorePawnsToTile(loc, pawnstack)
]], loc:GetLuaString()))
Board:AddEffect(fx)
Signature: void RestorePawnsToTile(Point, table)
Argument name | Type | Description |
---|---|---|
loc |
Point | The location to restore the pawns to |
pawnStack |
table | List of all pawns that have been moved using MovePawnsFromTile
|
Restores all pawns in the list to the specified location, honoring the order in which they've been placed originally.
Use in conjunction with MovePawnsFromTile
Signature: void SetFire(Point, boolean)
Argument name | Type | Description |
---|---|---|
loc |
Point | The tile that will be affected |
fire |
boolean | Whether the tile should be set on fire, or extinguished |
Sets the specified tile on fire if the second argument is true
, or extinguishes it if it is false
. Extinguishing the tile does not remove the Fire status from pawns standing on the tile.
Signature: void SetShield(Point, boolean)
Argument name | Type | Description |
---|---|---|
loc |
Point | The tile that will be affected |
shield |
boolean | Whether the tile should be shielded, or unshielded |
Adds a shield to any pawn, building or mountain on the specified tile if the second argument is true
, or removes any shield if it is false
.
Board points can be iterated using regular Lua ipairs
like so:
for index, point in ipairs(Board) do
LOG(index, point)
end
Points are iterated by x-coordinate first and then by y-coordinate, so Point(0,0)
will be first, then Point(1,0)
, etc. then upon reaching the edge of the board will continue at Point(0,1)
, Point(1,1)
etc.
Signature: PointList GetTiles(function)
Argument name | Type | Description |
---|---|---|
predicateFn |
function | Predicate function taking a point and returning a boolean value. Optional. |
Returns a PointList
of all points in the board if predicateFn
is nil, or all points in the board that return true for predicateFn
, if it is provided. Uses ipairs
under the hood.
Example:
-- Grab all tiles in the Board
local allTiles = Board:GetTiles()
-- Grab all tiles that are on fire
local tilesOnFire = Board:GetTiles(function(p)
return Board:IsFire(p)
end)
Signature: Point GetTile(function)
Argument name | Type | Description |
---|---|---|
predicateFn |
function | Predicate function taking a point and returning a boolean value. |
Returns the first point in the board for which predicateFn
returns true. Returns nil
if no points match. Uses ipairs
under the hood.