From bdc3054423b6264d0bae1af037fe9330622b228f Mon Sep 17 00:00:00 2001 From: Koerty Date: Sun, 3 Jun 2018 00:57:02 +0200 Subject: [PATCH] Fix horizontal scrolling grid bugs This fix 2 bugs with the horizontal scrolling grid : - The grid is now positioned correctly (bug introduced by the buffer of the dynamic image loader) - The right column contain the partial tile in horizontal mod, not the bottom row --- es-core/src/components/ImageGridComponent.h | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/es-core/src/components/ImageGridComponent.h b/es-core/src/components/ImageGridComponent.h index 7d8272899..e17d31dd3 100644 --- a/es-core/src/components/ImageGridComponent.h +++ b/es-core/src/components/ImageGridComponent.h @@ -313,7 +313,9 @@ void ImageGridComponent::buildTiles() calcGridDimension(); Vector2f tileDistance = mTileSize + mMargin; - Vector2f startPosition = mTileSize / 2 - Vector2f(0, tileDistance.y() * texBuffersForward[3]); + Vector2f bufferSize = Vector2f(mScrollDirection == SCROLL_HORIZONTALLY ? tileDistance.x() * texBuffersForward[3] : 0, + mScrollDirection == SCROLL_VERTICALLY ? tileDistance.y() * texBuffersForward[3] : 0); + Vector2f startPosition = mTileSize / 2 - bufferSize; int X, Y; @@ -456,15 +458,15 @@ void ImageGridComponent::calcGridDimension() // <=> COLUMNS = (GRID_SIZE + MARGIN) / (TILE_SIZE + MARGIN) Vector2f gridDimension = (mSize + mMargin) / (mTileSize + mMargin); - // Invert dimensions for horizontally scrolling grid - if (mScrollDirection == SCROLL_HORIZONTALLY) - gridDimension = Vector2f(gridDimension.y(), gridDimension.x()); - mLastRowPartial = Math::floorf(gridDimension.y()) != gridDimension.y(); // Ceil y dim so we can display partial last row mGridDimension = Vector2i(gridDimension.x(), Math::ceilf(gridDimension.y())); + // Invert dimensions for horizontally scrolling grid + if (mScrollDirection == SCROLL_HORIZONTALLY) + mGridDimension = Vector2i(mGridDimension.y(), mGridDimension.x()); + // Grid dimension validation if (mGridDimension.x() < 1) LOG(LogError) << "Theme defined grid X dimension below 1";