-/*
- * Gauge.cpp
- *
- * Created on: Aug 7, 2012
- * Author: holy
- */
-
#include "Gauge.h"
-using geometry::Vector;
+#include "../loader/Interpreter.h"
+#include "../loader/TypeDescription.h"
+
+using math::Vector;
+using loader::FieldDescription;
+using loader::Interpreter;
+using loader::TypeDescription;
namespace graphics {
}
+
+void Gauge::CreateTypeDescription() {
+ Gauge g;
+
+ TypeDescription &td(TypeDescription::Create(TYPE_ID, "Gauge"));
+ td.SetDescription(
+ "Gauges display a percentage by filling the left part different than the right.\n"
+ "The fill level is only mapped with repeat.\n"
+ "Start is filled if the level in greater than zero, end is filled if the level is at its maximum.");
+ td.SetConstructor(&Construct);
+ td.SetSize(sizeof(Gauge));
+
+ td.AddField("image", FieldDescription(((char *)&g.surface) - ((char *)&g), Interpreter::IMAGE_ID).SetReferenced().SetDescription("the underlying graphic from which the gauge parts are cut"));
+ td.AddField("full", FieldDescription(((char *)&g.fullOffset) - ((char *)&g), Interpreter::VECTOR_ID).SetDescription("top-left corner of the filled gauge"));
+ td.AddField("empty", FieldDescription(((char *)&g.emptyOffset) - ((char *)&g), Interpreter::VECTOR_ID).SetDescription("top-left corner of the empty gauge"));
+ td.AddField("height", FieldDescription(((char *)&g.height) - ((char *)&g), Interpreter::NUMBER_ID).SetDescription("height of the gauges"));
+ td.AddField("start", FieldDescription(((char *)&g.startWidth) - ((char *)&g), Interpreter::NUMBER_ID).SetDescription("width of the start part"));
+ td.AddField("repeat", FieldDescription(((char *)&g.repeatWidth) - ((char *)&g), Interpreter::NUMBER_ID).SetDescription("width of the repeat part"));
+ td.AddField("end", FieldDescription(((char *)&g.endWidth) - ((char *)&g), Interpreter::NUMBER_ID).SetDescription("width of the end part"));
+}
+
+void Gauge::Construct(void *data) {
+ new (data) Gauge;
+}
+
}