mapdata#
Represents a single map screen.
Depending on how the mapdata
was loaded, it may represent different things.
Temporary screens
A single temporary screen, aka a live reference to a currently loaded screen.
Modifications to temporary screens are lost when a new region is loaded.
Load via:
Game->LoadTempScreen() - the one that takes a screen and a layer parameter. Loads from the current region.
Game->LoadTempScreenForComboPos() Loads from the current region.
Game->LoadScrollingScreen() - the one that takes a screen and a layer parameter. Loads from the previous region, valid during scrolling only.
Temporary screens (whole-region)
When representing every temporary screen in an active Region, the combo array variables can access every position in a region, but variables representing values from a singular screen only read from the top-left screen (the origin screen) of the Region. This is exactly like how Screen works.
Load via:
Game->LoadTempScreen() - the one that takes just a layer
Game->LoadScrollingScreen() - the one that takes just a layer
Canonical screens
The βofficialβ copy of the mapdata. Temporary screens are copied from canonical screens when the player loads into a new region.
Modifications to canonical screens will not update any associated temporary screens (until the next time the player loads that screen).
Load via:
Tutorials#
Variables#
int |
|
int |
|
int |
|
int |
|
int |
|
int |
|
int[] |
|
int |
|
untyped[] |
|
bool[] |
|
int |
|
int[] |
|
int[] |
|
int |
|
int |
|
int |
|
int |
|
int |
|
int[] |
|
int[] |
|
int[] |
|
int |
|
int[] |
|
int |
|
int[] |
|
int[] |
|
int |
|
int |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int |
|
int |
|
int |
|
int |
|
int |
|
int |
|
int[] |
|
int[] |
|
int[] |
|
bool[] |
|
bool[] |
|
int |
|
int |
|
int |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int |
|
int |
|
int |
|
int |
|
int |
|
int[] |
|
const int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
int[] |
|
bool[] |
|
bool[] |
|
const int |
|
const int |
|
bool[] |
|
bool[] |
|
int |
|
untyped[] |
|
int |
|
bool[] |
|
int |
|
int |
|
int |
|
const int |
|
untyped[] |
D deprecated |
int |
HasItem deprecated |
const int[] |
SFlags deprecated |
int |
EnemyFlags deprecated |
int |
SideWarpIndex deprecated |
int |
EntryX deprecated |
int |
EntryY deprecated |
const bool[] |
NumFFCs deprecated |
int |
LensLayer deprecated |
Functions#
bool |
isSolid(int x, int y) |
bool |
isSolidLayer(int x, int y, int layer) |
untyped |
GetFFCInitD(int ffc_index, int n) |
void |
SetFFCInitD(int ffc_index, int n, untyped value) |
bool |
GetExDoor(int dir, int index) |
void |
SetExDoor(int dir, int index, bool state) |
Enumerations#
Used with Screen->RoomType, mapdata::RoomType (RT_).
RoomType RT_DOORREPAIR = 5
RoomType RT_FEEDTHEGORIYA = 7
RoomType RT_GAMBLE = 4
RoomType RT_GANON = 15
RoomType RT_ITEMPOND = 17
Doesnβt work.
RoomType RT_LEARNSLASH = 19
RoomType RT_LEVEL9ENTRANCE = 8
RoomType RT_MAGICUPGRADE = 18
RoomType RT_MONEYORLIFE = 12
RoomType RT_MOREARROWS = 20
RoomType RT_MOREBOMBS = 11
RoomType RT_NONE = 0
RoomType RT_PAYFORINFO = 2
RoomType RT_POTIONORHEART = 6
RoomType RT_POTIONSHOP = 9
RoomType RT_SECRETMONEY = 3
RoomType RT_SHOP = 10
RoomType RT_SPECIALITEM = 1
RoomType RT_STAIRWARP = 14
RoomType RT_TAKEONEITEM = 21
RoomType RT_TENRUPEES = 13
RoomType RT_ZELDA = 16
Used with mapdata::Door[] and Screen->Door[].
DoorIndex DOOR_UP = 0
DoorIndex DOOR_DOWN = 1
DoorIndex DOOR_LEFT = 2
DoorIndex DOOR_RIGHT = 3
Used with mapdata::Door[] and Screen->Door[].
DoorType D_WALL = 0
DoorType D_OPEN = 1
DoorType D_LOCKED = 2
DoorType D_UNLOCKED = 3
A locked door that has been opened.
DoorType D_SHUTTER = 4
Defeat enemies to unlock this door.
DoorType D_BOMB = 6
A door that changes when bombed.
DoorType D_BOMBED = 7
A door that has been bombed.
DoorType D_WALKTHRU = 8
Push against the wall to pass through.
DoorType D_BOSSLOCKED = 10
DoorType D_BOSSUNLOCKED = 11
A boss door that has been opened.
DoorType D_OPENSHUTTER = 12
A shutter that has been opened.
DoorType D_1WAYSHUTTER = 14
A shutter that locks behind you and never opens.
DoorType D_NONE = 16
No door at all. Hero will not auto-walk.
Used with mapdata::FFCFlags[].
FFCBitflags FFCBF_OVERLAY = 1
FFCBitflags FFCBF_TRANS = 2
FFCBitflags FFCBF_SOLID = 4
FFCBitflags FFCBF_CARRYOVER = 8
FFCBitflags FFCBF_STATIONARY = 16
FFCBitflags FFCBF_CHANGER = 32
FFCBitflags FFCBF_PRELOAD = 64
FFCBitflags FFCBF_LENSVIS = 128
FFCBitflags FFCBF_RESET = 256
FFCBitflags FFCBF_ETHEREAL = 512
FFCBitflags FFCBF_IGNOREHOLDUP = 1024
FFCBitflags FFCBF_IGNORECHANGER = 2048
FFCBitflags FFCBF_IMPRECISIONCHANGER = 4096
FFCBitflags FFCBF_LENSINVIS = 8192
enum SecretComboIndex: π Source
Used with Screen->SecretCombo[], Screen->SecretCSet[], Screen->SecretFlags[], and mapdata.
SecretComboIndex SECCMB_BCANDLE = 0
SecretComboIndex SECCMB_ARROW = 1
SecretComboIndex SECCMB_BOMB = 2
SecretComboIndex SECCMB_STAIRS = 3
SecretComboIndex SECCMB_SECRET01 = 4
SecretComboIndex SECCMB_SECRET02 = 5
SecretComboIndex SECCMB_SECRET03 = 6
SecretComboIndex SECCMB_SECRET04 = 7
SecretComboIndex SECCMB_SECRET05 = 8
SecretComboIndex SECCMB_SECRET06 = 9
SecretComboIndex SECCMB_SECRET07 = 10
SecretComboIndex SECCMB_SECRET08 = 11
SecretComboIndex SECCMB_SECRET09 = 12
SecretComboIndex SECCMB_SECRET10 = 13
SecretComboIndex SECCMB_SECRET11 = 14
SecretComboIndex SECCMB_SECRET12 = 15
SecretComboIndex SECCMB_SECRET13 = 16
SecretComboIndex SECCMB_SECRET14 = 17
SecretComboIndex SECCMB_SECRET15 = 18
SecretComboIndex SECCMB_SECRET16 = 19
SecretComboIndex SECCMB_RCANDLE = 20
SecretComboIndex SECCMB_WANDFIRE = 21
SecretComboIndex SECCMB_DINSFIRE = 22
SecretComboIndex SECCMB_SARROW = 23
SecretComboIndex SECCMB_GARROW = 24
SecretComboIndex SECCMB_SBOMB = 25
SecretComboIndex SECCMB_BRANG = 26
SecretComboIndex SECCMB_MBRANG = 27
SecretComboIndex SECCMB_FBRANG = 28
SecretComboIndex SECCMB_WANDMAGIC = 29
SecretComboIndex SECCMB_REFMAGIC = 30
SecretComboIndex SECCMB_REFFIREBALL = 31
SecretComboIndex SECCMB_SWORD = 32
SecretComboIndex SECCMB_WSWORD = 33
SecretComboIndex SECCMB_MSWORD = 34
SecretComboIndex SECCMB_XSWORD = 35
SecretComboIndex SECCMB_SWORDBEAM = 36
SecretComboIndex SECCMB_WSWORDBEAM = 37
SecretComboIndex SECCMB_MSWORDBEAM = 38
SecretComboIndex SECCMB_XSWORDBEAM = 39
SecretComboIndex SECCMB_HOOKSHOT = 40
SecretComboIndex SECCMB_WAND = 41
SecretComboIndex SECCMB_HAMMER = 42
SecretComboIndex SECCMB_STRIKE = 43
SecretComboIndex SECCMB_SECRETSNEXT = 44
Only ->SecretFlags[] has a value for this index.
SecretComboIndex SECCMB_MAX = 45
enum NoCarryBitflags: π Source
Used with mapdata::NoCarry and screendata::NoCarry.
NoCarryBitflags NOCARRY_B_SECRET = 8192
NoCarryBitflags NOCARRY_B_ITEM = 16
NoCarryBitflags NOCARRY_B_SPECIALITEM = 32
NoCarryBitflags NOCARRY_B_LOCKBLOCK = 256
NoCarryBitflags NOCARRY_B_BOSSLOCKBLOCK = 512
NoCarryBitflags NOCARRY_B_CHEST = 1024
NoCarryBitflags NOCARRY_B_LOCKEDCHEST = 2048
NoCarryBitflags NOCARRY_B_BOSSCHEST = 4096
enum NoResetBitflags: π Source
Used with mapdata::NoReset and screendata::NoReset.
NoResetBitflags NORESET_B_SECRET = 8192
NoResetBitflags NORESET_B_ITEM = 16
NoResetBitflags NORESET_B_SPECIALITEM = 32
NoResetBitflags NORESET_B_LOCKBLOCK = 256
NoResetBitflags NORESET_B_BOSSLOCKBLOCK = 512
NoResetBitflags NORESET_B_CHEST = 1024
NoResetBitflags NORESET_B_LOCKEDCHEST = 2048
NoResetBitflags NORESET_B_BOSSCHEST = 4096
NoResetBitflags NORESET_B_DOOR_B_UP = 1
NoResetBitflags NORESET_B_DOOR_B_DOWN = 2
NoResetBitflags NORESET_B_DOOR_B_LEFT = 4
NoResetBitflags NORESET_B_DOOR_B_RIGHT = 8
Screen states. Use these with Screen->State[], etc.
ScreenState ST_DOORUP = 0
The locked/bomb door has been permanently unlocked/bombed
ScreenState ST_DOORDOWN = 1
The locked/bomb door has been permanently unlocked/bombed
ScreenState ST_DOORLEFT = 2
The locked/bomb door has been permanently unlocked/bombed
ScreenState ST_DOORRIGHT = 3
The locked/bomb door has been permanently unlocked/bombed
ScreenState ST_ITEM = 4
If set, the item is gone
ScreenState ST_SPECIALITEM = 5
If set, the Cave/Item Cellar/Dive For Item/Armos item is gone
ScreenState ST_ENEMYNORETURN = 6
If set, enemies wonβt return
ScreenState ST_TEMPNORETURN = 7
If set, enemies wonβt return. This is automatically unset when you leave the DMap
ScreenState ST_LOCKBLOCK = 8
The lock block on the screen has been triggered
ScreenState ST_BOSSLOCKBLOCK = 9
The boss lock block on the screen has been triggered
ScreenState ST_CHEST = 10
The unlocked chest on this screen has been opened
ScreenState ST_LOCKEDCHEST = 11
The locked chest on this screen has been opened
ScreenState ST_BOSSCHEST = 12
The boss chest on this screen has been opened
ScreenState ST_SECRET = 13
Screen Secrets have been made permanent
ScreenState ST_VISITED = 14
If set, this screen will appear on the Overworld Map
ScreenState ST_LIGHTBEAM = 15
If set, the light triggers on the screen have been triggered
Variable descriptions#
True if the screen is valid. Screens that appear with the default blue background in the editor are invalid. Modifying a combo on a screen turns it valid.
If a layer is invalid, it will not be drawn.
The screenβs Region ID.
May only be written to for canonical mapdata (Game->LoadMapData()).
The screen guy.
The screen string.
value
RoomType
The special room type.
The item placed on the screen. -1 if no item placed.
int[] TileWarpType π Source
value
WarpType (WT_)
The Tile Warp type for Tile Warps A, B, C, and D; [0], [1], [2], and [3] respectively.
The screen script that runs on this screen.
The 8 script arguments for the script that runs on this screen.
bool[] TileWarpOverlay π Source
Set or get the overlay state for the warp ID corresponding to the index of this array.
The Door Set used for the NES dungeon doors on this screen.
The X-component for each of the four 2.50+ (blue) warp return squares.
The Y-component for each of the four 2.50+ (blue) warp return squares.
The X/Y position of the βStairsβ secret on the screen.
The X/Y position of the βStairsβ secret on the screen.
The X/Y position the screenβs item spawns at.
The X/Y position the screenβs item spawns at.
The palette set in the F4 menu in ZQuest for this screen. Has no effect during play, but can be read and written.
index
DoorIndex (DOOR_)
value
DoorType (D_)
The 4 door states of 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.
The Maze Path βExit Directionβ.
The 10 enemies that appear on this screen.
value
EnemyPattern (PATTERN_)
The spawn pattern for the screen enemies.
int[] SideWarpType π Source
value
WarpType (WT_)
The Sidewarp type for Sidewarps A, B, C, and D; [0], [1], [2], and [3] respectively.
int[] SideWarpOverlay π Source
Set or get the overlay state for the warp ID corresponding to the index of this array.
The X-component for the pre-2.50 (green) arrival square.
The X-component for the pre-2.50 (green) arrival square.
length
4
value
DIR_UP, DIR_DOWN, DIR_LEFT, DIR_RIGHT
The four directions you must go for the maze path.
int[] SideWarpScreen π Source
The destination screen for each of the four sidewarps.
index
DIR_UP, DIR_DOWN, DIR_LEFT, DIR_RIGHT
value
SideWarpIndex
The sidewarp ID for each screen edge.
SIDEWARP_NONE if there is no sidewarp in that direction.
int[] TileWarpReturnSquare π Source
The return square used by the Tile Warp (A, B, C, D).
int[] SideWarpReturnSquare π Source
The return square used by the Side Warp (A, B, C, D).
int[] SideWarpDMap π Source
The destination DMap for each of the four sidewarps.
The screenβs undercombo, which will appear as a result of various combo interactions, such as pushing blocks, awakening armos, etc.
The CSet associated with the undercombo.
The screenβs βcatchallβ value. This is the roomtype-specific data, such as the βSpecial Itemβ in a βSpecial Itemβ room.
The value of damage combo sensitivity for the screen.
The No Reset
carryover flags.
The No Carry Over
carryover flags.
The map and screen for each layer. Index [0] of these arrays does nothing, and is invalid to access.
The map and screen for each layer. Index [0] of these arrays does nothing, and is invalid to access.
int[] LayerOpacity π Source
The opacity value (OP_OPAQUE
or OP_TRANS
) for each layer. Index [0]
does nothing, and is invalid to access.
bool[] LayerInvisible π Source
If true, the given layer is invisible and will not be drawn.
bool[] ScriptDraws π Source
If false, the given layer of script draws will be disabled. Only applies if this screen is the origin screen of the current Region.
int TimedWarpTimer π Source
The timer used by βTime Warp Ticsβ in Screen Data->T.Warp
The map and screen that screen states carry over to.
The map and screen that screen states carry over to.
The combo that will be placed for each secret type.
The cset that will be placed for each secret type.
The screen flags that will be placed for each secret type.
The Data (combo ID) variable for each of the ffcs on the screen.
See ffc::Data for more details.
If this mapdata
was loaded via Game->LoadTempScreen() and layer 0,
this array and the other FFC arrays reference the live FFCs.
The CSet variable for each of the ffcs on the screen.
See ffc::CSet for more details.
The Delay variable for each of the ffcs on the screen.
See ffc::Delay for more details.
The X variable for each of the ffcs on the screen.
See ffc::X for more details.
The Y variable for each of the ffcs on the screen.
See ffc::Y for more details.
The Vx variable for each of the ffcs on the screen.
See ffc::Vx for more details.
The Vy variable for each of the ffcs on the screen.
See ffc::Vy for more details.
The Ax variable for each of the ffcs on the screen.
See ffc::Ax for more details.
The Vy variable for each of the ffcs on the screen.
See ffc::Vy for more details.
The Flags variable for each of the ffcs on the screen.
See ffc::Flags[] for more details.
int[] FFCEffectWidth π Source
The EffectWidth variable for each of the ffcs on the screen.
See ffc::EffectWidth for more details.
int[] FFCEffectHeight π Source
The EffectHeight variable for each of the ffcs on the screen.
See ffc::EffectHeight for more details.
int[] FFCTileWidth π Source
The TileWidth variable for each of the ffcs on the screen.
See ffc::TileWidth for more details.
int[] FFCTileHeight π Source
The TileHeighr variable for each of the ffcs on the screen.
See ffc::TileHeight for more details.
The Link variable for each of the ffcs on the screen.
See ffc::Link for more details.
The Script variable for each of the ffcs on the screen.
See ffc::Script for more details.
The SFX for the ambient sound of the screen.
The SFX for the boss roar on this screen.
The SFX that will play when secrets are triggered on this screen.
The SFX that will play when an item is held up on this screen.
The βScreen MIDIβ to play for this screen.
index
ScreenFlagGroup (SF_)
value
Varies based on ScreenFlagGroup (SF_)
Multiple bitflags, split into groups.
const int[] EFlags π Source
index
ScreenEnemyFlagGroup (SEF_)
value
Varies based on ScreenEnemyFlagGroup (SEF_)
Multiple bitflags related to screen enemies, split into groups.
The Combo ID placed at each position on the screen.
If this is a temporary screen loading with Game->LoadTempScreen(layer)
, then this allows access to every combo in the current region.
The CSet of the combo placed at each position on the screen.
If this is a temporary screen loading with Game->LoadTempScreen(layer)
, then this allows access to every combo in the current region.
The mapflag placed at each position on the screen.
If this is a temporary screen loading with Game->LoadTempScreen(layer)
, then this allows access to every combo in the current region.
The inherent flag of the combo placed at each position on the screen.
If this is a temporary screen loading with Game->LoadTempScreen(layer)
, then this allows access to every combo in the current region.
The combo type of the combo placed at each position on the screen.
If this is a temporary screen loading with Game->LoadTempScreen(layer)
, then this allows access to every combo in the current region.
The solidity map of the combo placed at each position on the screen.
If this is a temporary screen loading with Game->LoadTempScreen(layer)
, then this allows access to every combo in the current region.
The effect map of the combo placed at each position on the screen.
If this is a temporary screen loading with Game->LoadTempScreen(layer)
, then this allows access to every combo in the current region.
index
ScreenState (ST_)
The screen states used for this screen.
The 32 βExtra Statesβ used for this screen.
Returns the map this mapdata points to.
Returns the screen this mapdata points to.
Arrays of the 7 layer show/hide values for the lens of truth.
Arrays of the 7 layer show/hide values for the lens of truth.
Read-write, the size of the Data[] array.
Resizable array of data for scripts to use. All changes are saved to the save file.
Number of enemies remaining alive on this screen.
Returns true if the specified ffc is running a script?
May be used to pause/resume ffc script execution?
This needs to be cloned over to ffc->Running
The βAmbient Soundβ under S.Data2.
Rename this to AmbientSFX, or just SFX.
The screen palette.
const int CarryoverScreen π Source
Improperly implemented. Was meant to relate as Screen->D, except that
Screen->D is not bound to layermap.
Deprecated: mapdata->D[] has never worked!
If not zero, then the item for this screen is shown.
Deprecated: Use Item > -1
instead!
const int[] SFlags π Source
Deprecated: Use Flags[] instead!
Bitflags for enemies on the screen (E.Flags).
Deprecated: Use EFlags[] instead!
The warp return IDs.
Deprecated: by SideWarpID[].
Deprecated: Use Hero->RespawnX instead!
Deprecated: Use Hero->RespawnY instead!
const bool[] NumFFCs π Source
Deprecated.
Deprecated.
Function descriptions#
bool isSolid(int x, int y) π Source
Returns true if the given x,y position on the screen is βsolidβ.
bool isSolidLayer(int x, int y, int layer) π Source
Returns true if the given x,y position on the screen is βsolidβ.
untyped GetFFCInitD(int ffc_index, int n) π Source
Returns the value of InitDn
for the ffc on the screen with an ID of
ffc_index.
This needs to be converted to the type βuntypedβ to comply with the change of float ffc->InitD[] to untyped ffc->InitD[]
void SetFFCInitD(int ffc_index, int n, untyped value) π Source
Sets the value of InitDn
for the ffc on the screen with an ID of
ffc_index.
βint valueβ needs to be converted to the type βuntypedβ to comply with the change of float ffc->InitD[] to untyped ffc->InitD[]
bool GetExDoor(int dir, int index) π Source
Returns a door state for the screen.
void SetExDoor(int dir, int index, bool state) π Source
Sets a door state for the screen.