192 lines
5.1 KiB
C++
192 lines
5.1 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.
|
||
|
|
||
|
// 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 <boost/concept/assert.hpp>
|
||
|
#include <boost/config.hpp>
|
||
|
|
||
|
#include <boost/geometry/algorithms/convert.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:
|
||
|
|
||
|
#if !defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
||
|
#if !defined(BOOST_NO_CXX11_DEFAULTED_FUNCTIONS)
|
||
|
/// \constructor_default_no_init
|
||
|
box() = default;
|
||
|
#else
|
||
|
/// \constructor_default_no_init
|
||
|
inline box()
|
||
|
{}
|
||
|
#endif
|
||
|
#else // defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
||
|
inline box()
|
||
|
{
|
||
|
m_created = 1;
|
||
|
}
|
||
|
~box()
|
||
|
{
|
||
|
m_created = 0;
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
/*!
|
||
|
\brief Constructor taking the minimum corner point and the maximum corner point
|
||
|
*/
|
||
|
inline 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
|
||
|
}
|
||
|
|
||
|
inline Point const& min_corner() const
|
||
|
{
|
||
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
||
|
BOOST_GEOMETRY_ASSERT(m_created == 1);
|
||
|
#endif
|
||
|
return m_min_corner;
|
||
|
}
|
||
|
inline Point const& max_corner() const
|
||
|
{
|
||
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
||
|
BOOST_GEOMETRY_ASSERT(m_created == 1);
|
||
|
#endif
|
||
|
return m_max_corner;
|
||
|
}
|
||
|
|
||
|
inline Point& min_corner()
|
||
|
{
|
||
|
#if defined(BOOST_GEOMETRY_ENABLE_ACCESS_DEBUGGING)
|
||
|
BOOST_GEOMETRY_ASSERT(m_created == 1);
|
||
|
#endif
|
||
|
return m_min_corner;
|
||
|
}
|
||
|
inline 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 inline coordinate_type get(model::box<Point> const& b)
|
||
|
{
|
||
|
return geometry::get<Dimension>(b.min_corner());
|
||
|
}
|
||
|
|
||
|
static inline 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 inline coordinate_type get(model::box<Point> const& b)
|
||
|
{
|
||
|
return geometry::get<Dimension>(b.max_corner());
|
||
|
}
|
||
|
|
||
|
static inline void set(model::box<Point>& b, coordinate_type const& value)
|
||
|
{
|
||
|
geometry::set<Dimension>(b.max_corner(), value);
|
||
|
}
|
||
|
};
|
||
|
|
||
|
} // namespace traits
|
||
|
#endif // DOXYGEN_NO_TRAITS_SPECIALIZATIONS
|
||
|
|
||
|
}} // namespace boost::geometry
|
||
|
|
||
|
#endif // BOOST_GEOMETRY_GEOMETRIES_BOX_HPP
|