summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Dirk Hohndel <dirk@hohndel.org>2013-01-20 20:23:50 -0800
committerGravatar Dirk Hohndel <dirk@hohndel.org>2013-01-20 20:26:15 -0800
commit97ce7a37634dd21fb68479951b17d8d3b7383f8f (patch)
treec34348080d8a26dd987522188ad0ce85830458a4
parent3d248682eef1a200d5d992ca1a00abe810ca1a29 (diff)
downloadsubsurface-97ce7a37634dd21fb68479951b17d8d3b7383f8f.tar.gz
Fix map scrolling
The osm-gps-map default is to scroll-and-recenter around the mouse position. That is BAT SHIT CRAZY. So this implements our own scroll handling instead. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--gps.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/gps.c b/gps.c
index 0d7a666a9..aff21d4cd 100644
--- a/gps.c
+++ b/gps.c
@@ -24,6 +24,20 @@ static void on_close (GtkWidget *widget, gpointer user_data)
*window = NULL;
}
+/* the osm gps map default is to scroll-and-recenter around the mouse position
+ * that is BAT SHIT CRAZY.
+ * So let's do our own scroll handling instead */
+static gboolean scroll_cb(GtkWidget *widget, GdkEventScroll *event, gpointer data)
+{
+ OsmGpsMap *map = (OsmGpsMap *)widget;
+ if (event->direction == GDK_SCROLL_UP)
+ osm_gps_map_zoom_in(map);
+ else if (event->direction == GDK_SCROLL_DOWN)
+ osm_gps_map_zoom_out(map);
+ /* don't allow the insane default handler to get its hands on this event */
+ return TRUE;
+}
+
static void add_gps_point(OsmGpsMap *map, float latitude, float longitude)
{
OsmGpsMapTrack * track = osm_gps_map_track_new ();
@@ -82,6 +96,7 @@ void show_map(OsmGpsMap *map, GtkWidget **window)
GTK_WINDOW(*window)->allow_shrink = TRUE;
gtk_container_add(GTK_CONTAINER (*window), GTK_WIDGET(map));
g_signal_connect(*window, "destroy", G_CALLBACK (on_close), (gpointer)window);
+ g_signal_connect(G_OBJECT(map), "scroll-event", G_CALLBACK(scroll_cb), NULL);
}
gtk_widget_show_all(*window);
gtk_window_present(GTK_WINDOW(*window));