X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FFont.cpp;h=1dc90516ccae28455231d7d919b7ba650a891692;hb=1162be37102b24df11f469495c0184f3f9a26ba0;hp=d3a3de06d5396677ace4b5007aa79475a9995976;hpb=fb10fbd4a72793048916557308772fdaa2afebc2;p=l2e.git diff --git a/src/graphics/Font.cpp b/src/graphics/Font.cpp index d3a3de0..1dc9051 100644 --- a/src/graphics/Font.cpp +++ b/src/graphics/Font.cpp @@ -18,13 +18,13 @@ using std::pow; namespace graphics { -void Font::DrawChar(char c, SDL_Surface *dest, Point position) const { - if (!HasChar(c)) return; - const Mapping &m(map[(unsigned char)c]); - sprite->Draw(dest, position, m.col, m.row); +void Font::DrawChar(char c, SDL_Surface *dest, const Point &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, Point positionIn, int maxChars) const { +void Font::DrawString(const char *s, SDL_Surface *dest, const Point &positionIn, int maxChars) const { Point position(positionIn); Vector step(CharWidth(), 0); for (int i(0); s[i] && (maxChars <= 0 || i < maxChars); ++i, position += step) { @@ -32,11 +32,11 @@ void Font::DrawString(const char *s, SDL_Surface *dest, Point positionIn, i } } -void Font::DrawDigit(int digit, SDL_Surface *dest, Point position) const { - sprite->Draw(dest, position, digitsCol + digit, digitsRow); +void Font::DrawDigit(int digit, SDL_Surface *dest, const Point &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 Point &positionIn, int digits) const { int number(numberIn); if (digits > 0 && numberIn >= pow(10.0, digits)) { numberIn = pow(10.0, digits) - 1;