Screen#

Contains functionality related to the currently loaded mapdata screen, including functions for drawing and creating/loading objects belonging to the screen.

Many variables in Screen refer to a single mapdata screen (such as Screen->UnderCombo). For a scrolling Region with multiple screens, which screen these variables refer to depends on the context of the running script. See Screen->Index for more.

The combo array variables (such as Screen->ComboD[]) may access any combo position in the current region. Use ComboAt() to translate (x, y) world coordinates to a combo position. The size of these arrays is NUM_COMBO_POS.

For accessing specific screens, see mapdata.

Access with Screen->.

Tutorials#

Variables#

const int

Index

untyped[]

D

int[]

ComboD

int[]

ComboC

int[]

ComboF

int[]

ComboI

int[]

ComboT

int[]

ComboS

int[]

ComboE

int[]

Door

bool[]

State

bool[]

ExState

bool

Lit

int

Wavy

int

Quake

const int

NumItems

const int

GetRenderTarget

const int

NumNPCs

const int

ShowingMessage

const int

NumLWeapons

const int

NumEWeapons

int[]

Flags

int[]

EFlags

int

RoomType

int

MovingBlockX

int

MovingBlockY

int

MovingBlockLayer

int

MovingBlockCombo

int

MovingBlockCSet

int

UnderCombo

int

UnderCSet

int

Valid

int

Guy

int

String

int

Item

int[]

TileWarpType

bool[]

TileWarpOverlay

int

DoorComboSet

int[]

WarpReturnX

int[]

WarpReturnY

int

StairsX

int

StairsY

int

ItemX

int

ItemY

int[]

TileWarpDMap

int[]

TileWarpScreen

int

ExitDir

int[]

Enemy

int

Pattern

int[]

SideWarpType

bool[]

SideWarpOverlay

int

WarpArrivalX

int

WarpArrivalY

int[]

MazePath

int[]

SideWarpScreen

int[]

SideWarpID

int[]

TileWarpReturnSquare

int[]

SideWarpReturnSquare

int[]

SideWarpDMap

int

Palette

int

Catchall

int

CSensitive

int

NoReset

int

NoCarry

int[]

LayerMap

int[]

LayerScreen

int[]

LayerOpacity

bool[]

LayerInvisible

bool[]

ScriptDraws

int

TimedWarpTimer

int

NextMap

int

NextScreen

int[]

SecretCombo

int[]

SecretCSet

int[]

SecretFlags

int

AmbientSFX

int

BossSFX

int

SecretSFX

int

ItemSFX

int

MIDI

int

Script

untyped[]

InitD

const bool

SecretsTriggered

const int

NumPortals

const npc[]

NPCs

const itemsprite[]

Items

const lweapon[]

LWeapons

const eweapon[]

EWeapons

const ffc[]

FFCs

const portal[]

Portals

bool[]

LensShows

bool[]

LensHides

int

DataSize

untyped[]

Data

int

GuyCount

int

OceanSFX

int

RoomData

int

CSet

int

CarryoverMap

int

CarryoverScreen

int

HasItem deprecated

int[]

ScreenFlags deprecated

int

EnemyFlags deprecated

int

SideWarpIndex deprecated

bool[]

NumFFCs deprecated

int

EntryX deprecated

int

EntryY deprecated

int

LensLayer deprecated

DrawOrigin

DrawOrigin

sprite

DrawOriginTarget

Functions#

int

NumItems() deprecated

itemsprite

LoadItem(int n)

itemsprite

CreateItem(int id)

ffc

LoadFFC(int id)

ffc

LoadFFC(int screen, int index)

int

NumNPCs() deprecated

npc

LoadNPC(int n)

npc

CreateNPC(int id)

void

ClearSprites(int spritelist)

void

Rectangle(int layer, int x, int y, int x2, int y2, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool fill = true, int opacity = OP_OPAQUE)

void

Circle(int layer, int x, int y, int radius, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool fill = true, int opacity = OP_OPAQUE)

void

Arc(int layer, int x, int y, int radius, int start_degrees, int end_degrees, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool closed = true, bool fill = true, int opacity = OP_OPAQUE)

void

Ellipse(int layer, int x, int y, int xradius, int yradius, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool fill = true, int opacity = OP_OPAQUE)

void

Line(int layer, int x, int y, int x2, int y2, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, int opacity = OP_OPAQUE)

void

Spline(int layer, int x1, int y1, int x2, int y2, int x3, int y3, int x4, int y4, int color, int opacity = OP_OPAQUE)

void

PutPixel(int layer, int x, int y, int color, int rx = 0, int ry = 0, int rot_degrees = 0, int opacity = OP_OPAQUE)

void

PutPixels(int layer, int ptr, int rx, int ry, int rot_degrees)

void

DrawTiles(int layer, int ptr)

void

DrawCombos(int layer, int ptr)

void

Lines(int layer, int ptr)

void

DrawCharacter(int layer, int x, int y, int font, int color, int bg_color, int width, int height, char32 c, int opacity = OP_OPAQUE)

void

DrawInteger(int layer, int x, int y, int font, int color, int bg_color, int width, int height, int value, int num_decimal_places = 0, int opacity = OP_OPAQUE)

void

DrawTile(int layer, int x, int y, int tile, int block_w, int block_h, int cset, int xscale = -1, int yscale = -1, int rx = 0, int ry = 0, int rot_degrees = 0, int flip = 0, bool transparency = true, int opacity = OP_OPAQUE)

void

DrawTileCloaked(int layer, int x, int y, int tile, int blockw, int blockh, int flip = 0)

void

DrawCombo(int layer, int x, int y, int combo, int w, int h, int cset, int xscale = -1, int yscale = -1, int rx = 0, int ry = 0, int rot_degrees = 0, int frame = 0, int flip = 0, bool transparency = true, int opacity = OP_OPAQUE)

void

DrawComboCloaked(int layer, int x, int y, int combo, int tilewidth, int tileheight, int flip = 0)

void

Quad(int layer, int x1, int y1, int x2, int y2, int x3, int y3, int x4, int y4, int w, int h, int cset, int flip, int texture, int render_mode)

void

Triangle(int layer, int x1, int y1, int x2, int y2, int x3, int y3, int w, int h, int cset, int flip, int texture, int render_mode)

void

Quad3D(int layer, int[] pos, int[] uv, int[] csets, int[] size, int flip, int texture, int render_mode)

void

Triangle3D(int layer, int[] pos, int[] uv, int[] csets, int[] size, int flip, int tile, int polytype)

void

FastTile(int layer, int x, int y, int tile, int cset, int opacity = OP_OPAQUE)

void

FastCombo(int layer, int x, int y, int combo, int cset, int opacity = OP_OPAQUE)

void

DrawString(int layer, int x, int y, int font, int color, int background_color, int format, char32[] str, int opacity = OP_OPAQUE)

void

