X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FFont.cpp;h=a11850001717eae97289cdb2158c8aa129d32c1c;hb=0542849dfccfec1ce1477265fa0fee2401a8fb23;hp=0ff3d9d4d90360b997277ee20226920d1e4d6bb2;hpb=ca31ddeab37eebaa2de5e5b1c94974fac06d418b;p=l2e.git diff --git a/src/graphics/Font.cpp b/src/graphics/Font.cpp index 0ff3d9d..a118500 100644 --- a/src/graphics/Font.cpp +++ b/src/graphics/Font.cpp @@ -7,33 +7,43 @@ #include "Font.h" -#include "../geometry/operators.h" -#include "../geometry/Vector.h" - #include -using geometry::Point; using geometry::Vector; using std::pow; namespace graphics { -void Font::DrawDigit(int digit, SDL_Surface *dest, Point position) const { - sprite->Draw(dest, position, digitsCol + digit, digitsRow); +void Font::DrawChar(char c, SDL_Surface *dest, const Vector &position) const { + 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 { + Vector position(positionIn); + Vector step(CharWidth(), 0); + for (int i(0); s[i] && (maxChars <= 0 || i < maxChars); ++i, position += step) { + DrawChar(s[i], dest, position); + } +} + +void Font::DrawDigit(int digit, SDL_Surface *dest, const Vector &position) const { + DrawChar(digit + 0x30, dest, position); } -void Font::DrawNumber(int numberIn, SDL_Surface *dest, Point positionIn, int digits) const { +void Font::DrawNumber(int numberIn, SDL_Surface *dest, const Vector &positionIn, int digits) const { int number(numberIn); if (digits > 0 && numberIn >= pow(10.0, digits)) { numberIn = pow(10.0, digits) - 1; } - Point position(positionIn); + Vector position(positionIn); Vector step(sprite->Width(), 0); if (digits > 0) { int i(digits - 1); - while (number < pow(10.0, i)) { + while (number < pow(10.0, i) && i > 0) { position += step; --i; }