diff options
author | WBoerenkamps <wrj.boerenkamps@student.avans.nl> | 2024-10-25 20:59:34 +0200 |
---|---|---|
committer | WBoerenkamps <wrj.boerenkamps@student.avans.nl> | 2024-10-25 20:59:34 +0200 |
commit | 15a4c4a1cf67e13be53ef423c51c56488f332ea9 (patch) | |
tree | 661084fc8171089ce32bf779f2b3a85d634b38e4 /mwe/resource-manager/tiledMap.cpp | |
parent | f472e0ba3bf54fc5055cf9f08925bed3f98a1dbc (diff) | |
parent | b3b762a34e7ccb4a0dcd041a693ac7180af16002 (diff) |
merge conficts fixed
Diffstat (limited to 'mwe/resource-manager/tiledMap.cpp')
-rw-r--r-- | mwe/resource-manager/tiledMap.cpp | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/mwe/resource-manager/tiledMap.cpp b/mwe/resource-manager/tiledMap.cpp new file mode 100644 index 0000000..836929c --- /dev/null +++ b/mwe/resource-manager/tiledMap.cpp @@ -0,0 +1,70 @@ + + +#include "tiledMap.h" +#include "TextureMap.h" +#include "map_layer.h" +#include <SDL_render.h> +#include <cassert> +#include <iostream> +#include <ostream> +#include <string> +#include <tmxlite/Layer.hpp> +#include <tmxlite/Map.hpp> + +TiledMap::TiledMap(const std::string & content) { + if (m_TmxMap.loadFromString(content, "../../asset/tiled/")) { + std::cout << "Map loaded correctly " << std::endl; + } +} + +TiledMap::~TiledMap() { + for (const auto & r : m_MapTextures) { + delete r; + } + m_MapTextures.clear(); + + for (const auto & m : m_RenderLayers) { + delete m; + } + m_RenderLayers.clear(); +} + +void TiledMap::SetRenderer(SDL_Renderer & renderer) { + this->m_Renderer = &renderer; + this->SetMapTextures(); + this->SetMapLayers(); +} + +void TiledMap::draw() const { + for (const auto & l : m_RenderLayers) { + l->draw(m_Renderer); + } +} + +void TiledMap::SetMapTextures() { + const auto & tileSets = m_TmxMap.getTilesets(); + assert(~tileSets.empty()); + + std::cout << "Processing SetMapTextures " << std::endl; + + for (const auto & ts : tileSets) { + m_MapTextures.emplace_back(new TextureMap); + if (!m_MapTextures.back()->loadFromFile(ts.getImagePath(), + m_Renderer)) { + std::cerr << "Failed opening " << ts.getImagePath() << "\n"; + } + } +} + +void TiledMap::SetMapLayers() { + const auto & mapLayers = m_TmxMap.getLayers(); + + std::cout << "Processing SetMapLayers " << std::endl; + for (auto i = 0u; i < mapLayers.size(); ++i) { + if (mapLayers[i]->getType() == tmx::Layer::Type::Tile) { + m_RenderLayers.emplace_back(new MapLayer); + m_RenderLayers.back()->create(this->m_TmxMap, i, + this->m_MapTextures); + } + } +} |