DrawString(int layer, int x, int y, int font, int color, int background_color, int format, char32[] str, int opacity, int shadow_type, int shadow_color)

void

DrawLayer(int layer, int source_map, int source_screen, int source_layer, int x, int y, int rotation = 0, int opacity = OP_OPAQUE)

void

DrawScreen(int layer, int map, int screen, int x, int y, int rotation = 0)

void

DrawBitmap(int layer, int bitmap_id, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation, bool mask)

void

DrawBitmapEx(int layer, int bitmap_id, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation = 0, int cx = 0, int cy = 0, int mode = 0, int lit = 0, bool mask = true)

void

TileBlit(int layer, int tile, int cset, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation = 0, int cx = 0, int cy = 0, int mode = 0, int lit = 0, bool mask = true)

void

ComboBlit(int layer, int combo, int cset, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation = 0, int cx = 0, int cy = 0, int mode = 0, int lit = 0, bool mask = true)

void

SetRenderTarget(int rt)

void

Message(int message_id)

int

NumLWeapons() deprecated

lweapon

LoadLWeapon(int n)

lweapon

CreateLWeapon(int type)

int

NumEWeapons() deprecated

eweapon

LoadEWeapon(int n)

eweapon

CreateEWeapon(int type)

bool

isSolid(int x, int y)

bool

isSolidLayer(int x, int y, int layer)

void

TriggerSecrets()

void

TriggerSecrets(int screen)

void

ZapIn()

void

ZapOut()

void

WavyIn()

void

WavyOut()

void

OpeningWipe()

void

ClosingWipe()

void

OpeningWipe(int effect)

void

ClosingWipe(int effect)

void

Polygon(int layer, int num_points, int vertices, int color, int opacity = OP_OPAQUE)

void

DrawFrame(int layer, int x, int y, int tile, int cset, int width, int height, bool overlay = true, int opacity = OP_OPAQUE)

bool

SecretsTriggered() deprecated

bool

SpawnScreenEnemies()

bool

TriggerCombo(int layer, int pos)

int

NumPortals() deprecated

portal

LoadPortal(int n)

portal

CreatePortal()

void

DrawLightSquare(int cx, int cy, int radius = -1, int transp_rad = -1, int dith_rad = -1, int dith_type = -1, int dith_arg = -1)

void

DrawLightCircle(int cx, int cy, int radius = -1, int transp_rad = -1, int dith_rad = -1, int dith_type = -1, int dith_arg = -1)

void

DrawLightCone(int cx, int cy, int dir, int length = -1, int transp_rad = -1, int dith_rad = -1, int dith_type = -1, int dith_arg = -1)

bool

GetExDoor(int dir, int index)

void

SetExDoor(int dir, int index, bool state)

void

SetSideWarp(int warp_id, int screen, int dmap, int type)

void

SetTileWarp(int warp_id, int screen, int dmap, int type)

lweapon

CreateLWeaponDx(int type, int baseitem)

npc

LoadNPCByUID(int uid) deprecated

lweapon

LoadLWeaponByUID(int uid) deprecated

eweapon

LoadEWeaponByUID(int uid) deprecated

int

LayerMap(int layer) deprecated

int

LayerScreen(int layer) deprecated

int

GetSideWarpDMap(int warp_id) deprecated

int

GetSideWarpScreen(int warp_id) deprecated

int

GetSideWarpType(int warp_id) deprecated

int

GetTileWarpDMap(int warp_id) deprecated

int

GetTileWarpScreen(int warp_id) deprecated

int

GetTileWarpType(int warp_id) deprecated

Enumerations#

enum WipeEffect: πŸ”— Source

WipeEffect WIPE_CIRCLE = 0

WipeEffect WIPE_OVAL = 1

WipeEffect WIPE_TRIANGLE = 2

WipeEffect WIPE_SMAS = 3

WipeEffect WIPE_FADEBLACK = 4

WipeEffect WIPE_MAX = 5


enum DrawOrigin: πŸ”— Source

Determines how to interpret coordinates given to Screen draw functions.

DrawOrigin DRAW_ORIGIN_DEFAULT = 0L

Equal to DRAW_ORIGIN_REGION, unless in a scrolling region (or scrolling to/from one), in which case this is equal to DRAW_ORIGIN_PLAYING_FIELD.

DrawOrigin DRAW_ORIGIN_PLAYING_FIELD = 1L

The origin (0, 0) is the top-left pixel of the playing field (where screen combos are drawn). Normally, this is just below the passive subscreen. But in extended height mode, this is the top-left pixel of the screen and so is equivalent to DRAW_ORIGIN_SCREEN.

Use this to draw overlay effects across the playing field.

DrawOrigin DRAW_ORIGIN_SCREEN = 2L

The origin (0, 0) is the top-left pixel of the screen. Use this to draw overlay effects across the entire screen.

DrawOrigin DRAW_ORIGIN_REGION = 3L

The origin (0, 0) is the top-left pixel of the current region. Use this to draw with a sprite’s coordinates.

When scrolling, this is treated as DRAW_ORIGIN_REGION_SCROLLING_NEW for new screens and DRAW_ORIGIN_REGION_SCROLLING_OLD for old screens.

DrawOrigin DRAW_ORIGIN_REGION_SCROLLING_NEW = 4L

The origin (0, 0) is the top-left pixel of the new region being scrolled to.

Equivalent to DRAW_ORIGIN_REGION when not scrolling.

DrawOrigin DRAW_ORIGIN_REGION_SCROLLING_OLD = 5L

The origin (0, 0) is the top-left pixel of the old region being scrolled away from.

Equivalent to DRAW_ORIGIN_REGION when not scrolling.

DrawOrigin DRAW_ORIGIN_SPRITE = 6L

Added in version 3.0.

The origin (0, 0) is the top-left pixel of the sprite Screen->DrawOriginTarget.

If the sprite no longer exists at time of drawing, then the draw command will be ignored.


enum ScreenEnemyFlagGroup: πŸ”— Source

Screen enemy flag groups. Used with Screen->EFlags[].

ScreenEnemyFlagGroup SEF_SPAWN = 0

Corresponds to ScreenEnemyFlagSpawn (SEFSP_).

ScreenEnemyFlagGroup SEF_LIST1 = 1

Corresponds to ScreenEnemyFlagList1 (SEFL1_).

ScreenEnemyFlagGroup SEF_LIST2 = 2

Corresponds to ScreenEnemyFlagList2 (SEFL2_).


enum PolygonRenderMode: πŸ”— Source

Polygon rendering modes. Use with Screen->”Psuedo 3D” or β€œ*3D” drawing functions. ie; Polygon, Quad, or Triangle For more detail on these polygon rendering modes, see https://github.com/ZQuestClassic/ZQuestClassic/blob/main/third_party/allegro_legacy/docs/src/allegro._tx#L7808.

PolygonRenderMode PT_FLAT = 0

Single color shading.

