From efecf0ab20304b5d76b3072a66b36b50d8522082 Mon Sep 17 00:00:00 2001 From: Stanislaw Halik Date: Sun, 27 Nov 2022 21:39:41 +0100 Subject: scenery wip --- loader/json.cpp | 17 +++++++++++++++++ loader/loader.hpp | 4 ++++ 2 files changed, 21 insertions(+) (limited to 'loader') diff --git a/loader/json.cpp b/loader/json.cpp index 1a30a66b..7ee661f7 100644 --- a/loader/json.cpp +++ b/loader/json.cpp @@ -1,6 +1,9 @@ #include "impl.hpp" #include "serialize/json-helper.hpp" #include "serialize/anim.hpp" +#include "serialize/tile-atlas.hpp" +#include "serialize/scenery.hpp" +#include namespace floormat::loader_detail { @@ -10,3 +13,17 @@ anim_def loader_impl::deserialize_anim(StringView filename) } } // namespace floormat::loader_detail + +namespace floormat { + +std::vector> loader_::tile_atlases(StringView filename) +{ + return json_helper::from_json>>(Path::join(loader_::IMAGE_PATH, filename)); +} + +std::vector loader_::sceneries() +{ + return json_helper::from_json>(Path::join(ANIM_PATH, "scenery.json")); +} + +} // namespace floormat diff --git a/loader/loader.hpp b/loader/loader.hpp index e3f306ea..1c15ac43 100644 --- a/loader/loader.hpp +++ b/loader/loader.hpp @@ -2,11 +2,13 @@ #include namespace Magnum { using Vector2ub = Math::Vector2; } +namespace floormat::Serialize { struct serialized_scenery; } namespace floormat { struct tile_atlas; struct anim_atlas; +struct scenery_proto; struct loader_ { @@ -16,6 +18,8 @@ struct loader_ virtual std::shared_ptr anim_atlas(StringView name) = 0; static void destroy(); static loader_& default_loader() noexcept; + static std::vector> tile_atlases(StringView filename); + static std::vector sceneries(); loader_(const loader_&) = delete; loader_& operator=(const loader_&) = delete; -- cgit v1.2.3