Files
comaps/routing/segmented_route.hpp
Konstantin Pastbin e3e4a1985a Organic Maps sources as of 02.04.2025 (fad26bbf22ac3da75e01e62aa01e5c8e11861005)
To expand with full Organic Maps and Maps.ME commits history run:
  git remote add om-historic [om-historic.git repo url]
  git fetch --tags om-historic
  git replace squashed-history historic-commits
2025-05-08 21:10:51 +07:00

54 lines
1.4 KiB
C++

#pragma once
#include "routing/route.hpp"
#include "routing/segment.hpp"
#include "geometry/point2d.hpp"
#include <vector>
namespace routing
{
class SegmentedRoute final
{
public:
class Step final
{
public:
Step() = default;
Step(Segment const & segment, m2::PointD const & point) : m_segment(segment), m_point(point) {}
Segment const & GetSegment() const { return m_segment; }
m2::PointD const & GetPoint() const { return m_point; }
private:
Segment m_segment;
// The front point of segment
m2::PointD m_point = m2::PointD::Zero();
};
SegmentedRoute(m2::PointD const & start, m2::PointD const & finish,
std::vector<Route::SubrouteAttrs> const & subroutes);
void AddStep(Segment const & segment, m2::PointD const & point)
{
m_steps.emplace_back(segment, point);
}
double CalcDistance(m2::PointD const & point) const;
m2::PointD const & GetStart() const { return m_start; }
m2::PointD const & GetFinish() const { return m_finish; }
std::vector<Step> const & GetSteps() const { return m_steps; }
bool IsEmpty() const { return m_steps.empty(); }
std::vector<Route::SubrouteAttrs> const & GetSubroutes() const { return m_subroutes; }
Route::SubrouteAttrs const & GetSubroute(size_t i) const;
private:
m2::PointD const m_start;
m2::PointD const m_finish;
std::vector<Step> m_steps;
std::vector<Route::SubrouteAttrs> m_subroutes;
};
} // namespace routing