PolygonRenderMode PT_FLATSHADED = 1

β€œβ€ with flat shading (*3D only).

PolygonRenderMode PT_COLSHADED = 2

β€œβ€ with color shading (*3D only).

PolygonRenderMode PT_TEXTURE = 3

Texture mapped polygon using 2d linear interpolation.

PolygonRenderMode PT_PTEXTURE = 4

β€œβ€.

PolygonRenderMode PT_MASKTEXTURE = 5

Transparent texture mapped polygon using 2d linear interpolation.

PolygonRenderMode PT_MASKPTEXTURE = 6

β€œβ€.

PolygonRenderMode PT_LITTEXTURE = 7

β€œβ€ with lighting (*3D only).

PolygonRenderMode PT_LITPTEXTURE = 8

β€œβ€ (*3D only).

PolygonRenderMode PT_MASKLITTEXTURE = 9

β€œβ€ with transparency.

PolygonRenderMode PT_MASKLITPTEXTURE = 10

β€œβ€.

PolygonRenderMode PT_TRANSTEXTURE = 11

Translucent texture mapped polygon using 2d linear interpolation.

PolygonRenderMode PT_TRANSPTEXTURE = 12

β€œβ€.

PolygonRenderMode PT_MASKTRANSTEXTURE = 13

Translucent and transparent texture mapped polygon using 2d linear interpolation.

PolygonRenderMode PT_MASKTRANSPTEXTURE = 14

β€œβ€.


enum SpriteList: πŸ”— Source

Sprite lists. Used with Screen->ClearSprites().

SpriteList SL_GUYS = 0

Enemies.

SpriteList SL_ITEMS = 1

Items.

SpriteList SL_EWPNS = 2

Enemy weapons.

SpriteList SL_LWPNS = 3

Link’s weapons.

SpriteList SL_DECORATIONS = 4

Grass clippings, Hover boots glow, etc.

SpriteList SL_PARTICLES = 5

Farore’s Wind particles.


enum ScreenFlagGroup: πŸ”— Source

Screen Flag groups, used with Screen->Flags[]. See Screen Data dialog for what flags are contained in each group.

ScreenFlagGroup SF_ROOMTYPE = 0

Corresponds to ScreenFlagRoomType (SFR_).

ScreenFlagGroup SF_VIEW = 1

Corresponds to ScreenFlagView (SFV_).

ScreenFlagGroup SF_SECRETS = 2

Corresponds to ScreenFlagSecrets (SFS_).

ScreenFlagGroup SF_WARP = 3

Corresponds to ScreenFlagWarp (SFW_).

ScreenFlagGroup SF_ITEMS = 4

Corresponds to ScreenFlagItems (SFI_).

ScreenFlagGroup SF_COMBOS = 5

Corresponds to ScreenFlagCombos (SFC_).

ScreenFlagGroup SF_SAVE = 6

Corresponds to ScreenFlagSave (SFSV_).

ScreenFlagGroup SF_FFC = 7

Corresponds to ScreenFlagFFC (SFF_).

ScreenFlagGroup SF_WHISTLE = 8

Corresponds to ScreenFlagWhistle (SFWH_).

ScreenFlagGroup SF_MISC = 9

Corresponds to ScreenFlagMisc (SFM_).

ScreenFlagGroup SF_LAST = 10


enum ScreenFlagRoomType: πŸ”— Source

ScreenFlagRoomType SFR_INTERIOR = 0

ScreenFlagRoomType SFR_DUNGEON = 1

ScreenFlagRoomType SFR_SIDEVIEW = 2

ScreenFlagRoomType SFR_LAST = 3


enum ScreenFlagView: πŸ”— Source

ScreenFlagView SFV_NOLINKMARKER = 1

ScreenFlagView SFV_NOSUBSCREEN = 2

ScreenFlagView SFV_NOOFFSET = 3

β€˜β€¦but don’t offset’

ScreenFlagView SFV_LAYER2BG = 4

Layer 2 is Background

ScreenFlagView SFV_LAYER3BG = 5

ScreenFlagView SFV_DARKROOM = 6

ScreenFlagView SFV_DARK_DITHER = 7

ScreenFlagView SFV_DARK_TRANS = 8

ScreenFlagView SFV_LAST = 9


enum ScreenFlagSecrets: πŸ”— Source

ScreenFlagSecrets SFS_BLOCKSHUT = 0

Block->Shutters

ScreenFlagSecrets SFS_TEMPSECRETS = 1

Secrets are temporary.

ScreenFlagSecrets SFS_TRIGPERM = 2

All Triggers->Perm Secret

ScreenFlagSecrets SFS_ALLTRIGFLAGS = 3

All triggers->16-31

ScreenFlagSecrets SFS_LAST = 4


enum ScreenFlagWarp: πŸ”— Source

ScreenFlagWarp SFW_AUTODIRECT = 0

Auto Warps are Direct

ScreenFlagWarp SFW_SENDSIRECT = 1

Sensitive Warps are direct.

ScreenFlagWarp SFW_MAZEPATHS = 2

Use maze Path

ScreenFlagWarp SFW_MAZEOVERRIDE = 3

maze Overrides Sidewarps

ScreenFlagWarp SFW_SPRITECARRY = 4

Sprites carry over.

ScreenFlagWarp SFW_DISABLE_MIRROR = 5

Disable Magic Mirror

ScreenFlagWarp SFW_MAZE_CAN_GET_LOST = 6

Maze Can Get Lost

ScreenFlagWarp SFW_MAZE_LOOPY = 7

Maze Loopy

ScreenFlagWarp SFW_LAST = 8


enum ScreenFlagItems: πŸ”— Source

ScreenFlagItems SFI_HOLDUP = 0

Hold up item.

ScreenFlagItems SFI_FALLS = 1

Falls from ceiling

ScreenFlagItems SFI_SECRETSITEM = 2

Secret reveals item

ScreenFlagItems SFI_ITEMSECRET = 3

Item triggers secrets

ScreenFlagItems SFI_ITEMSECRETPERM = 4

Item triggering secrets is permanent

ScreenFlagItems SFI_ITEMRETURNS = 5

Regular item always returns

ScreenFlagItems SFI_SPECIALITEMRETURNS = 6

Special item always returns

ScreenFlagItems SFI_LAST = 7


enum ScreenFlagCombos: πŸ”— Source

ScreenFlagCombos SFC_MIDAIR = 0

Combos affect midair Link

ScreenFlagCombos SFC_CYCLEINIT = 1

Cycle combos on screen init.

ScreenFlagCombos SFC_IGNOREBOOTS = 2

Damage combos ignore boots.

ScreenFlagCombos SFC_TOGGLERINGS = 3

Toggle β€˜Rings Affect Combos’

ScreenFlagCombos SFC_LAST = 4


enum ScreenFlagSave: πŸ”— Source

ScreenFlagSave SFSV_SAVECONTHERE = 0

Save Point->ontinue here.

