Skip to content

Instantly share code, notes, and snippets.

@danvk
Created August 17, 2014 17:36
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save danvk/66405fd9b2b981faea3e to your computer and use it in GitHub Desktop.
Save danvk/66405fd9b2b981faea3e to your computer and use it in GitHub Desktop.
/*
Copyright (c) 2012, Canal TP
This is an example file, do whatever you want with it! (for example if you are in Paris, invite us for a beer)
This shows the simplest way to use the osm.pbf reader. It just counts the number of objects in the file.
To build this file :
g++ -O2 -o counter example_counter.cc -losmpbf -lprotobuf
To run it:
./counter path_to_your_data.osm.pbf
*/
#include "osmpbfreader.h"
using namespace CanalTP;
using std::string;
// We need to define a visitor with three methods that will be called while the file is read
struct Counter {
// Three integers count how many times each object type occurs
int nodes;
int ways;
int relations;
Counter() : nodes(0), ways(0), relations(0) {}
// This method is called every time a Node is read
void node_callback(uint64_t /*osmid*/, double /*lon*/, double /*lat*/, const Tags &/*tags*/){
++nodes;
}
// This method is called every time a Way is read
// refs is a vector that contains the reference to the nodes that compose the way
void way_callback(uint64_t osmid, const Tags &tags, const std::vector<uint64_t> &/*refs*/){
++ways;
if (!has_wikipedia_tag(tags)) return;
std::cout << "way\t" << osmid
<< "\t" << get_tag(tags, "wikipedia")
<< "\t" << get_tag(tags, "name")
<< std::endl;
}
// This method is called every time a Relation is read
// refs is a vector of pair corresponding of the relation type (Node, Way, Relation) and the reference to the object
void relation_callback(uint64_t osmid, const Tags &tags, const References & /*refs*/){
++relations;
if (!has_wikipedia_tag(tags)) return;
std::cout << "relation\t" << osmid
<< "\t" << get_tag(tags, "wikipedia")
<< "\t" << get_tag(tags, "name")
<< std::endl;
}
private:
bool has_wikipedia_tag(const Tags& tags) {
return (tags.find("wikipedia") != tags.end());
}
string get_tag(const Tags& tags, const string& tag_name) {
Tags::const_iterator i = tags.find(tag_name);
if (i == tags.end()) {
return "";
} else {
return i->second;
}
}
};
int main(int argc, char** argv) {
if(argc != 2) {
std::cout << "Usage: " << argv[0] << " file_to_read.osm.pbf" << std::endl;
return 1;
}
// Let's read that file !
Counter counter;
read_osm_pbf(argv[1], counter);
std::cout << "We read " << counter.nodes << " nodes, " << counter.ways << " ways and " << counter.relations << " relations" << std::endl;
return 0;
}
@naeimrezaeian
Copy link

how i can download this file osmpbfreader.h ?

@naeimrezaeian
Copy link

how i can get latitude/longitude for each node ?

@Lecrapouille
Copy link

Lecrapouille commented Oct 2, 2020

@naeimrezaeian I've not yet tested but looks like this https://github.com/CanalTP/libosmpbfreader and for gettins lat/long is void node_callback(uint64_t osmid, double lon, double lat, const Tags &tags)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment