IMapRendererContext.h 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  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. virtual double viewTransitionProgress() const = 0;
  52. /// if true, rendered images will be converted to grayscale
  53. virtual bool filterGrayscale() const = 0;
  54. virtual bool showRoads() const = 0;
  55. virtual bool showRivers() const = 0;
  56. virtual bool showBorder() const = 0;
  57. /// if true, world view overlay will be shown
  58. virtual bool showOverlay() const = 0;
  59. /// if true, map grid should be visible on map
  60. virtual bool showGrid() const = 0;
  61. virtual bool showVisitable() const = 0;
  62. virtual bool showBlockable() const = 0;
  63. };