ScreenFlagSave SFSV_SAVEONENTRY = 1

Save game on entry.

ScreenFlagSave SFSV_CONTHERE = 2

Comtinue here.

ScreenFlagSave SFSV_NOCONTINUEWARP = 3

No continue Here after warp.

ScreenFlagSave SFSV_LAST = 4


enum ScreenFlagFFC: πŸ”— Source

ScreenFlagFFC SFF_WRAP = 0

Freeform Combos Wrap Around

ScreenFlagFFC SFF_NOCARRYOVER = 1

No FFC carry over.

ScreenFlagFFC SFF_LAST = 2


enum ScreenFlagMisc: πŸ”— Source

ScreenFlagMisc SFM_ALLOW_LADDER = 0

Toggle β€˜Allow Ladder’

ScreenFlagMisc SFM_NO_DIVING = 1

Toggle β€˜No Diving’

ScreenFlagMisc SFM_SCRIPT1 = 2

General use 1 (Scripts)

ScreenFlagMisc SFM_SCRIPT2 = 3

General use 2 (Scripts)

ScreenFlagMisc SFM_SCRIPT3 = 4

General use 3 (Scripts)

ScreenFlagMisc SFM_SCRIPT4 = 5

General use 4 (Scripts)

ScreenFlagMisc SFM_SCRIPT5 = 6

General use 5 (Scripts)

ScreenFlagMisc SFM_LAST = 7


enum ScreenFlagWhistle: πŸ”— Source

ScreenFlagWhistle SFWH_STAIRS = 0

Whistle->Stairs

ScreenFlagWhistle SFWH_PALCHANGE = 1

Whistle->Palette Change

ScreenFlagWhistle SFWH_DRYLAKE = 2

Whistle->Dry lake

ScreenFlagWhistle SFWH_LAST = 3


enum ScreenEnemyFlagSpawn: πŸ”— Source

See ScreenEnemyFlagGroup (SEF_).

ScreenEnemyFlagSpawn SEFSP_ZORA = 0

ScreenEnemyFlagSpawn SEFSP_CORNERTRAP = 1

ScreenEnemyFlagSpawn SEFSP_MIDDLETRAP = 2

ScreenEnemyFlagSpawn SEFSP_ROCK = 3

ScreenEnemyFlagSpawn SEFSP_SHOOTER = 4

ScreenEnemyFlagSpawn SEFSP_LAST = 5


enum ScreenEnemyFlagList1: πŸ”— Source

See ScreenEnemyFlagGroup (SEF_).

ScreenEnemyFlagList1 SEFL1_RINGLEADER = 0

ScreenEnemyFlagList1 SEFL1_CARRYITEM = 1

ScreenEnemyFlagList1 SEFL1_INVIS = 2

ScreenEnemyFlagList1 SEFL1_BOSS = 3

ScreenEnemyFlagList1 SEFL1_TRAPS_IGNORE_SOLID = 4

ScreenEnemyFlagList1 SEFL1_LAST = 5


enum ScreenEnemyFlagList2: πŸ”— Source

See ScreenEnemyFlagGroup (SEF_).

ScreenEnemyFlagList2 SEFL2_ALWAYSRET = 0

ScreenEnemyFlagList2 SEFL2_ENEMIES_ITEM = 1

ScreenEnemyFlagList2 SEFL2_ENEMEIS_SECRET = 2

ScreenEnemyFlagList2 SEFL2_ENEMIES_SECRET_PERM = 3

ScreenEnemyFlagList2 SEFL2_CHAIN_ENEMIES_TRIGGERS = 4

ScreenEnemyFlagList2 SEFL2_LAST = 5


enum RenderTarget: πŸ”— Source

Render Targets. Used with Screen->”*RenderTarget” and Screen->”Bitmap” drawing functions.

RenderTarget RT_CURRENT = -2

Used with Blit(). mode7(), and RevBlit() for the current RT as dest.

RenderTarget RT_SCREEN = -1

Draws to screen.

RenderTarget RT_BITMAP0 = 0

Draws to off-screen bitmap 0.

RenderTarget RT_BITMAP1 = 1

Draws to off-screen bitmap 1.

RenderTarget RT_BITMAP2 = 2

Draws to off-screen bitmap 2.

RenderTarget RT_BITMAP3 = 3

Draws to off-screen bitmap 3.

RenderTarget RT_BITMAP4 = 4

Draws to off-screen bitmap 4.

RenderTarget RT_BITMAP5 = 5

Draws to off-screen bitmap 5.

RenderTarget RT_BITMAP6 = 6

Draws to off-screen bitmap 6.


Variable descriptions#

const int Index πŸ”— Source

Added in version 2.55.9: equivalent to Game->CurScreen

The index for the underlying screen. This determines which screen some variables refer to (such as UnderCombo, Valid, or Guy, just to name a few).

In a non-scrolling Region, this is equal to Game->CurScreen.

In a scrolling Region, the default is equal to Game->CurScreen (the top-left screen). However, many script types use a more relevant screen instead. For example:

  • screendata scripts use the screen they are assigned to

  • ffc, npc, eweapon, lweapon, itemsprite, combo - all use the screen they were spawned on (sprite::SpawnScreen)

  • player - uses Game->HeroScreen, which updates as the player moves around


untyped[] D πŸ”— Source

A set of 8 misc values for each screen.


int[] ComboD πŸ”— Source

The combo ID of each of the NUM_COMBO_POS combo positions on the screen.


int[] ComboC πŸ”— Source

The CSet of each of the NUM_COMBO_POS combo positions on the screen.


int[] ComboF πŸ”— Source

The placed (map) flag of each of the NUM_COMBO_POS combo positions on the screen.


int[] ComboI πŸ”— Source

The inherent flag of each of the NUM_COMBO_POS combo positions on the screen.


int[] ComboT πŸ”— Source

value ComboType (CT_)

The combo type of each of the NUM_COMBO_POS combo positions on the screen.


int[] ComboS πŸ”— Source

value ComboSolidityBitflags (CMB_)

The solidity bitflags of each of the NUM_COMBO_POS combo positions on the screen.


int[] ComboE πŸ”— Source

The effect area bitflags of each of the NUM_COMBO_POS combo positions on the screen.


int[] Door πŸ”— Source


bool[] State πŸ”— Source

index ScreenState (ST_)

The 32 screen states used by this screen.


bool[] ExState πŸ”— Source

The β€˜Extra States’ used by this screen.


bool Lit πŸ”— Source

Whether or not the current Region is β€˜lit’. Applies to Classic Darkrooms.


int Wavy πŸ”— Source

The remaining time, in frames, of the β€˜Wavy’ visual effect. Decrements by 1 each frame.


int Quake πŸ”— Source

The remaining time, in frames, of the β€˜Quake’ visual effect. Decrements by 1 each frame.


const int NumItems πŸ”— Source

Returns the number of the given object type that are present on the current screen.


