* viking -- GPS Data and Topo Analyzer, Explorer, and Manager
*
* Copyright (C) 2003-2005, Evan Battaglia <gtoevan@gmx.net>
- * Copyright (C) 2007, Guilhem Bonnefille <guilhem.bonnefille@gmail.com>
- * Copyright (c) 2012, Rob Norris <rw_norris@hotmail.com>
+ * Copyright (C) 2007,2013, Guilhem Bonnefille <guilhem.bonnefille@gmail.com>
+ * Copyright (c) 2012-2014, Rob Norris <rw_norris@hotmail.com>
*
* 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
#include <glib/gi18n.h>
#include "osm.h"
+#include "map_ids.h"
#include "vikmapslayer.h"
#include "vikslippymapsource.h"
#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 () {
VikMapSource *mapnik_type =
VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE,
- "id", 13,
- "label", "OpenStreetMap (Mapnik)",
+ "id", MAP_ID_OSM_MAPNIK,
+ "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",
NULL));
VikMapSource *cycle_type =
VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE,
- "id", 17,
- "label", "OpenStreetMap (Cycle)",
- "hostname", "b.tile.opencyclemap.org",
- "url", "/cycle/%d/%d/%d.png",
+ "id", MAP_ID_OSM_CYCLE,
+ "label", _("OpenStreetMap (Cycle)"),
+ "name", "OSM-Cycle",
+ "url", "https://tile.thunderforest.com/cycle/%d/%d/%d.png?apikey="VIK_CONFIG_THUNDERFOREST_KEY,
"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 *transport_type =
VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE,
- "id", 20,
- "label", "OpenStreetMap (Transport)",
- "hostname", "c.tile2.opencyclemap.org",
+ "id", MAP_ID_OSM_TRANSPORT,
+ "label", _("OpenStreetMap (Transport)"),
+ "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 =
+ VikMapSource *hot_type =
VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE,
- "id", 19,
- "label", "OpenStreetMap (MapQuest)",
- "hostname", "otile1.mqcdn.com",
- "url", "/tiles/1.0.0/osm/%d/%d/%d.png",
+ "id", MAP_ID_OSM_HUMANITARIAN,
+ "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,
- "copyright", "Tiles Courtesy of MapQuest © OpenStreetMap contributors",
- "license", "MapQuest Specific",
- "license-url", "http://developer.mapquest.com/web/info/terms-of-use",
+ "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 =
VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE,
- "id", 21,
+ "id", MAP_ID_OSM_ON_DISK,
"label", _("On Disk OSM Tile Format"),
// For using your own generated data assumed you know the license already!
"copyright", "© OpenStreetMap contributors", // probably
"use-direct-file-access", TRUE,
NULL));
- maps_layer_register_map_source (mapquest_type);
+ // NB no cache needed for this type!!
+ VikMapSource *mbtiles_type =
+ VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE,
+ "id", MAP_ID_MBTILES,
+ "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", MAP_ID_OSM_METATILES,
+ "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));
+
+ // Note using a registered token for the Mapbox Tileservice
+ // Thus not only will the (free) service allocation limit be reached by normal users
+ // but by anymore who cares to read these sources and use the default themselves.
+ VikMapSource *mapbox_type =
+ VIK_MAP_SOURCE(g_object_new(VIK_TYPE_SLIPPY_MAP_SOURCE,
+ "id", MAP_ID_MAPBOX_OUTDOORS,
+ "name", "Mapbox-Outdoors",
+ "label", _("Mapbox Outdoors"),
+ "url", "https://api.tiles.mapbox.com/styles/v1/mapbox/outdoors-v9/tiles/256/%d/%d/%d?access_token="VIK_CONFIG_MAPBOX_TOKEN,
+ "check-file-server-time", TRUE,
+ "use-etag", FALSE,
+ "zoom-min", 0,
+ "zoom-max", 19,
+ "copyright", "© Mapbox © OpenStreetMap",
+ "license", _("Mapbox Specific"),
+ "license-url", "https://www.mapbox.com/tos",
+ NULL));
+
+ // NB The first registered map source is the default
+ // (unless the user has specified Map Layer defaults)
+ maps_layer_register_map_source (mapbox_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://www.openstreetmap.org/?lat=%s&lon=%s&zoom=%d" );
vik_ext_tools_register ( VIK_EXT_TOOL ( webtool ) );
g_object_unref ( webtool );
vik_ext_tools_register ( VIK_EXT_TOOL ( webtool ) );
g_object_unref ( webtool );
+ // Note the use of positional parameters
+ webtool = vik_webtool_center_new_with_members ( _("OSM (query)"), "http://www.openstreetmap.org/query?lat=%1$s&lon=%2$s#map=%3$d/%1$s/%2$s" );
+ vik_ext_tools_register ( VIK_EXT_TOOL ( webtool ) );
+ g_object_unref ( webtool );
+
webtool = vik_webtool_center_new_with_members ( _("OSM (render)"), "http://www.informationfreeway.org/?lat=%s&lon=%s&zoom=%d&layers=B0000F000F" );
vik_ext_tools_register ( VIK_EXT_TOOL ( webtool ) );
g_object_unref ( webtool );
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",
NULL ) );
vik_goto_register ( VIK_GOTO_TOOL ( namefinder ) );
g_object_unref ( namefinder );
+
+ // Not really OSM but can't be bothered to create somewhere else to put it...
+ webtool = vik_webtool_center_new_with_members ( _("Wikimedia Toolserver GeoHack"), "http://tools.wmflabs.org/geohack/geohack.php?params=%s;%s" );
+ vik_ext_tools_register ( VIK_EXT_TOOL ( webtool ) );
+ g_object_unref ( webtool );
}