| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 | // Boost.Geometry (aka GGL, Generic Geometry Library)// Copyright (c) 2007-2012 Barend Gehrels, 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_ALGORITHMS_INTERSECTION_HPP#define BOOST_GEOMETRY_ALGORITHMS_INTERSECTION_HPP#include <boost/geometry/core/coordinate_dimension.hpp>#include <boost/geometry/algorithms/detail/overlay/intersection_insert.hpp>#include <boost/geometry/algorithms/intersects.hpp>namespace boost { namespace geometry{#ifndef DOXYGEN_NO_DETAILnamespace detail { namespace intersection{template <std::size_t Dimension, std::size_t DimensionCount>struct intersection_box_box{    template    <        typename Box1, typename Box2, typename BoxOut,        typename Strategy    >    static inline bool apply(Box1 const& box1,            Box2 const& box2, BoxOut& box_out,            Strategy const& strategy)    {        typedef typename coordinate_type<BoxOut>::type ct;        ct min1 = get<min_corner, Dimension>(box1);        ct min2 = get<min_corner, Dimension>(box2);        ct max1 = get<max_corner, Dimension>(box1);        ct max2 = get<max_corner, Dimension>(box2);        if (max1 < min2 || max2 < min1)        {            return false;        }        // Set dimensions of output coordinate        set<min_corner, Dimension>(box_out, min1 < min2 ? min2 : min1);        set<max_corner, Dimension>(box_out, max1 > max2 ? max2 : max1);        return intersection_box_box<Dimension + 1, DimensionCount>               ::apply(box1, box2, box_out, strategy);    }};template <std::size_t DimensionCount>struct intersection_box_box<DimensionCount, DimensionCount>{    template    <        typename Box1, typename Box2, typename BoxOut,        typename Strategy    >    static inline bool apply(Box1 const&, Box2 const&, BoxOut&, Strategy const&)    {        return true;    }};}} // namespace detail::intersection#endif // DOXYGEN_NO_DETAIL#ifndef DOXYGEN_NO_DISPATCHnamespace dispatch{// By default, all is forwarded to the intersection_insert-dispatchertemplate<    typename Geometry1, typename Geometry2,    typename Tag1 = typename geometry::tag<Geometry1>::type,    typename Tag2 = typename geometry::tag<Geometry2>::type,    bool Reverse = reverse_dispatch<Geometry1, Geometry2>::type::value>struct intersection{    template <typename GeometryOut, typename Strategy>    static inline bool apply(Geometry1 const& geometry1,            Geometry2 const& geometry2,            GeometryOut& geometry_out,            Strategy const& strategy)    {        typedef typename boost::range_value<GeometryOut>::type OneOut;        intersection_insert        <            Geometry1, Geometry2, OneOut,            overlay_intersection        >::apply(geometry1, geometry2, std::back_inserter(geometry_out), strategy);        return true;    }};// If reversal is needed, perform ittemplate<    typename Geometry1, typename Geometry2,    typename Tag1, typename Tag2>struct intersection<    Geometry1, Geometry2,    Tag1, Tag2,    true>    : intersection<Geometry2, Geometry1, Tag2, Tag1, false>{    template <typename GeometryOut, typename Strategy>    static inline bool apply(        Geometry1 const& g1,        Geometry2 const& g2,        GeometryOut& out,        Strategy const& strategy)    {        return intersection<                   Geometry2, Geometry1,                   Tag2, Tag1,                   false               >::apply(g2, g1, out, strategy);    }};template<    typename Box1, typename Box2, bool Reverse>struct intersection    <        Box1, Box2,        box_tag, box_tag,        Reverse    > : public detail::intersection::intersection_box_box            <                0, geometry::dimension<Box1>::value            >{};} // namespace dispatch#endif // DOXYGEN_NO_DISPATCH/*!\brief \brief_calc2{intersection}\ingroup intersection\details \details_calc2{intersection, spatial set theoretic intersection}.\tparam Geometry1 \tparam_geometry\tparam Geometry2 \tparam_geometry\tparam GeometryOut Collection of geometries (e.g. std::vector, std::deque, boost::geometry::multi*) of which    the value_type fulfills a \p_l_or_c concept, or it is the output geometry (e.g. for a box)\param geometry1 \param_geometry\param geometry2 \param_geometry\param geometry_out The output geometry, either a multi_point, multi_polygon,    multi_linestring, or a box (for intersection of two boxes)\qbk{[include reference/algorithms/intersection.qbk]}*/template<    typename Geometry1,    typename Geometry2,    typename GeometryOut>inline bool intersection(Geometry1 const& geometry1,            Geometry2 const& geometry2,            GeometryOut& geometry_out){    concept::check<Geometry1 const>();    concept::check<Geometry2 const>();    typedef strategy_intersection        <            typename cs_tag<Geometry1>::type,            Geometry1,            Geometry2,            typename geometry::point_type<Geometry1>::type        > strategy;    return dispatch::intersection<               Geometry1,               Geometry2           >::apply(geometry1, geometry2, geometry_out, strategy());}}} // namespace boost::geometry#endif // BOOST_GEOMETRY_ALGORITHMS_INTERSECTION_HPP
 |