const int GetRenderTarget πŸ”— Source

value RenderTarget (RT_)

Gets/sets the current β€œRender Target”. Most times this should be β€˜RT_SCREEN’, though versions older than 2.55 required using this for bitmap drawing. 2.55’s bitmap effectively obsolete the render target system, and should be used instead of this.


const int NumNPCs πŸ”— Source

Returns the number of the given object type that are present on the current screen.


const int ShowingMessage πŸ”— Source

The message ID of the currently active message. 0 if no message is displayed.


const int NumLWeapons πŸ”— Source

Returns the number of the given object type that are present on the current screen.


const int NumEWeapons πŸ”— Source

Returns the number of the given object type that are present on the current screen.


int[] Flags πŸ”— Source

index ScreenFlagGroup (SF_)

value Varies based on ScreenFlagGroup (SF_)

Multiple bitflags, split into groups.


int[] EFlags πŸ”— Source

index ScreenEnemyFlagGroup (SEF_)

value Varies based on ScreenEnemyFlagGroup (SEF_)

Multiple bitflags related to screen enemies, split into groups.


int RoomType πŸ”— Source

value RoomType

The special room type.


int MovingBlockX πŸ”— Source


int MovingBlockY πŸ”— Source


int MovingBlockLayer πŸ”— Source

The layer of a currently moving pushblock. Is -1 and ignores writes if there is no pushblock currently moving. Allows values 0-6; the block will β€œsettle into place” on this layer.


int MovingBlockCombo πŸ”— Source


int MovingBlockCSet πŸ”— Source


int UnderCombo πŸ”— Source

The undercombo ID used by the screen.


int UnderCSet πŸ”— Source

The CSet of the undercombo used by the screen.


int Valid πŸ”— Source


int Guy πŸ”— Source

The screen guy.


int String πŸ”— Source

The screen string.


int Item πŸ”— Source

The screen item.

To determine if there is an item on the screen, if you ever assigned item 0 as a valid screen item in your quest, you will also want to read HasItem for that screen.

Note: The NULL value is 0, which is a valid item.


int[] TileWarpType πŸ”— Source

index TileWarpIndex (TILEWARP_)

value WarpType (WT_)

The Tile Warp type for Tile Warps A, B, C, and D; [0], [1], [2], and [3] respectively.


bool[] TileWarpOverlay πŸ”— Source

Set or get the overlay state for the warp ID corresponding to the index of this array.


int DoorComboSet πŸ”— Source

The doorset used by the screen, for NES dungeon doors.


int[] WarpReturnX πŸ”— Source

The X-component for each of the four 2.50+ (blue) warp return squares.


int[] WarpReturnY πŸ”— Source

The Y-component for each of the four 2.50+ (blue) warp return squares.


int StairsX πŸ”— Source

The X component for where a Stairs secret appears on the screen.


int StairsY πŸ”— Source

The Y component for where a Stairs secret appears on the screen.


int ItemX πŸ”— Source

The X component for the item location on the screen.


int ItemY πŸ”— Source

The Y component for the item location on the screen.


int[] TileWarpDMap πŸ”— Source

The destination DMap for each of the four warp types.


int[] TileWarpScreen πŸ”— Source

The destination screen for each of the four warp types.


int ExitDir πŸ”— Source

The Maze Path β€˜Exit Direction’.


int[] Enemy πŸ”— Source

The IDs of the enemies that spawn on the screen.


int Pattern πŸ”— Source

value EnemyPattern (PATTERN_)

The enemy β€˜Spawn Pattern’.


int[] SideWarpType πŸ”— Source

index SideWarpIndex

value WarpType (WT_)

The Sidewarp type for Sidewarps A, B, C, and D; [0], [1], [2], and [3] respectively.


bool[] SideWarpOverlay πŸ”— Source

Set or get the overlay state for the warp ID corresponding to the index of this array.


int WarpArrivalX πŸ”— Source

The X-component for the pre-2.50 (green) arrival square.


int WarpArrivalY πŸ”— Source

The X-component for the pre-2.50 (green) arrival square.


int[] MazePath πŸ”— Source

The four Maze Path directions.


int[] SideWarpScreen πŸ”— Source

The destination screen for each of the four sidewarps.


int[] SideWarpID πŸ”— Source

Returns the sidewarp ID for a given screen edge, as SideWarpID[dir];

Returns SIDEWARP_NONE if there is no sidewarp in that direction.

Valid indices: DIR_UP, DIR_DOWN, DIR_LEFT, DIR_RIGHT Valid values: SideWarpIndex


int[] TileWarpReturnSquare πŸ”— Source

The return square used by Tile Warp (A, B, C, D).


int[] SideWarpReturnSquare πŸ”— Source

The return square used by Side Warp (A, B, C, D).


int[] SideWarpDMap πŸ”— Source

The destination DMap for each of the four sidewarps.


int Palette πŸ”— Source

The palette for the screen set via β€˜F4’ or β€˜Screen>>Palette’ in ZQuest


int Catchall πŸ”— Source

The screen β€˜Catchall’ value.


int CSensitive πŸ”— Source

The value of Damage Combo Sensitivity for the screen.


int NoReset πŸ”— Source

value NoResetBitflags (NORESET_)

Which parts of the screen state that won’t reset on reentry.


int NoCarry πŸ”— Source

value NoCarryBitflags (NOCARRY_)

For screen state carryovers, which parts of the screen state that won’t carry over to the target screen.


int[] LayerMap πŸ”— Source

The Map IDs used by screen layers 1 through 6, represented as [1] through [6].

Index [0] does nothing, and trying to access it will report an error to the log.

This only refers to the screen denoted by Index.


int[] LayerScreen πŸ”— Source

The Screen IDs used by screen layers 1 through 6, represented as [1] through [6].

Index [0] does nothing, and trying to access it will report an error to the log.

This only refers to the screen denoted by Index.


int[] LayerOpacity πŸ”— Source

The opacity value for each layer used by this screen.

Valid layers are 1 through 6, represented as [1] through [6].

Index [0] does nothing, and trying to access it will report an error to the log.


bool[] LayerInvisible πŸ”— Source

If true, the current layer is invisible.

Writing this true for layers 1 through 6 will make those layers invisible.


bool[] ScriptDraws πŸ”— Source

If true, the ZC engine will perform script draws on the given queue layer.

Each queue layer returns true by default.

Writing this false disables script draws targetted to a specific layer queue.


int TimedWarpTimer πŸ”— Source

The timer used by β€˜Time Warp Tics’ in Screen Data->T.Warp


int NextMap πŸ”— Source

The map to where secrets on the current mapscreen carry over.

Corresponds to the Screen Data>>>Screen State Carryover β€˜Next Map’ selection in the ZQ Editor.


int NextScreen πŸ”— Source

The screen to where secrets on the current mapscreen carry over.

Corresponds to the Screen Data>>>Screen State Carryover β€˜Next Screen’ selection in the ZQ Editor.


