X-Git-Url: https://git.street.me.uk/andy/viking.git/blobdiff_plain/3346da3197777f491600afc798e79cfc20d8290e..67c55ccf956ca89d35feec1c582febdd83fb88b2:/src/osm.c?ds=sidebyside diff --git a/src/osm.c b/src/osm.c index cff5c39a..f5f28f31 100644 --- a/src/osm.c +++ b/src/osm.c @@ -2,8 +2,8 @@ * viking -- GPS Data and Topo Analyzer, Explorer, and Manager * * Copyright (C) 2003-2005, Evan Battaglia - * Copyright (C) 2007, Guilhem Bonnefille - * Copyright (c) 2012, Rob Norris + * Copyright (C) 2007,2013, Guilhem Bonnefille + * Copyright (c) 2012-2014, Rob Norris * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -32,9 +32,14 @@ #include "vikwmscmapsource.h" #include "vikwebtoolcenter.h" #include "vikwebtoolbounds.h" +#include "vikwebtoolformat.h" +#include "vikwebtool_datasource.h" #include "vikexttools.h" +#include "vikexttool_datasources.h" #include "vikgotoxmltool.h" #include "vikgoto.h" +#include "vikrouting.h" +#include "vikroutingwebengine.h" /* initialisation */ void osm_init () { @@ -42,10 +47,13 @@ void osm_init () { VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE, "id", 13, "label", "OpenStreetMap (Mapnik)", + "name", "OSM-Mapnik", "hostname", "tile.openstreetmap.org", "url", "/%d/%d/%d.png", "check-file-server-time", FALSE, "use-etag", TRUE, + "zoom-min", 0, + "zoom-max", 19, "copyright", "© OpenStreetMap contributors", "license", "CC-BY-SA", "license-url", "http://www.openstreetmap.org/copyright", @@ -54,10 +62,13 @@ void osm_init () { VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE, "id", 17, "label", "OpenStreetMap (Cycle)", - "hostname", "b.tile.opencyclemap.org", + "name", "OSM-Cycle", + "hostname", "tile.opencyclemap.org", "url", "/cycle/%d/%d/%d.png", "check-file-server-time", TRUE, "use-etag", FALSE, + "zoom-min", 0, + "zoom-max", 18, "copyright", "Tiles courtesy of Andy Allan © OpenStreetMap contributors", "license", "CC-BY-SA", "license-url", "http://www.openstreetmap.org/copyright", @@ -66,38 +77,47 @@ void osm_init () { VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE, "id", 20, "label", "OpenStreetMap (Transport)", - "hostname", "c.tile2.opencyclemap.org", + "name", "OSM-Transport", + "hostname", "tile2.opencyclemap.org", "url", "/transport/%d/%d/%d.png", "check-file-server-time", TRUE, "use-etag", FALSE, + "zoom-min", 0, + "zoom-max", 18, "copyright", "Tiles courtesy of Andy Allan © OpenStreetMap contributors", "license", "CC-BY-SA", "license-url", "http://www.openstreetmap.org/copyright", NULL)); - VikMapSource *wms_type = - VIK_MAP_SOURCE(g_object_new(VIK_TYPE_WMSC_MAP_SOURCE, - "id", 18, - "label", "OpenStreetMap (WMS)", - "hostname", "full.wms.geofabrik.de", - "url", "/std/demo_key?LAYERS=osm-full&FORMAT=image/png&SERVICE=WMS&VERSION=1.1.1&REQUEST=GetMap&STYLES=&EXCEPTIONS=&SRS=EPSG:4326&BBOX=%s,%s,%s,%s&WIDTH=256&HEIGHT=256", - "check-file-server-time", FALSE, - "copyright", "© OpenStreetMap contributors", - "license", "CC-BY-SA", - "license-url", "http://www.openstreetmap.org/copyright", - NULL)); - VikMapSource *mapquest_type = VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE, "id", 19, + "name", "OSM-MapQuest", "label", "OpenStreetMap (MapQuest)", "hostname", "otile1.mqcdn.com", "url", "/tiles/1.0.0/osm/%d/%d/%d.png", "check-file-server-time", TRUE, "use-etag", FALSE, + "zoom-min", 0, + "zoom-max", 19, "copyright", "Tiles Courtesy of MapQuest © OpenStreetMap contributors", "license", "MapQuest Specific", "license-url", "http://developer.mapquest.com/web/info/terms-of-use", NULL)); + VikMapSource *hot_type = + VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE, + "id", 22, + "name", "OSM-Humanitarian", + "label", "OpenStreetMap (Humanitarian)", + "hostname", "c.tile.openstreetmap.fr", + "url", "/hot/%d/%d/%d.png", + "check-file-server-time", TRUE, + "use-etag", FALSE, + "zoom-min", 0, + "zoom-max", 20, // Super detail!! + "copyright", "© OpenStreetMap contributors. Tiles courtesy of Humanitarian OpenStreetMap Team", + "license", "CC-BY-SA", + "license-url", "http://www.openstreetmap.org/copyright", + NULL)); // NB no cache needed for this type!! VikMapSource *direct_type = @@ -109,16 +129,40 @@ void osm_init () { "use-direct-file-access", TRUE, NULL)); + // NB no cache needed for this type!! + VikMapSource *mbtiles_type = + VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE, + "id", 23, + "label", _("MBTiles File"), + // For using your own generated data assumed you know the license already! + "copyright", "© OpenStreetMap contributors", // probably + "use-direct-file-access", TRUE, + "is-mbtiles", TRUE, + NULL)); + + // NB no cache needed for this type!! + VikMapSource *metatiles_type = + VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE, + "id", 24, + "label", _("OSM Metatiles"), + // For using your own generated data assumed you know the license already! + "copyright", "© OpenStreetMap contributors", // probably + "use-direct-file-access", TRUE, + "is-osm-meta-tiles", TRUE, + NULL)); + maps_layer_register_map_source (mapquest_type); maps_layer_register_map_source (mapnik_type); maps_layer_register_map_source (cycle_type); maps_layer_register_map_source (transport_type); - maps_layer_register_map_source (wms_type); + maps_layer_register_map_source (hot_type); maps_layer_register_map_source (direct_type); + maps_layer_register_map_source (mbtiles_type); + maps_layer_register_map_source (metatiles_type); // Webtools VikWebtoolCenter *webtool = NULL; - webtool = vik_webtool_center_new_with_members ( _("OSM (view)"), "http://openstreetmap.org/?lat=%s&lon=%s&zoom=%d&layers=B000FTF" ); + webtool = vik_webtool_center_new_with_members ( _("OSM (view)"), "http://openstreetmap.org/?lat=%s&lon=%s&zoom=%d" ); vik_ext_tools_register ( VIK_EXT_TOOL ( webtool ) ); g_object_unref ( webtool ); @@ -137,6 +181,19 @@ void osm_init () { vik_ext_tools_register ( VIK_EXT_TOOL ( webtoolbounds ) ); g_object_unref ( webtoolbounds ); + VikWebtoolFormat *vwtf = NULL; + vwtf = vik_webtool_format_new_with_members ( _("Geofabrik Map Compare"), + "http://tools.geofabrik.de/mc/#%s/%s/%s", + "ZAO" ); + vik_ext_tools_register ( VIK_EXT_TOOL ( vwtf ) ); + g_object_unref ( vwtf ); + + // Datasource + VikWebtoolDatasource *vwtds = NULL; + vwtds = vik_webtool_datasource_new_with_members ( _("OpenStreetMap Notes"), "http://api.openstreetmap.org/api/0.6/notes.gpx?bbox=%s,%s,%s,%s&closed=0", "LBRT", NULL, NULL, NULL ); + vik_ext_tool_datasources_register ( VIK_EXT_TOOL ( vwtds ) ); + g_object_unref ( vwtds ); + // Goto VikGotoXmlTool *nominatim = VIK_GOTO_XML_TOOL ( g_object_new ( VIK_GOTO_XML_TOOL_TYPE, "label", "OSM Nominatim", "url-format", "http://nominatim.openstreetmap.org/search?q=%s&format=xml", @@ -162,5 +219,18 @@ void osm_init () { webtool = vik_webtool_center_new_with_members ( _("Wikimedia Toolserver GeoHack"), "http://toolserver.org/~geohack/geohack.php?params=%s;%s" ); vik_ext_tools_register ( VIK_EXT_TOOL ( webtool ) ); g_object_unref ( webtool ); + + /* See API references: https://github.com/DennisOSRM/Project-OSRM/wiki/Server-api */ + VikRoutingEngine *osrm = g_object_new ( VIK_ROUTING_WEB_ENGINE_TYPE, + "id", "osrm", + "label", "OSRM", + "format", "gpx", + "url-base", "http://router.project-osrm.org/viaroute?output=gpx", + "url-start-ll", "&loc=%s,%s", + "url-stop-ll", "&loc=%s,%s", + "url-via-ll", "&loc=%s,%s", + NULL); + vik_routing_register ( VIK_ROUTING_ENGINE ( osrm ) ); + g_object_unref ( osrm ); }