X-Git-Url: http://git.localhorst.tv/?a=blobdiff_plain;f=src%2Fgraphics%2FSprite.h;h=942d98e51e5e7424d791d657aa7ab94d4371ace3;hb=0542849dfccfec1ce1477265fa0fee2401a8fb23;hp=5710ee58639b3eebf439dd975794968c03e39620;hpb=5421c812b9fc64371c7f8ce3886b0b091eef458f;p=l2e.git diff --git a/src/graphics/Sprite.h b/src/graphics/Sprite.h index 5710ee5..942d98e 100644 --- a/src/graphics/Sprite.h +++ b/src/graphics/Sprite.h @@ -8,6 +8,8 @@ #ifndef GRAPHICS_SPRITE_H_ #define GRAPHICS_SPRITE_H_ +#include "../geometry/Vector.h" + #include namespace graphics { @@ -15,18 +17,32 @@ namespace graphics { class Sprite { public: - Sprite(SDL_Surface *s, int width, int height) - : surface(s), width(width), height(height) { } + Sprite(SDL_Surface *s, int width, int height, int xOffset = 0, int yOffset = 0) + : surface(s), width(width), height(height), xOffset(xOffset), yOffset(yOffset) { } public: int Width() const { return width; } int Height() const { return height; } - void Draw(SDL_Surface *dest, int x, int y, int col = 0, int row = 0) const; + void Draw(SDL_Surface *dest, const geometry::Vector &position, int col = 0, int row = 0) const; + void DrawTopRight(SDL_Surface *dest, const geometry::Vector &position, int col = 0, int row = 0) const { + geometry::Vector offset(-Width(), 0); + Draw(dest, position + offset, col, row); + } + void DrawCenter(SDL_Surface *dest, const geometry::Vector &position, int col = 0, int row = 0) const { + geometry::Vector offset(-Width() / 2, -Height() / 2); + Draw(dest, position + offset, col, row); + } + void DrawCenterBottom(SDL_Surface *dest, const geometry::Vector &position, int col = 0, int row = 0) const { + geometry::Vector offset(-Width() / 2, -Height()); + Draw(dest, position + offset, col, row); + } private: SDL_Surface *surface; int width; int height; + int xOffset; + int yOffset; };