]> git.localhorst.tv Git - l2e.git/blobdiff - src/graphics/Font.cpp
Merge branch 'loader'
[l2e.git] / src / graphics / Font.cpp
index 0ff3d9d4d90360b997277ee20226920d1e4d6bb2..ca06a076a80c251a17f7fead31171d7ce5c6a1a3 100644 (file)
@@ -7,33 +7,52 @@
 
 #include "Font.h"
 
-#include "../geometry/operators.h"
-#include "../geometry/Vector.h"
-
 #include <cmath>
+#include <iostream>
 
-using geometry::Point;
 using geometry::Vector;
 using std::pow;
 
 namespace graphics {
 
-void Font::DrawDigit(int digit, SDL_Surface *dest, Point<int> position) const {
-       sprite->Draw(dest, position, digitsCol + digit, digitsRow);
+void Font::DrawChar(char c, SDL_Surface *dest, const Vector<int> &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<int> &positionIn, int maxChars) const {
+       if (!sprite) return;
+
+       Vector<int> position(positionIn);
+       Vector<int> step(CharWidth(), 0);
+       for (int i(0); s[i] && (maxChars <= 0 || i < maxChars); ++i, position += step) {
+               DrawChar(s[i], dest, position);
+       }
 }
 
-void Font::DrawNumber(int numberIn, SDL_Surface *dest, Point<int> positionIn, int digits) const {
+void Font::DrawDigit(int digit, SDL_Surface *dest, const Vector<int> &position) const {
+       if (!sprite) return;
+
+       DrawChar(digit + 0x30, dest, position);
+}
+
+void Font::DrawNumber(int numberIn, SDL_Surface *dest, const Vector<int> &positionIn, int digits) const {
+       if (!sprite) return;
+
        int number(numberIn);
        if (digits > 0 && numberIn >= pow(10.0, digits)) {
                numberIn = pow(10.0, digits) - 1;
        }
 
-       Point<int> position(positionIn);
+       Vector<int> position(positionIn);
        Vector<int> 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;
                }