#include "engine/guidance/assemble_steps.hpp" #include #include "util/bearing.hpp" #include "util/log.hpp" #include #include namespace osrm { namespace engine { namespace guidance { namespace detail { std::pair getDepartBearings(const LegGeometry &leg_geometry, const PhantomNode &source_node, const bool traversed_in_reverse) { BOOST_ASSERT(leg_geometry.locations.size() >= 2); const auto turn_coordinate = leg_geometry.locations.front(); const auto post_turn_coordinate = *(leg_geometry.locations.begin() + 1); if (turn_coordinate == post_turn_coordinate) { return std::make_pair(0, source_node.GetBearing(traversed_in_reverse)); } return std::make_pair( 0, std::round(util::coordinate_calculation::bearing(turn_coordinate, post_turn_coordinate))); } std::pair getArriveBearings(const LegGeometry &leg_geometry, const PhantomNode &target_node, const bool traversed_in_reverse) { BOOST_ASSERT(leg_geometry.locations.size() >= 2); const auto turn_coordinate = leg_geometry.locations.back(); const auto pre_turn_coordinate = *(leg_geometry.locations.end() - 2); if (turn_coordinate == pre_turn_coordinate) { return std::make_pair(target_node.GetBearing(traversed_in_reverse), 0); } return std::make_pair( std::round(util::coordinate_calculation::bearing(pre_turn_coordinate, turn_coordinate)), 0); } } // ns detail } // ns engine } // ns guidance } // ns detail