256 lines
6.4 KiB
C++
256 lines
6.4 KiB
C++
// Boost.Geometry (aka GGL, Generic Geometry Library)
|
|
|
|
// Copyright (c) 2007-2012 Barend Gehrels, Amsterdam, the Netherlands.
|
|
// Copyright (c) 2008-2012 Bruno Lalande, Paris, France.
|
|
// Copyright (c) 2009-2012 Mateusz Loskot, London, UK.
|
|
|
|
// This file was modified by Oracle on 2020.
|
|
// Modifications copyright (c) 2020, Oracle and/or its affiliates.
|
|
// Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle
|
|
|
|
// Parts of Boost.Geometry are redesigned from Geodan's Geographic Library
|
|
// (geolib/GGL), copyright (c) 1995-2010 Geodan, Amsterdam, the Netherlands.
|
|
|
|
// Use, modification and distribution is subject to the Boost Software License,
|
|
// Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
|
|
// http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
#ifndef BOOST_GEOMETRY_GEOMETRIES_BOX_HPP
|
|
#define BOOST_GEOMETRY_GEOMETRIES_BOX_HPP
|
|
|
|
#include <cstddef>
|
|
#include <type_traits>
|
|
|
|
#include <boost/concept/assert.hpp>
|
|
|
|
#include <boost/geometry/algorithms/convert.hpp>
|
|
|
|
#include <boost/geometry/core/access.hpp>
|
|
#include <boost/geometry/core/make.hpp>
|
|
#include <boost/geometry/core/point_type.hpp>
|
|
#include <boost/geometry/core/tag.hpp>
|
|
#include <boost/geometry/core/tags.hpp>
|
|
|
|
#include <boost/geometry/geometries/concepts/point_concept.hpp>
|
|
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
#include <boost/geometry/core/assert.hpp>
|
|
#endif
|
|
|
|
|
|
namespace boost { namespace geometry
|
|
{
|
|
|
|
namespace model
|
|
{
|
|
|
|
/*!
|
|
\brief Class box: defines a box made of two describing points
|
|
\ingroup geometries
|
|
\details Box is always described by a min_corner() and a max_corner() point. If another
|
|
rectangle is used, use linear_ring or polygon.
|
|
\note Boxes are for selections and for calculating the envelope of geometries. Not all algorithms
|
|
are implemented for box. Boxes are also used in Spatial Indexes.
|
|
\tparam Point point type. The box takes a point type as template parameter.
|
|
The point type can be any point type.
|
|
It can be 2D but can also be 3D or more dimensional.
|
|
The box can also take a latlong point type as template parameter.
|
|
|
|
\qbk{[include reference/geometries/box.qbk]}
|
|
\qbk{before.synopsis, [heading Model of]}
|
|
\qbk{before.synopsis, [link geometry.reference.concepts.concept_box Box Concept]}
|
|
*/
|
|
|
|
template<typename Point>
|
|
class box
|
|
{
|
|
BOOST_CONCEPT_ASSERT( (concepts::Point<Point>) );
|
|
|
|
public:
|
|
|
|
// TODO: constexpr requires LiteralType and until C++20
|
|
// it has to have trivial destructor which makes access
|
|
// debugging impossible with constexpr.
|
|
|
|
#if !defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
/// \constructor_default_no_init
|
|
constexpr box() = default;
|
|
#else // defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
box()
|
|
{
|
|
m_created = 1;
|
|
}
|
|
~box()
|
|
{
|
|
m_created = 0;
|
|
}
|
|
#endif
|
|
|
|
/*!
|
|
\brief Constructor taking the minimum corner point and the maximum corner point
|
|
*/
|
|
template
|
|
<
|
|
typename P = Point,
|
|
std::enable_if_t
|
|
<
|
|
! std::is_copy_constructible<P>::value,
|
|
int
|
|
> = 0
|
|
>
|
|
box(Point const& min_corner, Point const& max_corner)
|
|
{
|
|
geometry::convert(min_corner, m_min_corner);
|
|
geometry::convert(max_corner, m_max_corner);
|
|
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
m_created = 1;
|
|
#endif
|
|
}
|
|
|
|
/*!
|
|
\brief Constructor taking the minimum corner point and the maximum corner point
|
|
*/
|
|
template
|
|
<
|
|
typename P = Point,
|
|
std::enable_if_t
|
|
<
|
|
std::is_copy_constructible<P>::value,
|
|
int
|
|
> = 0
|
|
>
|
|
#if ! defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
constexpr
|
|
#endif
|
|
box(Point const& min_corner, Point const& max_corner)
|
|
: m_min_corner(min_corner)
|
|
, m_max_corner(max_corner)
|
|
{
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
m_created = 1;
|
|
#endif
|
|
}
|
|
|
|
#if ! defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
constexpr
|
|
#endif
|
|
Point const& min_corner() const
|
|
{
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
BOOST_GEOMETRY_ASSERT(m_created == 1);
|
|
#endif
|
|
return m_min_corner;
|
|
}
|
|
|
|
#if ! defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
constexpr
|
|
#endif
|
|
Point const& max_corner() const
|
|
{
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
BOOST_GEOMETRY_ASSERT(m_created == 1);
|
|
#endif
|
|
return m_max_corner;
|
|
}
|
|
|
|
Point& min_corner()
|
|
{
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
BOOST_GEOMETRY_ASSERT(m_created == 1);
|
|
#endif
|
|
return m_min_corner;
|
|
}
|
|
|
|
Point& max_corner()
|
|
{
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
BOOST_GEOMETRY_ASSERT(m_created == 1);
|
|
#endif
|
|
return m_max_corner;
|
|
}
|
|
|
|
private:
|
|
|
|
Point m_min_corner;
|
|
Point m_max_corner;
|
|
|
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
|
int m_created;
|
|
#endif
|
|
};
|
|
|
|
|
|
} // namespace model
|
|
|
|
|
|
// Traits specializations for box above
|
|
#ifndef DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
|
namespace traits
|
|
{
|
|
|
|
template <typename Point>
|
|
struct tag<model::box<Point> >
|
|
{
|
|
typedef box_tag type;
|
|
};
|
|
|
|
template <typename Point>
|
|
struct point_type<model::box<Point> >
|
|
{
|
|
typedef Point type;
|
|
};
|
|
|
|
template <typename Point, std::size_t Dimension>
|
|
struct indexed_access<model::box<Point>, min_corner, Dimension>
|
|
{
|
|
typedef typename geometry::coordinate_type<Point>::type coordinate_type;
|
|
|
|
static constexpr coordinate_type get(model::box<Point> const& b)
|
|
{
|
|
return geometry::get<Dimension>(b.min_corner());
|
|
}
|
|
|
|
static void set(model::box<Point>& b, coordinate_type const& value)
|
|
{
|
|
geometry::set<Dimension>(b.min_corner(), value);
|
|
}
|
|
};
|
|
|
|
template <typename Point, std::size_t Dimension>
|
|
struct indexed_access<model::box<Point>, max_corner, Dimension>
|
|
{
|
|
typedef typename geometry::coordinate_type<Point>::type coordinate_type;
|
|
|
|
static constexpr coordinate_type get(model::box<Point> const& b)
|
|
{
|
|
return geometry::get<Dimension>(b.max_corner());
|
|
}
|
|
|
|
static void set(model::box<Point>& b, coordinate_type const& value)
|
|
{
|
|
geometry::set<Dimension>(b.max_corner(), value);
|
|
}
|
|
};
|
|
|
|
template <typename Point>
|
|
struct make<model::box<Point> >
|
|
{
|
|
typedef model::box<Point> box_type;
|
|
|
|
static const bool is_specialized = true;
|
|
|
|
static constexpr box_type apply(Point const& min_corner, Point const& max_corner)
|
|
{
|
|
return box_type(min_corner, max_corner);
|
|
}
|
|
};
|
|
|
|
|
|
} // namespace traits
|
|
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
|
|
|
}} // namespace boost::geometry
|
|
|
|
#endif // BOOST_GEOMETRY_GEOMETRIES_BOX_HPP
|