geographic.hpp 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. // Boost.Geometry
  2. // Copyright (c) 2020-2021, Oracle and/or its affiliates.
  3. // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle
  4. // Licensed under the Boost Software License version 1.0.
  5. // http://www.boost.org/users/license.html
  6. #ifndef BOOST_GEOMETRY_STRATEGIES_GEOGRAPHIC_HPP
  7. #define BOOST_GEOMETRY_STRATEGIES_GEOGRAPHIC_HPP
  8. #include <boost/geometry/strategies/area/geographic.hpp>
  9. #include <boost/geometry/strategies/azimuth/geographic.hpp>
  10. #include <boost/geometry/strategies/buffer/geographic.hpp>
  11. #include <boost/geometry/strategies/convex_hull/geographic.hpp>
  12. #include <boost/geometry/strategies/distance/geographic.hpp>
  13. #include <boost/geometry/strategies/envelope/geographic.hpp>
  14. #include <boost/geometry/strategies/expand/geographic.hpp>
  15. #include <boost/geometry/strategies/io/geographic.hpp>
  16. #include <boost/geometry/strategies/index/geographic.hpp>
  17. #include <boost/geometry/strategies/is_convex/geographic.hpp>
  18. #include <boost/geometry/strategies/relate/geographic.hpp>
  19. #include <boost/geometry/strategies/simplify/geographic.hpp>
  20. namespace boost { namespace geometry
  21. {
  22. namespace strategies
  23. {
  24. template
  25. <
  26. typename FormulaPolicy = strategy::andoyer,
  27. typename Spheroid = srs::spheroid<double>,
  28. typename CalculationType = void
  29. >
  30. class geographic
  31. // derived from the umbrella strategy defining the most strategies
  32. : public index::geographic<FormulaPolicy, Spheroid, CalculationType>
  33. {
  34. using base_t = index::geographic<FormulaPolicy, Spheroid, CalculationType>;
  35. public:
  36. geographic() = default;
  37. explicit geographic(Spheroid const& spheroid)
  38. : base_t(spheroid)
  39. {}
  40. auto azimuth() const
  41. {
  42. return strategy::azimuth::geographic
  43. <
  44. FormulaPolicy, Spheroid, CalculationType
  45. >(base_t::m_spheroid);
  46. }
  47. auto point_order() const
  48. {
  49. return strategy::point_order::geographic
  50. <
  51. FormulaPolicy, Spheroid, CalculationType
  52. >(base_t::m_spheroid);
  53. }
  54. };
  55. } // namespace strategies
  56. }} // namespace boost::geometry
  57. #endif // BOOST_GEOMETRY_STRATEGIES_GEOGRAPHIC_HPP