dust3d/thirdparty/carve-1.4.0/include/carve/convex_hull.hpp

53 lines
1.6 KiB
C++

// Begin License:
// Copyright (C) 2006-2008 Tobias Sargeant (tobias.sargeant@gmail.com).
// All rights reserved.
//
// This file is part of the Carve CSG Library (http://carve-csg.com/)
//
// This file may be used under the terms of the GNU General Public
// License version 2.0 as published by the Free Software Foundation
// and appearing in the file LICENSE.GPL2 included in the packaging of
// this file.
//
// This file is provided "AS IS" with NO WARRANTY OF ANY KIND,
// INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE.
// End:
#pragma once
#include <list>
#include <vector>
#include <algorithm>
#include <carve/carve.hpp>
#include <carve/geom2d.hpp>
namespace carve {
namespace geom {
std::vector<int> convexHull(const std::vector<carve::geom2d::P2> &points);
template<typename project_t, typename polygon_container_t>
std::vector<int> convexHull(const project_t &project, const polygon_container_t &points) {
std::vector<carve::geom2d::P2> proj;
proj.reserve(points.size());
for (typename polygon_container_t::const_iterator i = points.begin(); i != points.end(); ++i) {
proj.push_back(project(*i));
}
return convexHull(proj);
}
template<typename project_t, typename iter_t>
std::vector<int> convexHull(const project_t &project, iter_t beg, iter_t end, size_t size_hint = 0) {
std::vector<carve::geom2d::P2> proj;
if (size_hint) proj.reserve(size_hint);
for (; beg != end; ++beg) {
proj.push_back(project(*beg));
}
return convexHull(proj);
}
}
}