You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
108 lines
2.2 KiB
108 lines
2.2 KiB
/** |
|
* @file automap.h |
|
* |
|
* Interface of the in-game map overlay. |
|
*/ |
|
#pragma once |
|
|
|
#include <cstdint> |
|
|
|
#include "engine.h" |
|
#include "engine/displacement.hpp" |
|
#include "engine/point.hpp" |
|
#include "gendung.h" |
|
|
|
namespace devilution { |
|
|
|
enum MapExplorationType : uint8_t { |
|
/** unexplored map tile */ |
|
MAP_EXP_NONE, |
|
/** map tile explored in vanilla - compatibility reasons */ |
|
MAP_EXP_OLD, |
|
/** map explored by a shrine */ |
|
MAP_EXP_SHRINE, |
|
/** map tile explored by someone else in multiplayer */ |
|
MAP_EXP_OTHERS, |
|
/** map tile explored by current player */ |
|
MAP_EXP_SELF, |
|
}; |
|
|
|
/** Specifies whether the automap is enabled. */ |
|
extern bool AutomapActive; |
|
/** Tracks the explored areas of the map. */ |
|
extern uint8_t AutomapView[DMAXX][DMAXY]; |
|
/** Specifies the scale of the automap. */ |
|
extern int AutoMapScale; |
|
extern Displacement AutomapOffset; |
|
extern int AmLine64; |
|
extern int AmLine32; |
|
extern int AmLine16; |
|
extern int AmLine8; |
|
extern int AmLine4; |
|
|
|
/** |
|
* @brief Initializes the automap. |
|
*/ |
|
void InitAutomapOnce(); |
|
|
|
/** |
|
* @brief Loads the mapping between tile IDs and automap shapes. |
|
*/ |
|
void InitAutomap(); |
|
|
|
/** |
|
* @brief Displays the automap. |
|
*/ |
|
void StartAutomap(); |
|
|
|
/** |
|
* @brief Scrolls the automap upwards. |
|
*/ |
|
void AutomapUp(); |
|
|
|
/** |
|
* @brief Scrolls the automap downwards. |
|
*/ |
|
void AutomapDown(); |
|
|
|
/** |
|
* @brief Scrolls the automap leftwards. |
|
*/ |
|
void AutomapLeft(); |
|
|
|
/** |
|
* @brief Scrolls the automap rightwards. |
|
*/ |
|
void AutomapRight(); |
|
|
|
/** |
|
* @brief Increases the zoom level of the automap. |
|
*/ |
|
void AutomapZoomIn(); |
|
|
|
/** |
|
* @brief Decreases the zoom level of the automap. |
|
*/ |
|
void AutomapZoomOut(); |
|
|
|
/** |
|
* @brief Renders the automap to the given buffer. |
|
*/ |
|
void DrawAutomap(const Surface &out); |
|
|
|
/** |
|
* @brief Updates automap explorer at point if value is higher than existing. |
|
*/ |
|
void UpdateAutomapExplorer(Point map, MapExplorationType explorer); |
|
|
|
/** |
|
* @brief Marks the given coordinate as within view on the automap. |
|
*/ |
|
void SetAutomapView(Point tile, MapExplorationType explorer); |
|
|
|
/** |
|
* @brief Resets the zoom level of the automap. |
|
*/ |
|
void AutomapZoomReset(); |
|
|
|
} // namespace devilution
|
|
|