summaryrefslogtreecommitdiffhomepage
path: root/tile-atlas.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tile-atlas.cpp')
-rw-r--r--tile-atlas.cpp15
1 files changed, 7 insertions, 8 deletions
diff --git a/tile-atlas.cpp b/tile-atlas.cpp
index ac786bd1..d5d56cce 100644
--- a/tile-atlas.cpp
+++ b/tile-atlas.cpp
@@ -5,15 +5,14 @@
namespace Magnum::Examples {
-tile_atlas::tile_atlas(Containers::StringView name, const ImageView2D& image, Vector2i dims) :
+tile_atlas::tile_atlas(Containers::StringView name, const ImageView2D& image, Vector2ui dims) :
name_{name},
size_{image.size()},
dims_{dims}
{
CORRADE_INTERNAL_ASSERT(dims_[0] > 0 && dims_[1] > 0);
- CORRADE_INTERNAL_ASSERT(size_ % dims_ == Vector2i{});
- CORRADE_INTERNAL_ASSERT(dims.product() < 256);
- CORRADE_INTERNAL_ASSERT(tile_size() * dims_ == size_);
+ CORRADE_INTERNAL_ASSERT(size_ % dims_ == Vector2ui{});
+ CORRADE_INTERNAL_ASSERT(dims_.product() < 256);
tex_.setWrapping(GL::SamplerWrapping::ClampToBorder)
.setMagnificationFilter(GL::SamplerFilter::Linear)
.setMinificationFilter(GL::SamplerFilter::Linear)
@@ -24,10 +23,10 @@ tile_atlas::tile_atlas(Containers::StringView name, const ImageView2D& image, Ve
std::array<Vector2, 4> tile_atlas::texcoords_for_id(std::size_t id_) const
{
- ASSERT(id_ < size());
- const Vector2i id = { (int)id_ % dims_[0], (int)id_ / dims_[0] };
- const Vector2 p1(tile_size());
- const auto p0 = Vector2(id * p1);
+ const auto sz = size_/dims_;
+ ASSERT(id_ < sz.product());
+ const Vector2ui id = { (unsigned)id_ % dims_[0], (unsigned)id_ / dims_[0] };
+ const Vector2 p0(id * sz), p1(sz);
const auto x0 = p0.x(), x1 = p1.x(), y0 = p0.y(), y1 = p1.y();
return {{
{ x0+x1, y0+y1 }, // bottom right