Systems::render_map now holds the logic to render the map, and it's working well enough to use for displaying.

This commit is contained in:
Zed A. Shaw 2025-07-15 11:39:05 -04:00
parent 0d1eacdc5c
commit dca38397e7
3 changed files with 45 additions and 40 deletions

View file

@ -6,6 +6,7 @@
#include "levelmanager.hpp"
#include "systems.hpp"
using namespace fmt;
using namespace nlohmann;
using std::string;
@ -81,37 +82,6 @@ TEST_CASE("dijkstra algo test", "[map]") {
}
}
sf::Sprite render_map(Matrix& tiles, EntityGrid& entity_map, sf::RenderTexture& render) {
(void) entity_map;
sf::Vector2i size{MAP_TILE_DIM,MAP_TILE_DIM};
sf::Vector2u dim{
(unsigned int)matrix::width(tiles) * size.x,
(unsigned int)matrix::height(tiles) * size.y};
bool worked = render.resize(dim);
dbc::check(worked, "Failed to resize map render target.");
render.clear({0,0,0,0});
for(matrix::each_row it{tiles}; it.next();) {
wchar_t display = tiles[it.y][it.x];
if(display == L' ') continue; // skip for now
auto& sprite = textures::get_map_sprite(display);
sprite.setPosition({float(it.x * size.x), float(it.y * size.y)});
render.draw(sprite);
}
for(auto [point, display] : entity_map) {
auto& sprite = textures::get_map_sprite(display);
sprite.setPosition({float(point.x * size.x), float(point.y * size.y)});
render.draw(sprite);
}
render.display();
return sf::Sprite{render.getTexture()};
}
TEST_CASE("map image test", "[map-sprite]") {
components::init();
textures::init();
@ -122,6 +92,7 @@ TEST_CASE("map image test", "[map-sprite]") {
EntityGrid entity_map;
auto render = std::make_shared<sf::RenderTexture>();
sf::Sprite sprite{render->getTexture()};
auto player = level.world->get_the<components::Player>();
auto& player_pos = level.world->get<components::Position>(player.entity);
@ -131,13 +102,13 @@ TEST_CASE("map image test", "[map-sprite]") {
System::draw_map(level, map_tiles, entity_map, 2);
// on level start make one render texture with the base map
auto map_sprite = render_map(map_tiles, entity_map, *render);
}
System::render_map(map_tiles, entity_map, *render);
/*
// confirm we get two different maps
auto out_img = render->getTexture().copyToImage();
bool worked = out_img.saveToFile("map_render.png");
REQUIRE(worked);
*/
#ifdef TEST_RENDER
// confirm we get two different maps
auto out_img = render->getTexture().copyToImage();
bool worked = out_img.saveToFile(fmt::format("tmp/map_render{}{}.png", it.x, it.y));
REQUIRE(worked);
#endif
}
}