int[] SecretCombo πŸ”— Source

index SecretComboIndex (SECCMB_)

The Combo IDs used by β€˜Secret Combos’ on this screen.


int[] SecretCSet πŸ”— Source

index SecretComboIndex (SECCMB_)

The CSets used by β€˜Secret Combos’ on this screen.


int[] SecretFlags πŸ”— Source

index SecretComboIndex (SECCMB_)

value ComboFlag (CF_)

The Combo Flags used by β€˜Secret Combos’ on this screen.


int AmbientSFX πŸ”— Source

The β€˜Ambient Sound’ under S.Data2.


int BossSFX πŸ”— Source

The Boss Roar sound for this screen.


int SecretSFX πŸ”— Source

The sound that will play on this screen, when secrets are triggered.


int ItemSFX πŸ”— Source

The sound that will play if Link holds an item over his head on this screen.


int MIDI πŸ”— Source

The MIDI that plays on this screen.


int Script πŸ”— Source

The screendata script used for the current screen.


untyped[] InitD πŸ”— Source

The eight D args used by the screendata script for the current screen.


const bool SecretsTriggered πŸ”— Source

Returns true if secrets have been triggered on this screen (including temp).


const int NumPortals πŸ”— Source

Returns the number of the given object type that are present on the current screen.


const npc[] NPCs πŸ”— Source

Internal Array pointers to arrays containing all of each respective type of object on the screen. These arrays are 0-indexed.


const itemsprite[] Items πŸ”— Source

Internal Array pointers to arrays containing all of each respective type of object on the screen. These arrays are 0-indexed.


const lweapon[] LWeapons πŸ”— Source

Internal Array pointers to arrays containing all of each respective type of object on the screen. These arrays are 0-indexed.


const eweapon[] EWeapons πŸ”— Source

Internal Array pointers to arrays containing all of each respective type of object on the screen. These arrays are 0-indexed.


const ffc[] FFCs πŸ”— Source

Internal Array pointers to arrays containing all of each respective type of object on the screen. These arrays are 0-indexed.


const portal[] Portals πŸ”— Source

Internal Array pointers to arrays containing all of each respective type of object on the screen. These arrays are 0-indexed.


bool[] LensShows πŸ”— Source

Arrays of the layers which the lens shows, and hides, respectively.


bool[] LensHides πŸ”— Source

Arrays of the layers which the lens shows, and hides, respectively.


int DataSize πŸ”— Source

The size of the Data[] array.

Changes save to the save file.


untyped[] Data πŸ”— Source

Resizable array of data for scripts to use.

Changes save to the save file.


int GuyCount πŸ”— Source

Number of enemies remaining alive on this screen.


int OceanSFX πŸ”— Source


int RoomData πŸ”— Source


int CSet πŸ”— Source

The palette for the screen set via β€˜F4’ or β€˜Screen>>Palette’ in ZQuest


int CarryoverMap πŸ”— Source


int CarryoverScreen πŸ”— Source


int HasItem πŸ”— Source

If not zero, then the item for this screen will be shown.

When the Hero takes the item on a screen, this is set to 0.

Deprecated: Check ->Item > -1 instead!


int[] ScreenFlags πŸ”— Source

Deprecated.


int EnemyFlags πŸ”— Source

A flagset for enemies on the screen (E.Flags).

Deprecated: Use EFlags[] instead!


int SideWarpIndex πŸ”— Source

The warp return IDs. Deprecated by SideWarpID[].

Deprecated.


bool[] NumFFCs πŸ”— Source

Deprecated.


int EntryX πŸ”— Source

Deprecated: Use Hero->RespawnX instead!


int EntryY πŸ”— Source

Deprecated: Use Hero->RespawnY instead!


int LensLayer πŸ”— Source

Deprecated.


DrawOrigin DrawOrigin πŸ”— Source

Added in version 2.55.9.

Determines how coordinates given to Screen drawing functions are interpreted.

Each script has its own copy of this variable, meaning other scripts can’t change a script’s draw origin unexpectedly.

Defaults to DRAW_ORIGIN_DEFAULT.


sprite DrawOriginTarget πŸ”— Source

Added in version 3.0.

When Screen->DrawOrigin is DRAW_ORIGIN_SPRITE, this sprite is used as the origin for Screen drawing functions.

Each script has its own copy of this variable.


Function descriptions#

int NumItems() πŸ”— Source

Returns the number of the given object type that are present on the current screen.

Deprecated: Use NumItems instead!


itemsprite LoadItem(int n) πŸ”— Source

Where β€˜1 <= n <= NumItems’, returns a pointer to the nth object on the screen.


itemsprite CreateItem(int id) πŸ”— Source

param ItemID (I_) id

Creates a new item sprite.


ffc LoadFFC(int id) πŸ”— Source

Returns the ffc for the given id, where 1 <= id <= MAX_FFC.

See ffc::ID.


ffc LoadFFC(int screen, int index) πŸ”— Source

Returns the ffc from screen of the specified index, where 0 <= index < 128.

screen must be a valid screen within the current Region.


int NumNPCs() πŸ”— Source

Returns the number of the given object type that are present on the current screen.

Deprecated: Use NumNPCs instead!


npc LoadNPC(int n) πŸ”— Source

Where 1 <= n <= NumNPCs, returns a pointer to the nth npc on the screen.


npc CreateNPC(int id) πŸ”— Source

param NPCID (NPC_) id

Creates a new npc (enemy) sprite, with the given ID.


void ClearSprites(int spritelist) πŸ”— Source

param SpriteList (SL_) spritelist

Kills all sprite objects of the specified type.


void Rectangle(int layer, int x, int y, int x2, int y2, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool fill = true, int opacity = OP_OPAQUE) πŸ”— Source


void Circle(int layer, int x, int y, int radius, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool fill = true, int opacity = OP_OPAQUE) πŸ”— Source


void Arc(int layer, int x, int y, int radius, int start_degrees, int end_degrees, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool closed = true, bool fill = true, int opacity = OP_OPAQUE) πŸ”— Source


void Ellipse(int layer, int x, int y, int xradius, int yradius, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, bool fill = true, int opacity = OP_OPAQUE) πŸ”— Source


void Line(int layer, int x, int y, int x2, int y2, int color, int scale = 1, int rx = 0, int ry = 0, int rot_degrees = 0, int opacity = OP_OPAQUE) πŸ”— Source


void Spline(int layer, int x1, int y1, int x2, int y2, int x3, int y3, int x4, int y4, int color, int opacity = OP_OPAQUE) πŸ”— Source


void PutPixel(int layer, int x, int y, int color, int rx = 0, int ry = 0, int rot_degrees = 0, int opacity = OP_OPAQUE) πŸ”— Source


void PutPixels(int layer, int ptr, int rx, int ry, int rot_degrees) πŸ”— Source

Puts multiple pixels to the screen in one function call.

