From 7b7a99dbe2ab53dffeda16487864f40eaa517202 Mon Sep 17 00:00:00 2001 From: Leon Styhre Date: Wed, 21 Sep 2022 22:03:03 +0200 Subject: [PATCH] Fixed an issue where overlapping wheel carousel items were not rendered in the correct order. --- .../components/primary/CarouselComponent.h | 21 +++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/es-core/src/components/primary/CarouselComponent.h b/es-core/src/components/primary/CarouselComponent.h index 30337734a..bf7f8569d 100644 --- a/es-core/src/components/primary/CarouselComponent.h +++ b/es-core/src/components/primary/CarouselComponent.h @@ -548,6 +548,8 @@ template void CarouselComponent::render(const glm::mat4& parentT mRenderer->drawRect(0.0f, 0.0f, mSize.x, mSize.y, mCarouselColor, mCarouselColorEnd, mColorGradientHorizontal); + bool isWheel {mType == CarouselType::VERTICAL_WHEEL || mType == CarouselType::HORIZONTAL_WHEEL}; + // Draw the items. // itemSpacing will also include the size of the item itself. glm::vec2 itemSpacing {0.0f, 0.0f}; @@ -555,7 +557,7 @@ template void CarouselComponent::render(const glm::mat4& parentT float yOff {0.0f}; float scaleSize {mItemSize.x * mItemScale - mItemSize.x}; - if (mType == CarouselType::HORIZONTAL_WHEEL || mType == CarouselType::VERTICAL_WHEEL) { + if (isWheel) { xOff = (mSize.x - mItemSize.x) / 2.0f - (camOffset * itemSpacing.y); yOff = (mSize.y - mItemSize.y) / 2.0f; // Alignment of the actual carousel inside to the overall component area. @@ -732,11 +734,22 @@ template void CarouselComponent::render(const glm::mat4& parentT } else { // Make sure that overlapping items are rendered in the correct order. - for (int i = 0; i < belowCenter - 0; ++i) + size_t zeroDistanceEntry {0}; + + for (int i = 0; i < belowCenter; ++i) renderItemsSorted.emplace_back(renderItems[i]); - for (int i = static_cast(renderItems.size()) - 1; i > belowCenter - 1; --i) + for (int i = static_cast(renderItems.size()) - 1; i > belowCenter - 1; --i) { + if (isWheel && (mPositiveDirection ? std::ceil(renderItems[i].distance) : + std::floor(renderItems[i].distance)) == 0) { + zeroDistanceEntry = i; + continue; + } renderItemsSorted.emplace_back(renderItems[i]); + } + + if (isWheel) + renderItemsSorted.emplace_back(renderItems[zeroDistanceEntry]); } for (auto& renderItem : renderItemsSorted) { @@ -745,7 +758,7 @@ template void CarouselComponent::render(const glm::mat4& parentT if (comp == nullptr) continue; - if (mType == CarouselType::VERTICAL_WHEEL || mType == CarouselType::HORIZONTAL_WHEEL) { + if (isWheel) { if (mItemAxisHorizontal) { glm::mat4 positionCalc {renderItem.trans}; const float xOff {(GuiComponent::mOrigin.x - mItemRotationOrigin.x) * mItemSize.x};