]> git.localhorst.tv Git - l2e.git/commitdiff
changed Frame implementation
authorDaniel Karbach <daniel.karbach@localhorst.tv>
Sun, 21 Oct 2012 18:00:47 +0000 (20:00 +0200)
committerDaniel Karbach <daniel.karbach@localhorst.tv>
Sun, 21 Oct 2012 18:00:47 +0000 (20:00 +0200)
src/graphics/Frame.cpp
src/graphics/Texture.cpp
src/graphics/Texture.h

index 46fa1b59db7c799255c282f90e9fe92c654a509d..86b9cd25d5d7b5d06c0213aea81ef303db945b96 100644 (file)
@@ -7,6 +7,7 @@
 
 #include "Frame.h"
 
+#include "Texture.h"
 #include "../loader/Interpreter.h"
 #include "../loader/TypeDescription.h"
 
@@ -40,55 +41,26 @@ void Frame::Draw(SDL_Surface *dest, const Vector<int> &position, int width, int
        SDL_BlitSurface(surface, &srcRect, dest, &destRect);
 
        // top border
-       srcRect.x += BorderWidth();
-       srcRect.w = RepeatWidth();
-       destRect.x += BorderWidth();
-       int fullRepeatWidth(width - (2 * BorderWidth()));
-       int repeatCursor(0);
-       while (repeatCursor < fullRepeatWidth) {
-               SDL_BlitSurface(surface, &srcRect, dest, &destRect);
-               destRect.x += RepeatWidth();
-               repeatCursor += RepeatWidth();
-       }
+       Texture(surface, Vector<int>(RepeatWidth(), BorderHeight()), Vector<int>(offset.X() + BorderWidth(), offset.Y()))
+       .Render(dest, Vector<int>(position.X() + BorderWidth(), position.Y()), Vector<int>(position.X() + width - BorderWidth(), position.Y() + BorderHeight()));
 
        // top-right corner
-       srcRect.x += RepeatWidth();
+       srcRect.x = offset.X() + RepeatWidth() + BorderWidth();
        srcRect.w = BorderWidth();
+       destRect.x = position.X() + width - BorderWidth();
        SDL_BlitSurface(surface, &srcRect, dest, &destRect);
 
-       // middle
-       destRect.y += BorderHeight();
-       int fullRepeatHeight(height - (2 * BorderHeight()));
-       int hRepeatCursor(0);
-       while (hRepeatCursor < fullRepeatHeight) {
-
-               // left border
-               srcRect.x = offset.X();
-               srcRect.y = offset.Y() + BorderHeight();
-               srcRect.w = BorderWidth();
-               srcRect.h = RepeatHeight();
-               destRect.x = position.X();
-               SDL_BlitSurface(surface, &srcRect, dest, &destRect);
-
-               // fill
-               repeatCursor = 0;
-               srcRect.x += BorderWidth();
-               srcRect.w = RepeatWidth();
-               destRect.x += BorderWidth();
-               while (repeatCursor < fullRepeatWidth) {
-                       SDL_BlitSurface(surface, &srcRect, dest, &destRect);
-                       destRect.x += RepeatWidth();
-                       repeatCursor += RepeatWidth();
-               }
-
-               // right border
-               srcRect.x += RepeatWidth();
-               srcRect.w = BorderWidth();
-               SDL_BlitSurface(surface, &srcRect, dest, &destRect);
-
-               destRect.y += RepeatHeight();
-               hRepeatCursor += RepeatHeight();
-       }
+       // left border
+       Texture(surface, Vector<int>(BorderWidth(), RepeatHeight()), Vector<int>(offset.X(), offset.Y() + BorderHeight()))
+       .Render(dest, Vector<int>(position.X(), position.Y() + BorderHeight()), Vector<int>(position.X() + BorderWidth(), position.Y() + height - BorderHeight()));
+
+       // center fill
+       Texture(surface, RepeatSize(), Vector<int>(offset.X() + BorderWidth(), offset.Y() + BorderHeight()))
+       .Render(dest, position + BorderSize(), position + Vector<int>(width, height) - BorderSize());
+
+       // right border
+       Texture(surface, Vector<int>(BorderWidth(), RepeatHeight()), Vector<int>(offset.X() + BorderWidth() + RepeatWidth(), offset.Y() + BorderHeight()))
+       .Render(dest, Vector<int>(position.X() + width - BorderWidth(), position.Y() + BorderHeight()), Vector<int>(position.X() + width, position.Y() + height - BorderHeight()));
 
        // bottom-left corner
        srcRect.x = offset.X();
@@ -96,27 +68,17 @@ void Frame::Draw(SDL_Surface *dest, const Vector<int> &position, int width, int
        srcRect.w = BorderWidth();
        srcRect.h = BorderHeight();
        destRect.x = position.X();
+       destRect.y = position.Y() + height - BorderHeight();
        SDL_BlitSurface(surface, &srcRect, dest, &destRect);
 
        // bottom border
-       srcRect.x += BorderWidth();
-       srcRect.w = RepeatWidth();
-       destRect.x += BorderWidth();
-       repeatCursor = 0;
-       while (repeatCursor < fullRepeatWidth) {
-               SDL_BlitSurface(surface, &srcRect, dest, &destRect);
-               destRect.x += RepeatWidth();
-               repeatCursor += RepeatWidth();
-       }
-       if (fullRepeatWidth < fullRepeatWidth) {
-               srcRect.w = fullRepeatWidth - fullRepeatWidth;
-               SDL_BlitSurface(surface, &srcRect, dest, &destRect);
-               destRect.x += fullRepeatWidth - fullRepeatWidth;
-       }
+       Texture(surface, Vector<int>(RepeatWidth(), BorderHeight()), Vector<int>(offset.X() + BorderWidth(), offset.Y() + BorderHeight() + RepeatHeight()))
+       .Render(dest, Vector<int>(position.X() + BorderWidth(), position.Y() + height - BorderHeight()), Vector<int>(position.X() + width - BorderWidth(), position.Y() + height));
 
        // bottom-right corner
-       srcRect.x += RepeatWidth();
+       srcRect.x = offset.X() + BorderWidth() + RepeatWidth();
        srcRect.w = BorderWidth();
+       destRect.x = position.X() + width - BorderWidth();
        SDL_BlitSurface(surface, &srcRect, dest, &destRect);
 }
 
index 6fc8f0e1c3a142aefc65d15d1d5aa538e6d1661f..2bb0e97f2113529421bcd5ee6ac3b1c0f2b3fabc 100644 (file)
@@ -13,8 +13,13 @@ using geometry::Vector;
 
 namespace graphics {
 
-Texture::Texture()
-: surface(0) {
+Texture::Texture(
+               SDL_Surface *surface,
+               const Vector<int> &size,
+               const Vector<int> &offset)
+: surface(surface)
+, size(size)
+, offset(offset) {
 
 }
 
index 3b6357eef477525f2b9632ca3bc8b0be291eb6da..ecb516a918197e52504afeebf62382c14aaf3260 100644 (file)
@@ -17,7 +17,10 @@ namespace graphics {
 class Texture {
 
 public:
-       Texture();
+       explicit Texture(
+                       SDL_Surface *surface = 0,
+                       const geometry::Vector<int> &size = geometry::Vector<int>(),
+                       const geometry::Vector<int> &offset = geometry::Vector<int>());
        ~Texture();
 
 public:
@@ -25,13 +28,13 @@ public:
 
 public:
        void SetSurface(SDL_Surface *s) { surface = s; }
-       void SetOffset(const geometry::Vector<int> &o) { offset = o; }
        void SetSize(const geometry::Vector<int> &s) { size = s; }
+       void SetOffset(const geometry::Vector<int> &o) { offset = o; }
 
 private:
        SDL_Surface *surface;
-       geometry::Vector<int> offset;
        geometry::Vector<int> size;
+       geometry::Vector<int> offset;
 
 };