/* -*- Mode: C; indent-tabs-mode: t; c-basic-offset: 4; tab-width: 4 -*- */ /* * viking * Copyright (C) 2009-2010, Guilhem Bonnefille * * viking is free software: you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * viking is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * with this program. If not, see . */ /** * SECTION:vikmapsource * @short_description: the base class to describe map source * * The #VikMapSource class is both the interface and the base class * for the hierarchie of map source. */ #ifdef HAVE_CONFIG_H #include "config.h" #endif #include "vikviewport.h" #include "vikcoord.h" #include "mapcoord.h" #include "download.h" #include "vikmapsource.h" static void vik_map_source_init (VikMapSource *object); static void vik_map_source_finalize (GObject *object); static void vik_map_source_class_init (VikMapSourceClass *klass); static gboolean _supports_download_only_new (VikMapSource *object); G_DEFINE_ABSTRACT_TYPE (VikMapSource, vik_map_source, G_TYPE_OBJECT); static void vik_map_source_init (VikMapSource *object) { /* TODO: Add initialization code here */ } static void vik_map_source_finalize (GObject *object) { /* TODO: Add deinitalization code here */ G_OBJECT_CLASS (vik_map_source_parent_class)->finalize (object); } static void vik_map_source_class_init (VikMapSourceClass *klass) { GObjectClass* object_class = G_OBJECT_CLASS (klass); klass->get_copyright = NULL; klass->get_license = NULL; klass->get_license_url = NULL; klass->get_logo = NULL; klass->get_name = NULL; klass->get_uniq_id = NULL; klass->get_label = NULL; klass->get_tilesize_x = NULL; klass->get_tilesize_y = NULL; klass->get_scale = NULL; klass->get_drawmode = NULL; klass->is_direct_file_access = NULL; klass->is_mbtiles = NULL; klass->supports_download_only_new = _supports_download_only_new; klass->get_zoom_min = NULL; klass->get_zoom_max = NULL; klass->get_lat_min = NULL; klass->get_lat_max = NULL; klass->get_lon_min = NULL; klass->get_lon_max = NULL; klass->get_offset_x = NULL; klass->get_offset_y = NULL; klass->coord_to_mapcoord = NULL; klass->mapcoord_to_center_coord = NULL; klass->download = NULL; klass->download_handle_init = NULL; klass->download_handle_cleanup = NULL; object_class->finalize = vik_map_source_finalize; } gboolean _supports_download_only_new (VikMapSource *self) { // Default feature: does not support return FALSE; } /** * vik_map_source_get_copyright: * @self: the VikMapSource of interest. * @bbox: bounding box of interest. * @zoom: the zoom level of interest. * @fct: the callback function to use to return matching copyrights. * @data: the user data to use to call the callbaack function. * * Retrieve copyright(s) for the corresponding bounding box and zoom level. */ void vik_map_source_get_copyright (VikMapSource *self, LatLonBBox bbox, gdouble zoom, void (*fct)(VikViewport*,const gchar*), void *data) { VikMapSourceClass *klass; g_return_if_fail (self != NULL); g_return_if_fail (VIK_IS_MAP_SOURCE (self)); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_if_fail (klass->get_copyright != NULL); (*klass->get_copyright)(self, bbox, zoom, fct, data); } const gchar * vik_map_source_get_license (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, NULL); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), NULL); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_license != NULL, NULL); return (*klass->get_license)(self); } const gchar * vik_map_source_get_license_url (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, NULL); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), NULL); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_license_url != NULL, NULL); return (*klass->get_license_url)(self); } const GdkPixbuf * vik_map_source_get_logo (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, NULL); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), NULL); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_logo != NULL, NULL); return (*klass->get_logo)(self); } const gchar * vik_map_source_get_name (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, NULL); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), NULL); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_name != NULL, NULL); return (*klass->get_name)(self); } guint16 vik_map_source_get_uniq_id (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, (guint16 )0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), (guint16 )0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_uniq_id != NULL, (guint16 )0); return (*klass->get_uniq_id)(self); } const gchar * vik_map_source_get_label (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, NULL); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), NULL); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_label != NULL, NULL); return (*klass->get_label)(self); } guint16 vik_map_source_get_tilesize_x (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, (guint16 )0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), (guint16 )0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_tilesize_x != NULL, (guint16 )0); return (*klass->get_tilesize_x)(self); } guint16 vik_map_source_get_tilesize_y (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, (guint16 )0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), (guint16 )0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_tilesize_y != NULL, (guint16 )0); return (*klass->get_tilesize_y)(self); } gdouble vik_map_source_get_scale (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, (gdouble)1.0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), (gdouble)1.0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_scale != NULL, (gdouble)1.0); return (*klass->get_scale)(self); } VikViewportDrawMode vik_map_source_get_drawmode (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, (VikViewportDrawMode )0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), (VikViewportDrawMode )0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_drawmode != NULL, (VikViewportDrawMode )0); return (*klass->get_drawmode)(self); } /** * vik_map_source_is_direct_file_access: * @self: the VikMapSource of interest. * * Return true when we can bypass all this download malarky * Treat the files as a pre generated data set in OSM tile server layout: tiledir/%d/%d/%d.png */ gboolean vik_map_source_is_direct_file_access (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, FALSE); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), FALSE); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->is_direct_file_access != NULL, FALSE); return (*klass->is_direct_file_access)(self); } /** * vik_map_source_is_mbtiles: * @self: the VikMapSource of interest. * * Return true when the map is in an MB Tiles format. * See http://github.com/mapbox/mbtiles-spec * (Read Only ATM) */ gboolean vik_map_source_is_mbtiles (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, FALSE); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), FALSE); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->is_mbtiles != NULL, FALSE); return (*klass->is_mbtiles)(self); } /** * vik_map_source_is_osm_meta_tiles: * @self: the VikMapSource of interest. * * Treat the files as a pre generated data set directly by tirex or renderd * tiledir/Z/[xxxxyyyy]/[xxxxyyyy]/[xxxxyyyy]/[xxxxyyyy]/[xxxxyyyy].meta */ gboolean vik_map_source_is_osm_meta_tiles (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, FALSE); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), FALSE); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->is_osm_meta_tiles != NULL, FALSE); return (*klass->is_osm_meta_tiles)(self); } gboolean vik_map_source_supports_download_only_new (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, FALSE); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), FALSE); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->supports_download_only_new != NULL, FALSE); return (*klass->supports_download_only_new)(self); } /** * */ guint8 vik_map_source_get_zoom_min (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, 0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), 0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_zoom_min != NULL, 0); return (*klass->get_zoom_min)(self); } /** * */ guint8 vik_map_source_get_zoom_max (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, 18); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), 18); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_zoom_max != NULL, 18); return (*klass->get_zoom_max)(self); } /** * */ gdouble vik_map_source_get_lat_max (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, 90.0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), 90.0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_lat_max != NULL, 90.0); return (*klass->get_lat_max)(self); } /** * */ gdouble vik_map_source_get_lat_min (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, -90.0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), -90.0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_lat_min != NULL, -90.0); return (*klass->get_lat_min)(self); } /** * */ gdouble vik_map_source_get_lon_max (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, 180.0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), 180.0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_lon_max != NULL, 180.0); return (*klass->get_lon_max)(self); } /** * */ gdouble vik_map_source_get_lon_min (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, -180.0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), -180.0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_lon_min != NULL, -180.0); return (*klass->get_lon_min)(self); } /** * vik_map_source_get_file_extension: * @self: the VikMapSource of interest. * * Returns the file extension of files held on disk. * Typically .png but may be .jpg or whatever the user defines * */ const gchar * vik_map_source_get_file_extension (VikMapSource * self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, NULL); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), NULL); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_file_extension != NULL, NULL); return (*klass->get_file_extension)(self); } gdouble vik_map_source_get_offset_x (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, (gdouble)0.0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), (gdouble)0.0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_offset_x != NULL, (gdouble)0.0); return (*klass->get_offset_x)(self); } gdouble vik_map_source_get_offset_y (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, (gdouble)0.0); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), (gdouble)0.0); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->get_offset_y != NULL, (gdouble)0.0); return (*klass->get_offset_y)(self); } gboolean vik_map_source_coord_to_mapcoord (VikMapSource *self, const VikCoord *src, gdouble xzoom, gdouble yzoom, MapCoord *dest ) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, FALSE); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), FALSE); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->coord_to_mapcoord != NULL, FALSE); return (*klass->coord_to_mapcoord)(self, src, xzoom, yzoom, dest); } void vik_map_source_mapcoord_to_center_coord (VikMapSource *self, MapCoord *src, VikCoord *dest) { VikMapSourceClass *klass; g_return_if_fail (self != NULL); g_return_if_fail (VIK_IS_MAP_SOURCE (self)); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_if_fail (klass->mapcoord_to_center_coord != NULL); (*klass->mapcoord_to_center_coord)(self, src, dest); } /** * vik_map_source_download: * @self: The VikMapSource of interest. * @src: The map location to download * @dest_fn: The filename to save the result in * @handle: Potential reusable Curl Handle (may be NULL) * * Returns: How successful the download was as per the type #DownloadResult_t */ DownloadResult_t vik_map_source_download (VikMapSource * self, MapCoord * src, const gchar * dest_fn, void *handle) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, DOWNLOAD_PARAMETERS_ERROR); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), DOWNLOAD_PARAMETERS_ERROR); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->download != NULL, DOWNLOAD_PARAMETERS_ERROR); return (*klass->download)(self, src, dest_fn, handle); } void * vik_map_source_download_handle_init (VikMapSource *self) { VikMapSourceClass *klass; g_return_val_if_fail (self != NULL, NULL); g_return_val_if_fail (VIK_IS_MAP_SOURCE (self), NULL); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_val_if_fail (klass->download_handle_init != NULL, NULL); return (*klass->download_handle_init)(self); } void vik_map_source_download_handle_cleanup (VikMapSource * self, void * handle) { VikMapSourceClass *klass; g_return_if_fail (self != NULL); g_return_if_fail (VIK_IS_MAP_SOURCE (self)); klass = VIK_MAP_SOURCE_GET_CLASS(self); g_return_if_fail (klass->download_handle_cleanup != NULL); (*klass->download_handle_cleanup)(self, handle); }