]> git.localhorst.tv Git - l2e.git/commitdiff
improved Texture::Render()
authorDaniel Karbach <daniel.karbach@localhorst.tv>
Mon, 21 Jan 2013 19:36:48 +0000 (20:36 +0100)
committerDaniel Karbach <daniel.karbach@localhorst.tv>
Mon, 21 Jan 2013 19:36:48 +0000 (20:36 +0100)
src/graphics/Texture.cpp

index db45b3d9d13d3d329dd0f13f39276421cfe5fca8..97094bc5209c9ba34456ca4aeb7997f5487d8d40 100644 (file)
@@ -40,21 +40,38 @@ void Texture::Render(SDL_Surface *dest, const Vector<int> &from, const Vector<in
        SDL_Rect srcRect;
        srcRect.x = offset.X();
        srcRect.y = offset.Y();
+       srcRect.h = size.Y();
+       srcRect.w = size.X();
 
-       for (destRect.y = from.Y(); destRect.y < to.Y(); destRect.y += size.Y()) {
+       const Vector<int> total = to - from;
+       const Vector<int> over = total % size;
+       const Vector<int> target = from + (total - over);
+
+       for (destRect.y = from.Y(); destRect.y < target.Y(); destRect.y += size.Y()) {
+               for (destRect.x = from.X(); destRect.x < target.X(); destRect.x += size.X()) {
+                       SDL_BlitSurface(surface, &srcRect, dest, &destRect);
+               }
+       }
+       if (over.X() > 0) {
+               destRect.x = target.X();
+               srcRect.w = over.X();
                srcRect.h = size.Y();
-               destRect.h = size.Y();
-               if (destRect.y + destRect.h > to.Y()) {
-                       srcRect.h = to.Y() - destRect.y;
-                       destRect.h = to.Y() - destRect.y;
+               for (destRect.y = from.Y(); destRect.y < target.Y(); destRect.y += size.Y()) {
+                       SDL_BlitSurface(surface, &srcRect, dest, &destRect);
+               }
+       }
+       if (over.Y() > 0) {
+               destRect.y = target.Y();
+               srcRect.w = size.X();
+               srcRect.h = over.Y();
+               for (destRect.x = from.X(); destRect.x < target.X(); destRect.x += size.X()) {
+                       SDL_BlitSurface(surface, &srcRect, dest, &destRect);
                }
-               for (destRect.x = from.X(); destRect.x < to.X(); destRect.x += size.X()) {
-                       srcRect.w = size.X();
-                       destRect.w = size.X();
-                       if (destRect.x + destRect.w > to.X()) {
-                               srcRect.w = to.X() - destRect.x;
-                               destRect.w = to.X() - destRect.x;
-                       }
+               if (over.X() > 0) {
+                       srcRect.w = over.X();
+                       srcRect.h = over.Y();
+                       destRect.x = target.X();
+                       destRect.y = target.Y();
                        SDL_BlitSurface(surface, &srcRect, dest, &destRect);
                }
        }