areal.hpp 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. // Boost.Geometry
  2. // Copyright (c) 2018 Oracle and/or its affiliates.
  3. // Contributed and/or modified by Vissarion Fysikopoulos, on behalf of Oracle
  4. // Use, modification and distribution is subject to the Boost Software License,
  5. // Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at
  6. // http://www.boost.org/LICENSE_1_0.txt)
  7. #ifndef BOOST_GEOMETRY_ALGORITHMS_DETAIL_ENVELOPE_AREAL_HPP
  8. #define BOOST_GEOMETRY_ALGORITHMS_DETAIL_ENVELOPE_AREAL_HPP
  9. #include <boost/geometry/core/cs.hpp>
  10. #include <boost/geometry/core/tags.hpp>
  11. #include <boost/geometry/iterators/segment_iterator.hpp>
  12. #include <boost/geometry/algorithms/detail/envelope/range.hpp>
  13. #include <boost/geometry/algorithms/detail/envelope/linear.hpp>
  14. #include <boost/geometry/algorithms/dispatch/envelope.hpp>
  15. namespace boost { namespace geometry
  16. {
  17. #ifndef DOXYGEN_NO_DETAIL
  18. namespace detail { namespace envelope
  19. {
  20. template <typename EnvelopePolicy>
  21. struct envelope_polygon
  22. {
  23. template <typename Polygon, typename Box, typename Strategy>
  24. static inline void apply(Polygon const& polygon, Box& mbr, Strategy const& strategy)
  25. {
  26. typename ring_return_type<Polygon const>::type ext_ring
  27. = exterior_ring(polygon);
  28. if (geometry::is_empty(ext_ring))
  29. {
  30. // if the exterior ring is empty, consider the interior rings
  31. envelope_multi_range
  32. <
  33. EnvelopePolicy
  34. >::apply(interior_rings(polygon), mbr, strategy);
  35. }
  36. else
  37. {
  38. // otherwise, consider only the exterior ring
  39. EnvelopePolicy::apply(ext_ring, mbr, strategy);
  40. }
  41. }
  42. };
  43. }} // namespace detail::envelope
  44. #endif // DOXYGEN_NO_DETAIL
  45. #ifndef DOXYGEN_NO_DISPATCH
  46. namespace dispatch
  47. {
  48. template <typename Ring, typename CS_Tag>
  49. struct envelope<Ring, ring_tag, CS_Tag>
  50. : detail::envelope::envelope_range
  51. {};
  52. template <typename Ring>
  53. struct envelope<Ring, ring_tag, spherical_equatorial_tag>
  54. : detail::envelope::envelope_linestring_or_ring_on_spheroid
  55. {};
  56. template <typename Ring>
  57. struct envelope<Ring, ring_tag, geographic_tag>
  58. : detail::envelope::envelope_linestring_or_ring_on_spheroid
  59. {};
  60. template <typename Polygon, typename CS_Tag>
  61. struct envelope<Polygon, polygon_tag, CS_Tag>
  62. : detail::envelope::envelope_polygon
  63. <
  64. detail::envelope::envelope_range
  65. >
  66. {};
  67. template <typename Polygon>
  68. struct envelope<Polygon, polygon_tag, spherical_equatorial_tag>
  69. : detail::envelope::envelope_polygon
  70. <
  71. detail::envelope::envelope_linestring_or_ring_on_spheroid
  72. >
  73. {};
  74. template <typename Polygon>
  75. struct envelope<Polygon, polygon_tag, geographic_tag>
  76. : detail::envelope::envelope_polygon
  77. <
  78. detail::envelope::envelope_linestring_or_ring_on_spheroid
  79. >
  80. {};
  81. template <typename MultiPolygon, typename CS_Tag>
  82. struct envelope<MultiPolygon, multi_polygon_tag, CS_Tag>
  83. : detail::envelope::envelope_multi_range
  84. <
  85. detail::envelope::envelope_polygon
  86. <
  87. detail::envelope::envelope_range
  88. >
  89. >
  90. {};
  91. template <typename MultiPolygon>
  92. struct envelope<MultiPolygon, multi_polygon_tag, spherical_equatorial_tag>
  93. : detail::envelope::envelope_multi_range
  94. <
  95. detail::envelope::envelope_polygon
  96. <
  97. detail::envelope::envelope_linestring_or_ring_on_spheroid
  98. >
  99. >
  100. {};
  101. template <typename MultiPolygon>
  102. struct envelope<MultiPolygon, multi_polygon_tag, geographic_tag>
  103. : detail::envelope::envelope_multi_range
  104. <
  105. detail::envelope::envelope_polygon
  106. <
  107. detail::envelope::envelope_linestring_or_ring_on_spheroid
  108. >
  109. >
  110. {};
  111. } // namespace dispatch
  112. #endif // DOXYGEN_NO_DISPATCH
  113. }} // namespace boost::geometry
  114. #endif // BOOST_GEOMETRY_ALGORITHMS_DETAIL_ENVELOPE_AREAL_HPP