X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FGauge.cpp;h=b7023d40538b68075a0085ccd111201bca95f44e;hb=123ca72f7a92d2529c6f9b6bdff3f13d6f0223c9;hp=0d72ac0676eb11233a5d67df37e795f596e1d70a;hpb=d5959073b2c413ba1bd6f3d14bc8bcf59304e488;p=l2e.git diff --git a/src/graphics/Gauge.cpp b/src/graphics/Gauge.cpp index 0d72ac0..b7023d4 100644 --- a/src/graphics/Gauge.cpp +++ b/src/graphics/Gauge.cpp @@ -7,7 +7,11 @@ #include "Gauge.h" +#include "../loader/TypeDescription.h" + using geometry::Vector; +using loader::FieldDescription; +using loader::TypeDescription; namespace graphics { @@ -78,4 +82,29 @@ void Gauge::Draw(SDL_Surface *dest, const Vector &position, int width, Uint } + +void Gauge::CreateTypeDescription() { + Gauge g; + + int imageId(TypeDescription::GetTypeId("Image")); + int numberId(TypeDescription::GetTypeId("Number")); + int vectorId(TypeDescription::GetTypeId("Vector")); + + TypeDescription &td(TypeDescription::CreateOrGet("Gauge")); + td.SetConstructor(&Construct); + td.SetSize(sizeof(Gauge)); + + td.AddField("image", FieldDescription(((char *)&g.surface) - ((char *)&g), imageId, true)); + td.AddField("full", FieldDescription(((char *)&g.fullOffset) - ((char *)&g), vectorId, false)); + td.AddField("empty", FieldDescription(((char *)&g.emptyOffset) - ((char *)&g), vectorId, false)); + td.AddField("height", FieldDescription(((char *)&g.height) - ((char *)&g), numberId, false)); + td.AddField("start", FieldDescription(((char *)&g.startWidth) - ((char *)&g), numberId, false)); + td.AddField("repeat", FieldDescription(((char *)&g.repeatWidth) - ((char *)&g), numberId, false)); + td.AddField("end", FieldDescription(((char *)&g.endWidth) - ((char *)&g), numberId, false)); +} + +void Gauge::Construct(void *data) { + new (data) Gauge; +} + }