aboutsummaryrefslogtreecommitdiff
path: root/mwe/resource-manager/resource_converter.cpp
diff options
context:
space:
mode:
authorLoek Le Blansch <loek@pipeframe.xyz>2024-10-31 18:41:30 +0100
committerLoek Le Blansch <loek@pipeframe.xyz>2024-10-31 18:41:30 +0100
commit8e3367b186e60eb1e33bf58a066823cb00a7566e (patch)
treec4038a31993767276efec5fa1b1a37dff3b79465 /mwe/resource-manager/resource_converter.cpp
parentb7df77d6cc26cb9ee46891d7108f01734b3104dd (diff)
parent35ef3ba91ce9e00466508f2388f4c1dd2321b505 (diff)
Merge branch 'master' into poc/audio-miniaudio
Diffstat (limited to 'mwe/resource-manager/resource_converter.cpp')
-rw-r--r--mwe/resource-manager/resource_converter.cpp35
1 files changed, 35 insertions, 0 deletions
diff --git a/mwe/resource-manager/resource_converter.cpp b/mwe/resource-manager/resource_converter.cpp
new file mode 100644
index 0000000..0477dc2
--- /dev/null
+++ b/mwe/resource-manager/resource_converter.cpp
@@ -0,0 +1,35 @@
+
+
+#include "resource_converter.h"
+#include "Image_asset.h"
+#include "map_asset.h"
+#include "resource.h"
+#include <SDL_image.h>
+#include <SDL_surface.h>
+#include <iostream>
+#include <string>
+
+ResourceConverter::ResourceConverter() { IMG_Init(IMG_INIT_PNG); }
+
+ResourceConverter::~ResourceConverter() { IMG_Quit(); }
+
+SDL_Surface * ResourceConverter::FromStringToImage(const Texture & resource) {
+ const std::string & content = resource.getContent();
+ SDL_RWops * rw = SDL_RWFromConstMem(content.data(), content.size());
+ if (!rw) {
+ std::cerr << "Failed to create SDL_RWops: " << SDL_GetError()
+ << std::endl;
+ return nullptr;
+ }
+
+ SDL_Surface * surface = IMG_Load_RW(rw, 1);
+ if (!surface) {
+ std::cerr << "Failed to load image: " << IMG_GetError() << std::endl;
+ }
+ return surface;
+}
+
+TiledMap ResourceConverter::FromStringToMap(const Map & resource) {
+ const std::string & content = resource.getContent();
+ return TiledMap(content);
+}