]> git.localhorst.tv Git - l2e.git/blobdiff - src/graphics/Sprite.cpp
reordered type description creation to avoid reallocation
[l2e.git] / src / graphics / Sprite.cpp
index 363be11230caa6ea462383f636ccc8270d7dac45..28d3b5c215c33a0459ad0963fe3f6393a0d3f9cb 100644 (file)
@@ -7,14 +7,18 @@
 
 #include "Sprite.h"
 
-using geometry::Point;
+#include "../loader/TypeDescription.h"
+
+using geometry::Vector;
+using loader::FieldDescription;
+using loader::TypeDescription;
 
 namespace graphics {
 
-void Sprite::Draw(SDL_Surface *dest, Point<int> position, int col, int row) const {
+void Sprite::Draw(SDL_Surface *dest, const Vector<int> &position, int col, int row) const {
        SDL_Rect srcRect, destRect;
-       srcRect.x = xOffset + col * Width();
-       srcRect.y = yOffset + row * Height();
+       srcRect.x = offset.X() + col * Width();
+       srcRect.y = offset.Y() + row * Height();
        srcRect.w = Width();
        srcRect.h = Height();
        destRect.x = position.X();
@@ -36,4 +40,19 @@ void Sprite::Draw(SDL_Surface *dest, Point<int> position, int col, int row) cons
        }
 }
 
+
+void Sprite::CreateTypeDescription() {
+       Sprite s;
+
+       int imageId(TypeDescription::GetTypeId("Image"));
+       int vectorId(TypeDescription::GetTypeId("Vector"));
+
+       TypeDescription &td(TypeDescription::CreateOrGet("Sprite"));
+       td.SetSize(sizeof(Sprite));
+
+       td.AddField("image", FieldDescription(((char *)&s.surface) - ((char *)&s), imageId, true));
+       td.AddField("size", FieldDescription(((char *)&s.size) - ((char *)&s), vectorId, false));
+       td.AddField("offset", FieldDescription(((char *)&s.offset) - ((char *)&s), vectorId, false));
+}
+
 }