Files
comaps/track_analyzing/track_analyzer/crossroad_checker.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

43 lines
1.2 KiB
C++

#pragma once
#include "routing/geometry.hpp"
#include "routing/index_graph.hpp"
#include "routing/segment.hpp"
#include "base/stl_helpers.hpp"
#include <array>
#include <string>
namespace routing
{
class IsCrossroadChecker
{
public:
enum class Type
{
TurnFromSmallerToBigger,
TurnFromBiggerToSmaller,
IntersectionWithBig,
Count
};
using CrossroadInfo = std::array<size_t, base::Underlying(Type::Count)>;
IsCrossroadChecker(IndexGraph & indexGraph, Geometry & geometry) : m_indexGraph(indexGraph), m_geometry(geometry) {}
/// \brief Compares two segments by their highway type to find if there was a crossroad between them.
/// Check if current segment is a joint to find and find all intersections with other roads.
Type operator()(Segment const & current, Segment const & next) const;
static void MergeCrossroads(Type from, CrossroadInfo & to);
static void MergeCrossroads(IsCrossroadChecker::CrossroadInfo const & from,
IsCrossroadChecker::CrossroadInfo & to);
private:
IndexGraph & m_indexGraph;
Geometry & m_geometry;
};
std::string DebugPrint(IsCrossroadChecker::Type type);
} // namespace routing