diff options
| author | ilotterytea <iltsu@alright.party> | 2025-02-02 15:08:42 +0500 |
|---|---|---|
| committer | ilotterytea <iltsu@alright.party> | 2025-02-02 15:08:57 +0500 |
| commit | bc9d1725c5cca89f43c8e314e6bb8088f75acf27 (patch) | |
| tree | 26acb17b7232bd2fb7d065299b2c2e0927247eeb /src/sets/tileset.hpp | |
| parent | 34f081520c754cc20c2ec929be7798fe3f3806e1 (diff) | |
feat: a base class for sets
Diffstat (limited to 'src/sets/tileset.hpp')
| -rw-r--r-- | src/sets/tileset.hpp | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/src/sets/tileset.hpp b/src/sets/tileset.hpp new file mode 100644 index 0000000..09799ce --- /dev/null +++ b/src/sets/tileset.hpp @@ -0,0 +1,41 @@ +#pragma once +#include <SFML/Graphics/Texture.hpp> + +#include "entryset.hpp" + +#define TILE_WIDTH 16 +#define TILE_HEIGHT 16 + +namespace silly::editor { + enum TilesetTileType { TILE_FLOOR = 0, TILE_WALL }; + struct TilesetTile { + int id; + sf::Texture texture; + TilesetTileType type; + }; + + class TileSet : public EntrySet<TilesetTile, TilesetTileType> { + public: + void add_entry(const std::string &path, TilesetTileType type) override { + TilesetTile tile; + tile.type = type; + tile.id = this->entries.size(); + + if (!tile.texture.loadFromFile(path)) { + // TODO: add logging here + return; + } + + this->entries.push_back(std::make_shared<TilesetTile>(tile)); + } + + void remove_entry(const TilesetTile &entry) override { + this->entries.resize(std::distance( + this->entries.begin(), + std::remove_if(this->entries.begin(), this->entries.end(), + [&entry](const std::shared_ptr<TilesetTile> &t) { + return t.get()->id == entry.id; + }))); + } + }; +}
\ No newline at end of file |