PutPixels() expects an array as its arg, with the array in the format of repeating blocks of { x, y, color, trans } Example:

PutPixels(1, { 25, 10, 5, OP_OPAQUE, 26, 10, 6, OP_OPAQUE }, 0, 0, 0 );

This draws two pixels to the screen. The first is at coordinates (25, 10), color 5, and it is opaque. The second is at coordinates (26, 10), color 6, and opaque.


void DrawTiles(int layer, int ptr) πŸ”— Source

Similar to FastTile(), but it draws multiple tiles in one call.

The arg *ptr[] should be an array with repeating sets of: {x,y,tile,color,opacity}

…per tile that you want to draw.


void DrawCombos(int layer, int ptr) πŸ”— Source

Similar to FastCombo, but draws multiple combos in one call.

The arg *ptr[] should be an array with repeating sets of: {x,y,combo,cset,opacity}

…per combo that you want to draw.


void Lines(int layer, int ptr) πŸ”— Source

Similar to Line(0, but draws multiple lines in one call.

The arg *ptr[] should be an array with repeating sets of: { x, y, x2, y2, color, scale, rx, ry, angle, opacity }

…per line that you want to draw.


void DrawCharacter(int layer, int x, int y, int font, int color, int bg_color, int width, int height, char32 c, int opacity = OP_OPAQUE) πŸ”— Source


void DrawInteger(int layer, int x, int y, int font, int color, int bg_color, int width, int height, int value, int num_decimal_places = 0, int opacity = OP_OPAQUE) πŸ”— Source


void DrawTile(int layer, int x, int y, int tile, int block_w, int block_h, int cset, int xscale = -1, int yscale = -1, int rx = 0, int ry = 0, int rot_degrees = 0, int flip = 0, bool transparency = true, int opacity = OP_OPAQUE) πŸ”— Source


void DrawTileCloaked(int layer, int x, int y, int tile, int blockw, int blockh, int flip = 0) πŸ”— Source

As DrawTile(), but draws with a cloaked effect.


void DrawCombo(int layer, int x, int y, int combo, int w, int h, int cset, int xscale = -1, int yscale = -1, int rx = 0, int ry = 0, int rot_degrees = 0, int frame = 0, int flip = 0, bool transparency = true, int opacity = OP_OPAQUE) πŸ”— Source


void DrawComboCloaked(int layer, int x, int y, int combo, int tilewidth, int tileheight, int flip = 0) πŸ”— Source

As DrawCombo(), but draws with a cloaked effect.


void Quad(int layer, int x1, int y1, int x2, int y2, int x3, int y3, int x4, int y4, int w, int h, int cset, int flip, int texture, int render_mode) πŸ”— Source


void Triangle(int layer, int x1, int y1, int x2, int y2, int x3, int y3, int w, int h, int cset, int flip, int texture, int render_mode) πŸ”— Source


void Quad3D(int layer, int[] pos, int[] uv, int[] csets, int[] size, int flip, int texture, int render_mode) πŸ”— Source


void Triangle3D(int layer, int[] pos, int[] uv, int[] csets, int[] size, int flip, int tile, int polytype) πŸ”— Source


void FastTile(int layer, int x, int y, int tile, int cset, int opacity = OP_OPAQUE) πŸ”— Source


void FastCombo(int layer, int x, int y, int combo, int cset, int opacity = OP_OPAQUE) πŸ”— Source


void DrawString(int layer, int x, int y, int font, int color, int background_color, int format, char32[] str, int opacity = OP_OPAQUE) πŸ”— Source


void DrawString(int layer, int x, int y, int font, int color, int background_color, int format, char32[] str, int opacity, int shadow_type, int shadow_color) πŸ”— Source

As DrawString(), but includes a shadow on the text.

Valid values for shadow_type: ShadowType (SHD_).


void DrawLayer(int layer, int source_map, int source_screen, int source_layer, int x, int y, int rotation = 0, int opacity = OP_OPAQUE) πŸ”— Source


void DrawScreen(int layer, int map, int screen, int x, int y, int rotation = 0) πŸ”— Source


void DrawBitmap(int layer, int bitmap_id, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation, bool mask) πŸ”— Source


void DrawBitmapEx(int layer, int bitmap_id, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation = 0, int cx = 0, int cy = 0, int mode = 0, int lit = 0, bool mask = true) πŸ”— Source


void TileBlit(int layer, int tile, int cset, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation = 0, int cx = 0, int cy = 0, int mode = 0, int lit = 0, bool mask = true) πŸ”— Source

As β€˜bitmap->BlitTo’, but draws from a tile instead of a bitmap

Blit supports multiple MODES, OR’d together as a bitmask:

const int BITDX_NORMAL = 0;
const int BITDX_TRANS = 0x01; //Translucent
const int BITDX_PIVOT = 0x02; //THe sprite will rotate at a specific
point, instead of its center. const int BITDX_HFLIP = 0x04; //Horizontal
Flip const int BITDX_VFLIP = 0x08; //Vertical Flip.

You can also set a pivot point for the rotation, using β€˜int cx’ and β€˜int cy’

If these are non-zero, the rotation anchor point will center on these coordinates.

You may specify a color to β€˜int lit’ to use a lit mode. This tints the entire bitmap using that color index of the main palette.


void ComboBlit(int layer, int combo, int cset, int source_x, int source_y, int source_w, int source_h, int dest_x, int dest_y, int dest_w, int dest_h, int rotation = 0, int cx = 0, int cy = 0, int mode = 0, int lit = 0, bool mask = true) πŸ”— Source

As β€˜TileBlit’, but uses the current tile of a specified combo.

Blit supports multiple MODES, OR’d together as a bitmask:

const int BITDX_NORMAL = 0;
const int BITDX_TRANS = 0x01; //Translucent
const int BITDX_PIVOT = 0x02; //THe sprite will rotate at a specific
point, instead of its center. const int BITDX_HFLIP = 0x04; //Horizontal
Flip const int BITDX_VFLIP = 0x08; //Vertical Flip.

You can also set a pivot point for the rotation, using β€˜int cx’ and β€˜int cy’

If these are non-zero, the rotation anchor point will center on these coordinates.

You may specify a color to β€˜int lit’ to use a lit mode. This tints the entire bitmap using that color index of the main palette.


void SetRenderTarget(int rt) πŸ”— Source

param RenderTarget (RT_) rt

Gets/sets the current β€œRender Target”. Most times this should be β€˜RT_SCREEN’, though versions older than 2.55 required using this for bitmap drawing. 2.55’s bitmap effectively obsolete the render target system, and should be used instead of this.


void Message(int message_id) πŸ”— Source

Triggers the message number message_id from the Strings table to be displayed on the screen.

If message_id is 0, any message being displayed will be removed.


int NumLWeapons() πŸ”— Source

Returns the number of the given object type that are present on the current screen.

Deprecated: Use NumLWeapons instead!


lweapon LoadLWeapon(int n) πŸ”— Source

param int n - Between 1 and NumLWeapons (inclusive).

Returns a pointer to the nth lweapon on the screen.


lweapon CreateLWeapon(int type) πŸ”— Source

param LWeaponType (LW_) type

Creates a new lweapon sprite, with the given type.


int NumEWeapons() πŸ”— Source

Returns the number of the given object type that are present on the current screen.

Deprecated: Use NumEWeapons instead!


eweapon LoadEWeapon(int n) πŸ”— Source

param int n - Between 1 and NumEWeapons (inclusive).

Returns a pointer to the nth eweapon on the screen.


eweapon CreateEWeapon(int type) πŸ”— Source

param EWeaponType (EW_) type

Creates a new eweapon sprite, with the given type.


bool isSolid(int x, int y) πŸ”— Source


bool isSolidLayer(int x, int y, int layer) πŸ”— Source

As Screen->isSolid(), but instead of returning true if there is solidity on layers 0, 1, or 2 - returns the solidity only for the specified layer.


void TriggerSecrets() πŸ”— Source

Triggers secrets on this screen (Screen->Index).

Temporary only, for permanent use Screen->State[].


void TriggerSecrets(int screen) πŸ”— Source

Triggers secrets on the provided screen, which must be within the current Region.

Temporary only, for permanent use Game->LoadTempScreen() and mapdata::State[].


void ZapIn() πŸ”— Source

Plays the warping screen β€˜zap’ effect.


void ZapOut() πŸ”— Source

Plays the warping screen β€˜zap’ effect.


void WavyIn() πŸ”— Source

Plays the warping screen β€˜wave’ effect.


void WavyOut() πŸ”— Source

Plays the warping screen β€˜wave’ effect.


void OpeningWipe() πŸ”— Source

Plays the warping screen β€˜wipe’ effect, respecting the wipe-related QRs.


void ClosingWipe() πŸ”— Source

Plays the warping screen β€˜wipe’ effect, respecting the wipe-related QRs.


void OpeningWipe(int effect) πŸ”— Source

Plays the warping screen β€˜wipe’ effect.

Valid values for effect: WipeEffect (WIPE_).


void ClosingWipe(int effect) πŸ”— Source

Plays the warping screen β€˜wipe’ effect.

Valid values for effect: WipeEffect (WIPE_).


void Polygon(int layer, int num_points, int vertices, int color, int opacity = OP_OPAQUE) πŸ”— Source


void DrawFrame(int layer, int x, int y, int tile, int cset, int width, int height, bool overlay = true, int opacity = OP_OPAQUE) πŸ”— Source

Draws a frame using a 2x2 block of tiles, where the upper-left corner of which is the β€˜tile’ value

This works based on how the engine subscreen frame object works, stretching the frame from those tiles to whatever size you specify.

Width/height are in 8-pixel increments; ex. 4,4 would give a 2x2 tile block; 8,8 would give a 4x4.


bool SecretsTriggered() πŸ”— Source

Returns true if secrets have been triggered on this screen (including temp).

Deprecated: Use SecretsTriggered instead!


bool SpawnScreenEnemies() πŸ”— Source

Immediately attempts to spawn all the screen enemies (Enemy[]), using the Pattern.


bool TriggerCombo(int layer, int pos) πŸ”— Source

Attempts to trigger the combo at β€˜layer,pos’. Returns true on success, false on failure.


int NumPortals() πŸ”— Source

Returns the number of the given object type that are present on the current screen.

Deprecated: Use NumPortals instead!


portal LoadPortal(int n) πŸ”— Source

param int n - Between 1 and NumPortals (inclusive).

Returns a pointer to the nth portal on the screen.


portal CreatePortal() πŸ”— Source

Creates a new portal object.


void DrawLightSquare(int cx, int cy, int radius = -1, int transp_rad = -1, int dith_rad = -1, int dith_type = -1, int dith_arg = -1) πŸ”— Source

Draws a square light to the engine darkroom bitmap, centered on β€˜cx,cy’. Any of the args that defaults to -1, if passed as -1, will use the default value from Game->Generic[] associated.


void DrawLightCircle(int cx, int cy, int radius = -1, int transp_rad = -1, int dith_rad = -1, int dith_type = -1, int dith_arg = -1) πŸ”— Source

Draws a circular light to the engine darkroom bitmap, centered on β€˜cx,cy’. Any of the args that defaults to -1, if passed as -1, will use the default value from Game->Generic[] associated.


void DrawLightCone(int cx, int cy, int dir, int length = -1, int transp_rad = -1, int dith_rad = -1, int dith_type = -1, int dith_arg = -1) πŸ”— Source

Draws a cone of light to the engine darkroom bitmap, emanating in the 8-dir β€˜dir’ from the point β€˜cx,cy’. Any of the args that defaults to -1, if passed as -1, will use the default value from Game->Generic[] associated.


bool GetExDoor(int dir, int index) πŸ”— Source

Returns a door state for the screen.

Each direction (DIR_UP,DIR_DOWN,DIR_LEFT,DIR_RIGHT) has 8 indexes (0-7)


void SetExDoor(int dir, int index, bool state) πŸ”— Source

Sets a door state for the screen.

Each direction (DIR_UP,DIR_DOWN,DIR_LEFT,DIR_RIGHT) has 8 indexes (0-7)


void SetSideWarp(int warp_id, int screen, int dmap, int type) πŸ”— Source

Valid values for type: WarpType (WT_).


void SetTileWarp(int warp_id, int screen, int dmap, int type) πŸ”— Source


lweapon CreateLWeaponDx(int type, int baseitem) πŸ”— Source

Create an lweapon with sprites, sounds, and other values set as if it was generated by a specific item.


npc LoadNPCByUID(int uid) πŸ”— Source

Deprecated.


lweapon LoadLWeaponByUID(int uid) πŸ”— Source

Deprecated.


eweapon LoadEWeaponByUID(int uid) πŸ”— Source

Deprecated.


int LayerMap(int layer) πŸ”— Source

Deprecated: Use LayerMap[] instead!


int LayerScreen(int layer) πŸ”— Source

Deprecated: Use LayerScreen[] instead!


int GetSideWarpDMap(int warp_id) πŸ”— Source

Deprecated: Use SideWarpDMap[] instead!


int GetSideWarpScreen(int warp_id) πŸ”— Source

Deprecated: Use SideWarpScreen[] instead!


int GetSideWarpType(int warp_id) πŸ”— Source

Deprecated: Use SideWarpType[] instead!


int GetTileWarpDMap(int warp_id) πŸ”— Source

Deprecated: Use TileWarpDMap[] instead!


int GetTileWarpScreen(int warp_id) πŸ”— Source

Deprecated: Use TileWarpScreen[] instead!


int GetTileWarpType(int warp_id) πŸ”— Source

Deprecated: Use TileWarpType[] instead!