X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FFont.h;h=c879dcedf73e4fc8a6803cac9651e1e7c0e538af;hb=cc3d698b8c1ad09d7a3f9e3f28bc84e0ac1735ea;hp=0294d2539f0c47417ad45083d7a273b919eff4bb;hpb=ca31ddeab37eebaa2de5e5b1c94974fac06d418b;p=l2e.git diff --git a/src/graphics/Font.h b/src/graphics/Font.h index 0294d25..c879dce 100644 --- a/src/graphics/Font.h +++ b/src/graphics/Font.h @@ -1,15 +1,8 @@ -/* - * Font.h - * - * Created on: Aug 8, 2012 - * Author: holy - */ - #ifndef GRAPHICS_FONT_H_ #define GRAPHICS_FONT_H_ #include "Sprite.h" -#include "../geometry/Point.h" +#include "../geometry/Vector.h" #include @@ -18,18 +11,39 @@ namespace graphics { class Font { public: - explicit Font(const Sprite *sprite, int digitsCol = 0, int digitsRow = 0) : sprite(sprite), digitsCol(digitsCol), digitsRow(digitsRow) { } + static const int TYPE_ID = 404; + +public: + explicit Font(const Sprite *sprite = 0, int colOffset = 0, int rowOffset = 0) + : sprite(sprite), colOffset(colOffset), rowOffset(rowOffset) { + + } public: int CharWidth() const { return sprite->Width(); } int CharHeight() const { return sprite->Height(); } - void DrawDigit(int digit, SDL_Surface *dest, geometry::Point position) const; - void DrawNumber(int number, SDL_Surface *dest, geometry::Point position, int digits = 0) const; + int StringWidth(const char *) const; + int StringHeight(const char *) const; + + void DrawChar(char c, SDL_Surface *dest, const geometry::Vector &position) const; + void DrawString(const char *s, SDL_Surface *dest, const geometry::Vector &position, int maxWidth = 0) const; + void DrawStringRight(const char *s, SDL_Surface *dest, const geometry::Vector &position, int maxWidth = 0) const; + void DrawDigit(int d, SDL_Surface *dest, const geometry::Vector &position) const; + void DrawNumber(int n, SDL_Surface *dest, const geometry::Vector &position, int digits = 0) const; + void DrawNumberRight(int n, SDL_Surface *dest, const geometry::Vector &position, int digits = 0) const; + +public: + void SetSprite(const Sprite *s) { sprite = s; } + void SetColOffset(int n) { colOffset = n; } + void SetRowOffset(int n) { rowOffset = n; } + + static void CreateTypeDescription(); + static void Construct(void *); private: const Sprite *sprite; - int digitsCol; - int digitsRow; + int colOffset; + int rowOffset; };