X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FFrame.cpp;h=34767f53f0cd170185723e2a0806f4cd87ab14bf;hb=76ebf3fdefce0655ecd2404e735e8fd96347d934;hp=14856071662a8ba80494c6b536c4b1cc71e9fbf8;hpb=679b9e39c7680fd46482589f37f0a225032103b7;p=l2e.git diff --git a/src/graphics/Frame.cpp b/src/graphics/Frame.cpp index 1485607..34767f5 100644 --- a/src/graphics/Frame.cpp +++ b/src/graphics/Frame.cpp @@ -7,7 +7,11 @@ #include "Frame.h" +#include "../loader/TypeDescription.h" + using geometry::Vector; +using loader::FieldDescription; +using loader::TypeDescription; namespace graphics { @@ -114,4 +118,20 @@ void Frame::Draw(SDL_Surface *dest, const Vector &position, int width, int SDL_BlitSurface(surface, &srcRect, dest, &destRect); } + +void Frame::CreateTypeDescription() { + Frame f; + TypeDescription &td(TypeDescription::CreateOrGet("Frame")); + + td.SetSize(sizeof(Frame)); + + int imageId(TypeDescription::GetTypeId("Image")); + int vectorId(TypeDescription::GetTypeId("Vector")); + + td.AddField("surface", FieldDescription(((char *)&f.surface) - ((char *)&f), imageId, true)); + td.AddField("borderSize", FieldDescription(((char *)&f.borderSize) - ((char *)&f), vectorId, false)); + td.AddField("repeatSize", FieldDescription(((char *)&f.repeatSize) - ((char *)&f), vectorId, false)); + td.AddField("offset", FieldDescription(((char *)&f.offset) - ((char *)&f), vectorId, false)); +} + }