X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FFont.cpp;h=59059e07436d1893da0a9fc7dc73612fe5c79a92;hb=c591893775d3b850d0a88e743c09c91db337fbdc;hp=efaad1525611302446f7fd9f46479bfd62f19637;hpb=4bc70f5311dcbcca4e6b9e852bbcb19602f50eeb;p=l2e.git diff --git a/src/graphics/Font.cpp b/src/graphics/Font.cpp index efaad15..59059e0 100644 --- a/src/graphics/Font.cpp +++ b/src/graphics/Font.cpp @@ -7,6 +7,7 @@ #include "Font.h" +#include "../loader/Interpreter.h" #include "../loader/TypeDescription.h" #include @@ -14,6 +15,7 @@ using geometry::Vector; using loader::FieldDescription; +using loader::Interpreter; using loader::TypeDescription; using std::pow; @@ -37,6 +39,18 @@ void Font::DrawString(const char *s, SDL_Surface *dest, const Vector &posit } } +void Font::DrawStringRight(const char *s, SDL_Surface *dest, const Vector &positionIn, int maxChars) const { + if (!sprite) return; + + int length(0); + while (length < maxChars && s[length] != '\0') { + ++length; + } + Vector position(positionIn.X() - length * CharWidth(), positionIn.Y()); + + DrawString(s, dest, position, length); +} + void Font::DrawDigit(int digit, SDL_Surface *dest, const Vector &position) const { if (!sprite) return; @@ -74,14 +88,19 @@ void Font::DrawNumber(int numberIn, SDL_Surface *dest, const Vector &positi } } +void Font::DrawNumberRight(int number, SDL_Surface *dest, const Vector &positionIn, int digits) const { + if (!sprite) return; + + Vector position(positionIn.X() - digits * CharWidth(), positionIn.Y()); + + DrawNumber(number, dest, position, digits); +} + void Font::CreateTypeDescription() { Font f; - int numberId(TypeDescription::GetTypeId("Number")); - int spriteId(TypeDescription::GetTypeId("Sprite")); - - TypeDescription &td(TypeDescription::CreateOrGet("Font")); + TypeDescription &td(TypeDescription::Create(TYPE_ID, "Font")); td.SetDescription( "Simple font with fixed-width characters using a sprite for rendering.\n" "Characters from strings are mapped as follows:\n" @@ -90,9 +109,9 @@ void Font::CreateTypeDescription() { td.SetConstructor(&Construct); td.SetSize(sizeof(Font)); - td.AddField("sprite", FieldDescription(((char *)&f.sprite) - ((char *)&f), spriteId).SetReferenced().SetDescription("a sprite where each tile corresponds to a character")); - td.AddField("columnoffset", FieldDescription(((char *)&f.colOffset) - ((char *)&f), numberId).SetDescription("offset of the column of the first character")); - td.AddField("rowoffset", FieldDescription(((char *)&f.rowOffset) - ((char *)&f), numberId).SetDescription("offset of the row of the first character")); + td.AddField("sprite", FieldDescription(((char *)&f.sprite) - ((char *)&f), Sprite::TYPE_ID).SetReferenced().SetDescription("a sprite where each tile corresponds to a character")); + td.AddField("columnoffset", FieldDescription(((char *)&f.colOffset) - ((char *)&f), Interpreter::NUMBER_ID).SetDescription("offset of the column of the first character")); + td.AddField("rowoffset", FieldDescription(((char *)&f.rowOffset) - ((char *)&f), Interpreter::NUMBER_ID).SetDescription("offset of the row of the first character")); } void Font::Construct(void *data) {