IMapRendererContext.h 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. /*
  2. * IMapRendererContext.h, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #pragma once
  11. VCMI_LIB_NAMESPACE_BEGIN
  12. class int3;
  13. class Point;
  14. class CGObjectInstance;
  15. class ObjectInstanceID;
  16. struct TerrainTile;
  17. struct CGPath;
  18. VCMI_LIB_NAMESPACE_END
  19. class IMapRendererContext
  20. {
  21. public:
  22. using MapObject = ObjectInstanceID;
  23. using MapObjectsList = std::vector<MapObject>;
  24. virtual ~IMapRendererContext() = default;
  25. /// returns dimensions of current map
  26. virtual int3 getMapSize() const = 0;
  27. /// returns true if chosen coordinates exist on map
  28. virtual bool isInMap(const int3 & coordinates) const = 0;
  29. // /// returns true if selected tile has animation and should not be cached
  30. // virtual bool tileAnimated(const int3 & coordinates) const = 0;
  31. /// returns tile by selected coordinates. Coordinates MUST be valid
  32. virtual const TerrainTile & getMapTile(const int3 & coordinates) const = 0;
  33. /// returns all objects visible on specified tile
  34. virtual const MapObjectsList & getObjects(const int3 & coordinates) const = 0;
  35. /// returns specific object by ID, or nullptr if not found
  36. virtual const CGObjectInstance * getObject(ObjectInstanceID objectID) const = 0;
  37. /// returns path of currently active hero, or nullptr if none
  38. virtual const CGPath * currentPath() const = 0;
  39. /// returns true if specified tile is visible in current context
  40. virtual bool isVisible(const int3 & coordinates) const = 0;
  41. virtual size_t objectGroupIndex(ObjectInstanceID objectID) const = 0;
  42. virtual Point objectImageOffset(ObjectInstanceID objectID, const int3 & coordinates) const = 0;
  43. /// returns object animation transparency. IF set to 0, object will not be visible
  44. virtual double objectTransparency(ObjectInstanceID objectID, const int3 &coordinates) const = 0;
  45. /// returns animation frame for selected object
  46. virtual size_t objectImageIndex(ObjectInstanceID objectID, size_t groupSize) const = 0;
  47. /// returns index of image for overlay on specific tile, or numeric_limits::max if none
  48. virtual size_t overlayImageIndex(const int3 & coordinates) const = 0;
  49. /// returns animation frame for terrain
  50. virtual size_t terrainImageIndex(size_t groupSize) const = 0;
  51. // /// returns size of ouput tile, in pixels. 32x32 for "standard" map, may be smaller for world view mode
  52. // virtual Point getTileSize() const = 0;
  53. /// if true, world view overlay will be shown
  54. virtual bool showOverlay() const = 0;
  55. /// if true, map grid should be visible on map
  56. virtual bool showGrid() const = 0;
  57. virtual bool showVisitable() const = 0;
  58. virtual bool showBlockable() const = 0;
  59. };