2012-05-01 01:43:09 +02:00
|
|
|
#ifndef _OSMAND_BINARY_READ_H
|
|
|
|
#define _OSMAND_BINARY_READ_H
|
|
|
|
|
2012-06-15 14:34:25 +02:00
|
|
|
#include <fcntl.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <sys/types.h>
|
2012-05-01 01:43:09 +02:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <fstream>
|
|
|
|
#include <map>
|
|
|
|
#include <string>
|
|
|
|
#include <stdint.h>
|
2012-05-01 20:49:45 +02:00
|
|
|
|
|
|
|
|
2012-05-01 01:43:09 +02:00
|
|
|
#include "mapObjects.h"
|
2012-05-01 20:49:45 +02:00
|
|
|
#include "multipolygons.h"
|
|
|
|
#include "common.h"
|
2012-05-01 01:43:09 +02:00
|
|
|
|
|
|
|
|
2012-05-01 20:49:45 +02:00
|
|
|
#include "mapObjects.h"
|
|
|
|
#include "renderRules.h"
|
|
|
|
|
2012-05-02 00:43:51 +02:00
|
|
|
static const int MAP_VERSION = 2;
|
|
|
|
static const int BASEMAP_ZOOM = 11;
|
|
|
|
|
2012-05-01 01:43:09 +02:00
|
|
|
|
|
|
|
struct MapTreeBounds {
|
2012-06-15 14:34:25 +02:00
|
|
|
uint32_t length;
|
|
|
|
uint32_t filePointer;
|
|
|
|
uint32_t mapDataBlock;
|
|
|
|
uint32_t left ;
|
|
|
|
uint32_t right ;
|
|
|
|
uint32_t top ;
|
|
|
|
uint32_t bottom;
|
2012-05-01 01:43:09 +02:00
|
|
|
bool ocean;
|
|
|
|
|
|
|
|
MapTreeBounds() {
|
|
|
|
ocean = -1;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2012-06-13 19:54:50 +02:00
|
|
|
struct RouteSubregion {
|
2012-06-15 14:34:25 +02:00
|
|
|
uint32_t length;
|
|
|
|
uint32_t filePointer;
|
|
|
|
uint32_t mapDataBlock;
|
|
|
|
uint32_t left;
|
|
|
|
uint32_t right;
|
|
|
|
uint32_t top;
|
|
|
|
uint32_t bottom;
|
2012-06-13 19:54:50 +02:00
|
|
|
std::vector<RouteSubregion> subregions;
|
2012-06-14 20:52:03 +02:00
|
|
|
|
|
|
|
RouteSubregion() : length(0), filePointer(0), mapDataBlock(0){
|
|
|
|
}
|
2012-06-13 19:54:50 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2012-05-01 01:43:09 +02:00
|
|
|
struct MapRoot: MapTreeBounds {
|
|
|
|
int minZoom ;
|
|
|
|
int maxZoom ;
|
|
|
|
std::vector<MapTreeBounds> bounds;
|
|
|
|
};
|
|
|
|
|
2012-05-02 01:40:36 +02:00
|
|
|
enum PART_INDEXES {
|
|
|
|
MAP_INDEX = 1,
|
|
|
|
POI_INDEX,
|
|
|
|
ADDRESS_INDEX,
|
|
|
|
TRANSPORT_INDEX,
|
|
|
|
ROUTING_INDEX,
|
|
|
|
};
|
2012-05-01 01:43:09 +02:00
|
|
|
|
2012-05-02 01:40:36 +02:00
|
|
|
struct BinaryPartIndex {
|
2012-06-15 14:34:25 +02:00
|
|
|
uint32_t length;
|
2012-05-01 01:43:09 +02:00
|
|
|
int filePointer;
|
2012-05-02 01:40:36 +02:00
|
|
|
PART_INDEXES type;
|
2012-05-01 01:43:09 +02:00
|
|
|
std::string name;
|
2012-05-02 01:40:36 +02:00
|
|
|
|
|
|
|
BinaryPartIndex(PART_INDEXES tp) : type(tp) {}
|
|
|
|
};
|
|
|
|
|
2012-06-13 19:54:50 +02:00
|
|
|
struct RoutingIndex : BinaryPartIndex {
|
2012-06-15 14:34:25 +02:00
|
|
|
UNORDERED(map)< int, tag_value > decodingRules;
|
2012-06-13 19:54:50 +02:00
|
|
|
std::vector<RouteSubregion> subregions;
|
|
|
|
RoutingIndex() : BinaryPartIndex(ROUTING_INDEX) {
|
|
|
|
}
|
|
|
|
|
2012-06-15 14:34:25 +02:00
|
|
|
void initRouteEncodingRule(uint32_t id, std::string tag, std::string val) {
|
2012-06-13 19:54:50 +02:00
|
|
|
tag_value pair = tag_value(tag, val);
|
|
|
|
// DEFINE hash
|
|
|
|
//encodingRules[pair] = id;
|
|
|
|
decodingRules[id] = pair;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct RouteDataObject {
|
|
|
|
RoutingIndex* region;
|
2012-06-15 14:34:25 +02:00
|
|
|
std::vector<uint32_t> types ;
|
|
|
|
std::vector<uint32_t> pointsX ;
|
|
|
|
std::vector<uint32_t> pointsY ;
|
|
|
|
std::vector<uint64_t> restrictions ;
|
|
|
|
std::vector<std::vector<uint32_t> > pointTypes;
|
|
|
|
int64_t id;
|
2012-06-13 19:54:50 +02:00
|
|
|
};
|
|
|
|
|
2012-05-02 01:40:36 +02:00
|
|
|
|
|
|
|
|
|
|
|
struct MapIndex : BinaryPartIndex {
|
|
|
|
|
2012-05-01 01:43:09 +02:00
|
|
|
std::vector<MapRoot> levels;
|
|
|
|
|
2012-06-15 14:34:25 +02:00
|
|
|
UNORDERED(map)<int, tag_value > decodingRules;
|
2012-05-01 01:43:09 +02:00
|
|
|
// DEFINE hash
|
2012-06-15 14:34:25 +02:00
|
|
|
//UNORDERED(map)<tag_value, int> encodingRules;
|
2012-05-01 01:43:09 +02:00
|
|
|
|
|
|
|
int nameEncodingType;
|
|
|
|
int refEncodingType;
|
|
|
|
int coastlineEncodingType;
|
|
|
|
int coastlineBrokenEncodingType;
|
|
|
|
int landEncodingType;
|
|
|
|
int onewayAttribute ;
|
|
|
|
int onewayReverseAttribute ;
|
2012-06-15 14:34:25 +02:00
|
|
|
UNORDERED(set)< int > positiveLayers;
|
|
|
|
UNORDERED(set)< int > negativeLayers;
|
2012-05-01 01:43:09 +02:00
|
|
|
|
2012-05-02 01:40:36 +02:00
|
|
|
MapIndex() : BinaryPartIndex(MAP_INDEX) {
|
2012-05-01 01:43:09 +02:00
|
|
|
nameEncodingType = refEncodingType = coastlineBrokenEncodingType = coastlineEncodingType = -1;
|
|
|
|
landEncodingType = onewayAttribute = onewayReverseAttribute = -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void finishInitializingTags() {
|
|
|
|
int free = decodingRules.size() * 2 + 1;
|
|
|
|
coastlineBrokenEncodingType = free++;
|
|
|
|
initMapEncodingRule(0, coastlineBrokenEncodingType, "natural", "coastline_broken");
|
|
|
|
if (landEncodingType == -1) {
|
|
|
|
landEncodingType = free++;
|
|
|
|
initMapEncodingRule(0, landEncodingType, "natural", "land");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-15 14:34:25 +02:00
|
|
|
void initMapEncodingRule(uint32_t type, uint32_t id, std::string tag, std::string val) {
|
2012-05-01 01:43:09 +02:00
|
|
|
tag_value pair = tag_value(tag, val);
|
|
|
|
// DEFINE hash
|
|
|
|
//encodingRules[pair] = id;
|
|
|
|
decodingRules[id] = pair;
|
|
|
|
|
|
|
|
if ("name" == tag) {
|
|
|
|
nameEncodingType = id;
|
|
|
|
} else if ("natural" == tag && "coastline" == val) {
|
|
|
|
coastlineEncodingType = id;
|
|
|
|
} else if ("natural" == tag && "land" == val) {
|
|
|
|
landEncodingType = id;
|
|
|
|
} else if ("oneway" == tag && "yes" == val) {
|
|
|
|
onewayAttribute = id;
|
|
|
|
} else if ("oneway" == tag && "-1" == val) {
|
|
|
|
onewayReverseAttribute = id;
|
|
|
|
} else if ("ref" == tag) {
|
|
|
|
refEncodingType = id;
|
|
|
|
} else if ("layer" == tag) {
|
|
|
|
if (val != "" && val != "0") {
|
|
|
|
if (val[0] == '-') {
|
|
|
|
negativeLayers.insert(id);
|
|
|
|
} else {
|
|
|
|
positiveLayers.insert(id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
struct BinaryMapFile {
|
|
|
|
std::string inputName;
|
2012-06-15 14:34:25 +02:00
|
|
|
uint32_t version;
|
|
|
|
uint64_t dateCreated;
|
2012-05-01 01:43:09 +02:00
|
|
|
std::vector<MapIndex> mapIndexes;
|
2012-06-13 19:54:50 +02:00
|
|
|
std::vector<RoutingIndex> routingIndexes;
|
2012-05-02 01:40:36 +02:00
|
|
|
std::vector<BinaryPartIndex*> indexes;
|
2012-06-15 14:34:25 +02:00
|
|
|
int fd;
|
2012-06-19 18:20:32 +02:00
|
|
|
int routefd;
|
2012-05-01 01:43:09 +02:00
|
|
|
bool basemap;
|
|
|
|
|
|
|
|
bool isBasemap(){
|
|
|
|
return basemap;
|
|
|
|
}
|
|
|
|
|
|
|
|
~BinaryMapFile() {
|
2012-06-15 14:34:25 +02:00
|
|
|
close(fd);
|
2012-06-19 19:13:34 +02:00
|
|
|
close(routefd);
|
2012-05-01 01:43:09 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2012-05-02 19:35:36 +02:00
|
|
|
struct ResultPublisher {
|
|
|
|
std::vector< MapDataObject*> result;
|
|
|
|
|
|
|
|
bool publish(MapDataObject* r) {
|
|
|
|
result.push_back(r);
|
|
|
|
return true;
|
|
|
|
}
|
2012-05-04 13:13:00 +02:00
|
|
|
bool publish(std::vector<MapDataObject*> r) {
|
|
|
|
result.insert(result.begin(), r.begin(), r.end());
|
|
|
|
return true;
|
|
|
|
}
|
2012-05-02 19:35:36 +02:00
|
|
|
bool isCancelled() {
|
|
|
|
return false;
|
|
|
|
}
|
2012-05-04 13:13:00 +02:00
|
|
|
virtual ~ResultPublisher() {
|
|
|
|
deleteObjects(result);
|
|
|
|
}
|
2012-05-02 19:35:36 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct SearchQuery {
|
|
|
|
RenderingRuleSearchRequest* req;
|
|
|
|
int left;
|
|
|
|
int right;
|
|
|
|
int top;
|
|
|
|
int bottom;
|
|
|
|
int zoom;
|
2012-05-04 13:13:00 +02:00
|
|
|
ResultPublisher* publisher;
|
2012-05-02 19:35:36 +02:00
|
|
|
|
|
|
|
coordinates cacheCoordinates;
|
|
|
|
bool ocean;
|
|
|
|
bool land;
|
|
|
|
|
|
|
|
int numberOfVisitedObjects;
|
|
|
|
int numberOfAcceptedObjects;
|
|
|
|
int numberOfReadSubtrees;
|
|
|
|
int numberOfAcceptedSubtrees;
|
|
|
|
|
2012-05-04 13:13:00 +02:00
|
|
|
SearchQuery(int l, int r, int t, int b, RenderingRuleSearchRequest* req, ResultPublisher* publisher) :
|
|
|
|
req(req), left(l), right(r), top(t), bottom(b),publisher(publisher) {
|
2012-05-02 19:35:36 +02:00
|
|
|
numberOfAcceptedObjects = numberOfVisitedObjects = 0;
|
|
|
|
numberOfAcceptedSubtrees = numberOfReadSubtrees = 0;
|
|
|
|
ocean = land = false;
|
|
|
|
}
|
2012-06-14 20:52:03 +02:00
|
|
|
SearchQuery(int l, int r, int t, int b) :
|
|
|
|
req(req), left(l), right(r), top(t), bottom(b) {
|
2012-06-13 19:54:50 +02:00
|
|
|
}
|
2012-05-02 19:35:36 +02:00
|
|
|
|
2012-05-04 13:13:00 +02:00
|
|
|
bool publish(MapDataObject* obj) {
|
|
|
|
return publisher->publish(obj);
|
2012-05-02 19:35:36 +02:00
|
|
|
}
|
|
|
|
};
|
2012-05-01 20:49:45 +02:00
|
|
|
|
2012-06-14 20:52:03 +02:00
|
|
|
void searchRouteRegion(SearchQuery* q, std::vector<RouteDataObject*>& list, RoutingIndex* rs = NULL);
|
2012-05-01 01:43:09 +02:00
|
|
|
|
2012-05-08 00:50:47 +02:00
|
|
|
ResultPublisher* searchObjectsForRendering(SearchQuery* q, bool skipDuplicates, std::string msgNothingFound);
|
2012-05-01 20:49:45 +02:00
|
|
|
|
2012-05-01 09:47:20 +02:00
|
|
|
BinaryMapFile* initBinaryMapFile(std::string inputName);
|
2012-05-01 01:43:09 +02:00
|
|
|
|
2012-05-02 19:35:36 +02:00
|
|
|
bool closeBinaryMapFile(std::string inputName);
|
|
|
|
|
2012-05-01 01:43:09 +02:00
|
|
|
#endif
|