X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FFont.cpp;h=e4e538d90250abf4bb06034989f95cf247ba171a;hb=9f352d64f920f46a2d5b4fe67408154629933293;hp=a11850001717eae97289cdb2158c8aa129d32c1c;hpb=0542849dfccfec1ce1477265fa0fee2401a8fb23;p=l2e.git diff --git a/src/graphics/Font.cpp b/src/graphics/Font.cpp index a118500..e4e538d 100644 --- a/src/graphics/Font.cpp +++ b/src/graphics/Font.cpp @@ -7,20 +7,29 @@ #include "Font.h" +#include "../loader/TypeDescription.h" + #include +#include using geometry::Vector; +using loader::FieldDescription; +using loader::TypeDescription; using std::pow; namespace graphics { void Font::DrawChar(char c, SDL_Surface *dest, const Vector &position) const { + if (!sprite) return; + int col(colOffset + (c % 0x10)); int row(rowOffset + (c / 0x10)); sprite->Draw(dest, position, col, row); } void Font::DrawString(const char *s, SDL_Surface *dest, const Vector &positionIn, int maxChars) const { + if (!sprite) return; + Vector position(positionIn); Vector step(CharWidth(), 0); for (int i(0); s[i] && (maxChars <= 0 || i < maxChars); ++i, position += step) { @@ -29,10 +38,14 @@ void Font::DrawString(const char *s, SDL_Surface *dest, const Vector &posit } void Font::DrawDigit(int digit, SDL_Surface *dest, const Vector &position) const { + if (!sprite) return; + DrawChar(digit + 0x30, dest, position); } void Font::DrawNumber(int numberIn, SDL_Surface *dest, const Vector &positionIn, int digits) const { + if (!sprite) return; + int number(numberIn); if (digits > 0 && numberIn >= pow(10.0, digits)) { numberIn = pow(10.0, digits) - 1; @@ -61,4 +74,24 @@ void Font::DrawNumber(int numberIn, SDL_Surface *dest, const Vector &positi } } + +void Font::CreateTypeDescription() { + Font f; + + int numberId(TypeDescription::GetTypeId("Number")); + int spriteId(TypeDescription::GetTypeId("Sprite")); + + TypeDescription &td(TypeDescription::CreateOrGet("Font")); + td.SetConstructor(&Construct); + td.SetSize(sizeof(Font)); + + td.AddField("sprite", FieldDescription(((char *)&f.sprite) - ((char *)&f), spriteId, true)); + td.AddField("columnoffset", FieldDescription(((char *)&f.colOffset) - ((char *)&f), numberId, false)); + td.AddField("rowoffset", FieldDescription(((char *)&f.rowOffset) - ((char *)&f), numberId, false)); +} + +void Font::Construct(void *data) { + new (data) Font; +} + }