包含具有无效位置的NodeRef的方式

问题描述 投票:3回答:1

我用锇解析mayotte pbf,我的处理程序正在寻找方法。当我找到一个我处理它的重心并打印它。我遇到的问题是我处理的所有方法都有invalid location。如果打印位置我得到undefined纬度和经度。

我的PBF文件有问题,还是我对osmium library有所了解?

这是一个mcve:

/**
 * To compile this script, you should first install `libosmium` and its
 * dependencies. Then:
 *   g++ -std=c++11 -lz -lexpat -lbz2 mcve.cpp -o mcve
 */
#include <iostream>

#include <osmium/handler.hpp>
#include <osmium/io/any_input.hpp>
#include <osmium/osm/node.hpp>
#include <osmium/osm/way.hpp>
#include <osmium/visitor.hpp>

class ParkingAndCarpoolingAreasHandler : public osmium::handler::Handler {
public:
    void way(const osmium::Way& way) {
      double lng;
      double lat;
      double count = 0.0;
      for (const osmium::NodeRef& nr : way.nodes()) {
          if (!nr.location().valid()) {
            std::cerr << "Way (id=" << way.id()
                      << " version=" << way.version()
                      << " timestamp=" << way.timestamp()
                      << " visible=" << (way.visible() ? "true" : "false")
                      << " changeset=" << way.changeset()
                      << " uid=" << way.uid()
                      << " user=" << way.user() << ")\n";
            std::cerr << "NodeRef (ref=" << nr.ref() << " location=" << nr.location() << ")\n";
            std::cerr << std::endl;
            return;
          }
          count++;
          lng += nr.location().lon();
          lat += nr.location().lat();
      }
      lng /= count;
      lat /= count;
      std::cout << "POINT(" << lat << ' ' << lng << ")\n";
    }
};

int main() {
    auto otypes = osmium::osm_entity_bits::node | osmium::osm_entity_bits::way;
    osmium::io::Reader reader{"tmp/mayotte-latest.osm.pbf", otypes};
    ParkingAndCarpoolingAreasHandler handler;
    osmium::apply(reader, handler);
    reader.close();
}
c++ openstreetmap osmium
1个回答
2
投票

在OSM中,通常只存储对其所包含节点的引用。这些引用只包含节点ID但没有其他信息(例如坐标和标记)。要获得节点坐标,您必须查看实际节点,而不仅仅是它们的参考。

有关更多信息,请参阅OSM XMLPBF Format

由于我没有锇的经验,我无法告诉你如何通过他们的ID检索相应的节点。但是根据Osmium Concepts Manual,你可以使用NodeLocationsForWays处理程序来填充你的NodeRef对象的位置。 examples/osmium_road_length.cpp包含一个例子。

© www.soinside.com 2019 - 2024. All rights reserved.