diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2013-01-20 20:23:50 -0800 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-01-20 20:26:15 -0800 |
commit | 97ce7a37634dd21fb68479951b17d8d3b7383f8f (patch) | |
tree | c34348080d8a26dd987522188ad0ce85830458a4 | |
parent | 3d248682eef1a200d5d992ca1a00abe810ca1a29 (diff) | |
download | subsurface-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.c | 15 |
1 files changed, 15 insertions, 0 deletions
@@ -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)); |