// Boost.Geometry (aka GGL, Generic Geometry Library) // Copyright (c) 2017 Oracle and/or its affiliates. // Contributed and/or modified by Vissarion Fisikopoulos, on behalf of Oracle // Contributed and/or modified by Adam Wulkiewicz, on behalf of Oracle // 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_STRATEGIES_GEOGRAPHIC_ENVELOPE_SEGMENT_HPP #define BOOST_GEOMETRY_STRATEGIES_GEOGRAPHIC_ENVELOPE_SEGMENT_HPP #include #include #include #include #include #include namespace boost { namespace geometry { namespace strategy { namespace envelope { template < typename FormulaPolicy = strategy::andoyer, typename Spheroid = geometry::srs::spheroid, typename CalculationType = void > class geographic_segment { public: typedef Spheroid model_type; inline geographic_segment() : m_spheroid() {} explicit inline geographic_segment(Spheroid const& spheroid) : m_spheroid(spheroid) {} template inline void apply(Point1 const& point1, Point2 const& point2, Box& box) const { Point1 p1_normalized = detail::return_normalized(point1); Point2 p2_normalized = detail::return_normalized(point2); geometry::strategy::azimuth::geographic < FormulaPolicy, Spheroid, CalculationType > azimuth_geographic(m_spheroid); typedef typename coordinate_system::type::units units_type; detail::envelope::envelope_segment_impl < geographic_tag >::template apply(geometry::get<0>(p1_normalized), geometry::get<1>(p1_normalized), geometry::get<0>(p2_normalized), geometry::get<1>(p2_normalized), box, azimuth_geographic); } private: Spheroid m_spheroid; }; #ifndef DOXYGEN_NO_STRATEGY_SPECIALIZATIONS namespace services { template struct default_strategy { typedef strategy::envelope::geographic_segment < strategy::andoyer, srs::spheroid, CalculationType > type; }; } #endif // DOXYGEN_NO_STRATEGY_SPECIALIZATIONS }} // namespace strategy::envelope }} //namepsace boost::geometry #endif // BOOST_GEOMETRY_STRATEGIES_GEOGRAPHIC_ENVELOPE_SEGMENT_HPP