diff options
Diffstat (limited to 'yage/base/spritesheet.cpp')
-rw-r--r-- | yage/base/spritesheet.cpp | 122 |
1 files changed, 122 insertions, 0 deletions
diff --git a/yage/base/spritesheet.cpp b/yage/base/spritesheet.cpp new file mode 100644 index 00000000..748cdb5c --- /dev/null +++ b/yage/base/spritesheet.cpp @@ -0,0 +1,122 @@ +/* ---------------------------------------------------------------------------- + * spritesheet.cpp + * + * Copyright (c) 2017 Yann Herklotz Grave <ymherklotz@gmail.com> + * MIT License, see LICENSE file for more details. + * ---------------------------------------------------------------------------- + */ + +#include "spritesheet.h" + +namespace yage +{ + +namespace details +{ + +bool SpriteSheetHandler::Null() +{ + return true; +} + +bool SpriteSheetHandler::Bool(bool) +{ + return true; +} + +bool SpriteSheetHandler::Int(int i) +{ + return handleNumber(i); +} + +bool SpriteSheetHandler::Uint(unsigned u) +{ + return handleNumber(static_cast<int>(u)); +} + +bool SpriteSheetHandler::Int64(int64_t i) +{ + return handleNumber(static_cast<int>(i)); +} + +bool SpriteSheetHandler::Uint64(uint64_t u) +{ + return handleNumber(static_cast<int>(u)); +} + +bool SpriteSheetHandler::Double(double d) +{ + return handleNumber(static_cast<int>(d)); +} + +bool SpriteSheetHandler::String(const char *, rapidjson::SizeType, bool) +{ + return true; +} + +bool SpriteSheetHandler::Key(const char *str, rapidjson::SizeType length, bool) +{ + current_key_ = std::string(str, length); + return true; +} + +bool SpriteSheetHandler::StartObject() +{ + depth_++; + + if(depth_ == 3) { + current_image_ = current_key_; + } + + return true; +} + +bool SpriteSheetHandler::EndObject(rapidjson::SizeType) +{ + if(depth_ == 3) { + map_[current_image_] = coord_; + } + depth_--; + return true; +} + +bool SpriteSheetHandler::StartArray() +{ + return true; +} + +bool SpriteSheetHandler::EndArray(rapidjson::SizeType) +{ + return true; +} + +SpriteMap SpriteSheetHandler::spriteMap() const +{ + return map_; +} + +bool SpriteSheetHandler::handleNumber(int i) +{ + if(current_key_ == "width") { + if(depth_ == 1) { + image_width_ = i; + } else { + coord_.width = i; + } + } else if(current_key_ == "height") { + if(depth_ == 1) { + image_height_ = i; + } else { + coord_.height = i; + } + } else if(current_key_ == "x") { + coord_.x = i; + } else if(current_key_ == "y") { + coord_.y = i; + } + return true; +} + +} // namespace details + +} // namespace yage |