diff options
author | Dan Goodliffe <dan@randomdan.homeip.net> | 2025-03-07 20:23:53 +0000 |
---|---|---|
committer | Dan Goodliffe <dan@randomdan.homeip.net> | 2025-03-11 01:13:59 +0000 |
commit | 9da25631a119fd16f1810a027dae1fde7cb7527d (patch) | |
tree | 210f776fb8940f8b8f7ff6fa43a991076cd954e8 /gfx/aabb.h | |
parent | Only render terrain tiles which are visible in the frustum (diff) | |
download | ilt-9da25631a119fd16f1810a027dae1fde7cb7527d.tar.bz2 ilt-9da25631a119fd16f1810a027dae1fde7cb7527d.tar.xz ilt-9da25631a119fd16f1810a027dae1fde7cb7527d.zip |
AxisAlignedBoundingBox construct from range instead of span
Diffstat (limited to 'gfx/aabb.h')
-rw-r--r-- | gfx/aabb.h | 16 |
1 files changed, 14 insertions, 2 deletions
@@ -1,7 +1,8 @@ #pragma once #include "config/types.h" -#include <span> +#include <algorithm> +#include <tuple> class AxisAlignedBoundingBox { public: @@ -13,7 +14,18 @@ public: AxisAlignedBoundingBox operator-(const GlobalPosition3D & viewPoint) const; - [[nodiscard]] static AxisAlignedBoundingBox fromPoints(std::span<const GlobalPosition3D> points); + [[nodiscard]] static AxisAlignedBoundingBox + fromPoints(auto && points) + { + using Limits = std::numeric_limits<GlobalDistance>; + static constexpr const auto INITIAL + = std::make_pair(GlobalPosition3D {Limits::max()}, GlobalPosition3D {Limits::min()}); + return std::make_from_tuple<AxisAlignedBoundingBox>( + std::ranges::fold_left(points, INITIAL, [](const auto & prev, const auto & point) { + auto & [min, max] = prev; + return std::make_pair(glm::min(min, point), glm::max(max, point)); + })); + } GlobalPosition3D min, max; }; |