Diff of /trunk/src/osm-gps-map-osd-classic.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 136 by harbaum, Mon Oct 19 13:02:41 2009 UTC revision 143 by harbaum, Mon Oct 26 19:55:00 2009 UTC
# Line 135  typedef struct { Line 135  typedef struct {
135    
136  #define CLOSE_BUTTON_RADIUS   (BALLOON_CORNER_RADIUS)  #define CLOSE_BUTTON_RADIUS   (BALLOON_CORNER_RADIUS)
137    
138    #define FIN   printf("entering function %s\n", __func__);
139    #define FOUT  printf("leaving function %s\n", __func__);
140    
141  /* draw the bubble shape. this is used twice, once for the shape and once */  /* draw the bubble shape. this is used twice, once for the shape and once */
142  /* for the shadow */  /* for the shadow */
# Line 142  static void Line 144  static void
144  osm_gps_map_draw_balloon_shape (cairo_t *cr, int x0, int y0, int x1, int y1,  osm_gps_map_draw_balloon_shape (cairo_t *cr, int x0, int y0, int x1, int y1,
145         gboolean bottom, int px, int py, int px0, int px1) {         gboolean bottom, int px, int py, int px0, int px1) {
146    
147        FIN;
148    
149      cairo_move_to (cr, x0, y0 + BALLOON_CORNER_RADIUS);      cairo_move_to (cr, x0, y0 + BALLOON_CORNER_RADIUS);
150      cairo_arc (cr, x0 + BALLOON_CORNER_RADIUS, y0 + BALLOON_CORNER_RADIUS,      cairo_arc (cr, x0 + BALLOON_CORNER_RADIUS, y0 + BALLOON_CORNER_RADIUS,
151                 BALLOON_CORNER_RADIUS, -M_PI, -M_PI/2);                 BALLOON_CORNER_RADIUS, -M_PI, -M_PI/2);
# Line 170  osm_gps_map_draw_balloon_shape (cairo_t Line 174  osm_gps_map_draw_balloon_shape (cairo_t
174                 BALLOON_CORNER_RADIUS, M_PI/2, M_PI);                 BALLOON_CORNER_RADIUS, M_PI/2, M_PI);
175    
176      cairo_close_path (cr);      cairo_close_path (cr);
177    
178        FOUT;
179  }  }
180    
181  static void  static void
182  osd_render_balloon(osm_gps_map_osd_t *osd) {  osd_render_balloon(osm_gps_map_osd_t *osd) {
183        FIN;
184    
185      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
186    
187      /* get zoom */      /* get zoom */
# Line 284  osd_render_balloon(osm_gps_map_osd_t *os Line 292  osd_render_balloon(osm_gps_map_osd_t *os
292      }      }
293    
294      cairo_destroy(cr);      cairo_destroy(cr);
295    
296        FOUT;
297  }  }
298    
299  /* return true if balloon is being displayed and if */  /* return true if balloon is being displayed and if */
# Line 291  osd_render_balloon(osm_gps_map_osd_t *os Line 301  osd_render_balloon(osm_gps_map_osd_t *os
301  static gboolean  static gboolean
302  osd_balloon_check(osm_gps_map_osd_t *osd, gboolean click, gboolean down, gint x, gint y)  osd_balloon_check(osm_gps_map_osd_t *osd, gboolean click, gboolean down, gint x, gint y)
303  {  {
304        FIN;
305    
306      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
307    
308      if(!priv->balloon.surface)      if(!priv->balloon.surface)
# Line 340  osd_balloon_check(osm_gps_map_osd_t *osd Line 352  osd_balloon_check(osm_gps_map_osd_t *osd
352              priv->balloon.cb(&event, priv->balloon.data);              priv->balloon.cb(&event, priv->balloon.data);
353          }          }
354      }      }
355        FOUT;
356      return is_in;      return is_in;
357  }  }
358    
359  void osm_gps_map_osd_clear_balloon (OsmGpsMap *map) {  void osm_gps_map_osd_clear_balloon (OsmGpsMap *map) {
360        FIN;
361    
362      g_return_if_fail (OSM_IS_GPS_MAP (map));      g_return_if_fail (OSM_IS_GPS_MAP (map));
363    
364      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);
# Line 360  void osm_gps_map_osd_clear_balloon (OsmG Line 374  void osm_gps_map_osd_clear_balloon (OsmG
374          priv->balloon.lon = OSM_GPS_MAP_INVALID;          priv->balloon.lon = OSM_GPS_MAP_INVALID;
375      }      }
376      osm_gps_map_redraw(map);      osm_gps_map_redraw(map);
377        FOUT;
378  }  }
379    
380  void  void
381  osm_gps_map_osd_draw_balloon (OsmGpsMap *map, float latitude, float longitude,  osm_gps_map_osd_draw_balloon (OsmGpsMap *map, float latitude, float longitude,
382                                OsmGpsMapBalloonCallback cb, gpointer data) {                                OsmGpsMapBalloonCallback cb, gpointer data) {
383        FIN;
384      g_return_if_fail (OSM_IS_GPS_MAP (map));      g_return_if_fail (OSM_IS_GPS_MAP (map));
385    
386      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);
# Line 391  osm_gps_map_osd_draw_balloon (OsmGpsMap Line 407  osm_gps_map_osd_draw_balloon (OsmGpsMap
407      osd_render_balloon(osd);      osd_render_balloon(osd);
408    
409      osm_gps_map_redraw(map);      osm_gps_map_redraw(map);
410        FOUT;
411  }  }
412    
413  #endif // OSD_BALLOON  #endif // OSD_BALLOON
# Line 535  osd_shape(cairo_t *cr) { Line 552  osd_shape(cairo_t *cr) {
552  static gboolean  static gboolean
553  osm_gps_map_in_circle(gint x, gint y, gint cx, gint cy, gint rad)  osm_gps_map_in_circle(gint x, gint y, gint cx, gint cy, gint rad)
554  {  {
555        FIN;
556      return( pow(cx - x, 2) + pow(cy - y, 2) < rad * rad);      return( pow(cx - x, 2) + pow(cy - y, 2) < rad * rad);
557  }  }
558    
# Line 733  osd_source_content(osm_gps_map_osd_t *os Line 751  osd_source_content(osm_gps_map_osd_t *os
751    
752  static void  static void
753  osd_render_source_sel(osm_gps_map_osd_t *osd, gboolean force_rerender) {  osd_render_source_sel(osm_gps_map_osd_t *osd, gboolean force_rerender) {
754        FIN;
755    
756      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
757    
758      if(priv->source_sel.rendered && !force_rerender)      if(priv->source_sel.rendered && !force_rerender)
# Line 779  osd_render_source_sel(osm_gps_map_osd_t Line 799  osd_render_source_sel(osm_gps_map_osd_t
799      cairo_stroke (cr);      cairo_stroke (cr);
800    
801      cairo_destroy(cr);      cairo_destroy(cr);
802        FOUT;
803  }  }
804    
805  /* re-allocate the buffer used to draw the menu. This is used */  /* re-allocate the buffer used to draw the menu. This is used */
806  /* to collapse/expand the buffer */  /* to collapse/expand the buffer */
807  static void  static void
808  osd_source_reallocate(osm_gps_map_osd_t *osd) {  osd_source_reallocate(osm_gps_map_osd_t *osd) {
809        FIN;
810      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
811    
812      /* re-allocate offscreen bitmap */      /* re-allocate offscreen bitmap */
# Line 825  osd_source_reallocate(osm_gps_map_osd_t Line 847  osd_source_reallocate(osm_gps_map_osd_t
847          cairo_image_surface_create(CAIRO_FORMAT_ARGB32, w+2, h+2);          cairo_image_surface_create(CAIRO_FORMAT_ARGB32, w+2, h+2);
848    
849      osd_render_source_sel(osd, TRUE);      osd_render_source_sel(osd, TRUE);
850        FOUT;
851  }  }
852    
853  #define OSD_HZ      15  #define OSD_HZ      15
854  #define OSD_TIME    500  #define OSD_TIME    500
855    
856  static gboolean osd_source_animate(gpointer data) {  static gboolean osd_source_animate(gpointer data) {
857        FIN;
858      osm_gps_map_osd_t *osd = (osm_gps_map_osd_t*)data;      osm_gps_map_osd_t *osd = (osm_gps_map_osd_t*)data;
859      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
860      int diff = OSD_S_EXP_W - OSD_S_W - OSD_S_X;      int diff = OSD_S_EXP_W - OSD_S_W - OSD_S_X;
# Line 869  static gboolean osd_source_animate(gpoin Line 893  static gboolean osd_source_animate(gpoin
893      if(done)      if(done)
894          priv->source_sel.handler_id = 0;          priv->source_sel.handler_id = 0;
895    
896        FOUT;
897      return !done;      return !done;
898  }  }
899    
# Line 876  static gboolean osd_source_animate(gpoin Line 901  static gboolean osd_source_animate(gpoin
901  static void  static void
902  osd_source_toggle(osm_gps_map_osd_t *osd)  osd_source_toggle(osm_gps_map_osd_t *osd)
903  {  {
904        FIN;
905      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
906    
907      /* ignore clicks while animation is running */      /* ignore clicks while animation is running */
# Line 901  osd_source_toggle(osm_gps_map_osd_t *osd Line 927  osd_source_toggle(osm_gps_map_osd_t *osd
927      /* start timer to handle animation */      /* start timer to handle animation */
928      priv->source_sel.handler_id = gtk_timeout_add(OSD_TIME/OSD_HZ,      priv->source_sel.handler_id = gtk_timeout_add(OSD_TIME/OSD_HZ,
929                                                    osd_source_animate, osd);                                                    osd_source_animate, osd);
930        FOUT;
931  }  }
932    
933  /* check if the user clicked inside the source selection area */  /* check if the user clicked inside the source selection area */
934  static osd_button_t  static osd_button_t
935  osd_source_check(osm_gps_map_osd_t *osd, gboolean down, gint x, gint y) {  osd_source_check(osm_gps_map_osd_t *osd, gboolean down, gint x, gint y) {
936        FIN;
937      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
938    
939      if(!priv->source_sel.expanded)      if(!priv->source_sel.expanded)
# Line 963  osd_source_check(osm_gps_map_osd_t *osd, Line 991  osd_source_check(osm_gps_map_osd_t *osd,
991                      osm_gps_map_repaint(OSM_GPS_MAP(osd->widget));                      osm_gps_map_repaint(OSM_GPS_MAP(osd->widget));
992                  }                  }
993              }              }
994    
995              /* return "clicked in OSD background" to prevent further */              /* return "clicked in OSD background" to prevent further */
996              /* processing by application */              /* processing by application */
997              return OSD_BG;              return OSD_BG;
998          }          }
999      }      }
1000    
1001        FOUT;
1002      return OSD_NONE;      return OSD_NONE;
1003  }  }
1004  #endif // OSD_SOURCE_SEL  #endif // OSD_SOURCE_SEL
1005    
1006  static osd_button_t  static osd_button_t
1007  osd_check_int(osm_gps_map_osd_t *osd, gboolean click, gboolean down, gint x, gint y) {  osd_check_int(osm_gps_map_osd_t *osd, gboolean click, gboolean down, gint x, gint y) {
1008        FIN;
1009      osd_button_t but = OSD_NONE;      osd_button_t but = OSD_NONE;
1010    
1011  #ifdef OSD_BALLOON  #ifdef OSD_BALLOON
# Line 1021  osd_check_int(osm_gps_map_osd_t *osd, gb Line 1051  osd_check_int(osm_gps_map_osd_t *osd, gb
1051      }      }
1052  #endif  #endif
1053    
1054        FOUT;
1055      return but;      return but;
1056  }  }
1057    
# Line 1164  static char Line 1195  static char
1195  /* render a string at the given screen position */  /* render a string at the given screen position */
1196  static int  static int
1197  osd_render_centered_text(cairo_t *cr, int y, int width, char *text) {  osd_render_centered_text(cairo_t *cr, int y, int width, char *text) {
1198      char *p = g_strdup(text);      FIN;
1199    
1200        printf("params: %p %d %d %p\n", cr, y, width, text); // XXX
1201    
1202        if(!text) return y;
1203    
1204        printf("text given: %s\n", text); // XXX
1205    
1206        char *p = g_malloc(strlen(text)+4);  // space for "...\n"
1207        strcpy(p, text);
1208    
1209      cairo_text_extents_t extents;      cairo_text_extents_t extents;
1210      cairo_text_extents (cr, p, &extents);      cairo_text_extents (cr, p, &extents);
1211    
1212      /* check if text needs to be truncated */      /* check if text needs to be truncated */
1213      int len = strlen(text)-2;      int trunc_at = strlen(text)-1;
1214      while(extents.width > width) {      while(extents.width > width) {
1215          len--;          printf("trunc at %d\n", trunc_at);  // XXX
1216          strcpy(p+len, "...");  
1217            trunc_at--;
1218            strcpy(p+trunc_at, "...");
1219          cairo_text_extents (cr, p, &extents);          cairo_text_extents (cr, p, &extents);
1220      }      }
1221    
1222        printf("painting\n"); // XXX
1223    
1224      cairo_set_source_rgb(cr, 1.0, 1.0, 1.0);      cairo_set_source_rgb(cr, 1.0, 1.0, 1.0);
1225      cairo_set_line_width (cr, OSD_COORDINATES_FONT_SIZE/6);      cairo_set_line_width (cr, OSD_COORDINATES_FONT_SIZE/6);
1226      cairo_move_to (cr, (width - extents.width)/2, y - extents.y_bearing);      cairo_move_to (cr, (width - extents.width)/2, y - extents.y_bearing);
# Line 1188  osd_render_centered_text(cairo_t *cr, in Line 1233  osd_render_centered_text(cairo_t *cr, in
1233    
1234      g_free(p);      g_free(p);
1235    
1236      /* skip + 1/4 line */      /* skip + 1/5 line */
1237      return y + 5*OSD_COORDINATES_FONT_SIZE/4;      FOUT;
1238        return y + 6*OSD_COORDINATES_FONT_SIZE/5;
1239  }  }
1240    
1241  static void  static void
1242  osd_render_coordinates(osm_gps_map_osd_t *osd)  osd_render_coordinates(osm_gps_map_osd_t *osd)
1243  {  {
1244        FIN;
1245      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
1246    
1247      /* get current map position */      /* get current map position */
# Line 1235  osd_render_coordinates(osm_gps_map_osd_t Line 1282  osd_render_coordinates(osm_gps_map_osd_t
1282      g_free(longitude);      g_free(longitude);
1283    
1284      cairo_destroy(cr);      cairo_destroy(cr);
1285        FOUT;
1286  }  }
1287  #endif  // OSD_COORDINATES  #endif  // OSD_COORDINATES
1288    
# Line 1262  static float get_distance(float lat1, fl Line 1310  static float get_distance(float lat1, fl
1310  static void  static void
1311  osd_render_nav(osm_gps_map_osd_t *osd)  osd_render_nav(osm_gps_map_osd_t *osd)
1312  {  {
1313        FIN;
1314      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
1315    
1316      if(!priv->nav.surface || isnan(priv->nav.lat) || isnan(priv->nav.lon))      if(!priv->nav.surface || isnan(priv->nav.lat) || isnan(priv->nav.lon))
# Line 1366  osd_render_nav(osm_gps_map_osd_t *osd) Line 1415  osd_render_nav(osm_gps_map_osd_t *osd)
1415      }      }
1416    
1417      cairo_destroy(cr);      cairo_destroy(cr);
1418        FOUT;
1419  }  }
1420    
1421  void osm_gps_map_osd_clear_nav (OsmGpsMap *map) {  void osm_gps_map_osd_clear_nav (OsmGpsMap *map) {
1422        FIN;
1423      g_return_if_fail (OSM_IS_GPS_MAP (map));      g_return_if_fail (OSM_IS_GPS_MAP (map));
1424    
1425      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);
# Line 1385  void osm_gps_map_osd_clear_nav (OsmGpsMa Line 1436  void osm_gps_map_osd_clear_nav (OsmGpsMa
1436          if(priv->nav.name) g_free(priv->nav.name);          if(priv->nav.name) g_free(priv->nav.name);
1437      }      }
1438      osm_gps_map_redraw(map);      osm_gps_map_redraw(map);
1439        FOUT;
1440  }  }
1441    
1442  void  void
1443  osm_gps_map_osd_draw_nav (OsmGpsMap *map, gboolean imperial,  osm_gps_map_osd_draw_nav (OsmGpsMap *map, gboolean imperial,
1444                            float latitude, float longitude, char *name) {                            float latitude, float longitude, char *name) {
1445        FIN;
1446      g_return_if_fail (OSM_IS_GPS_MAP (map));      g_return_if_fail (OSM_IS_GPS_MAP (map));
1447    
1448      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);
# Line 1413  osm_gps_map_osd_draw_nav (OsmGpsMap *map Line 1466  osm_gps_map_osd_draw_nav (OsmGpsMap *map
1466      osd_render_nav(osd);      osd_render_nav(osd);
1467    
1468      osm_gps_map_redraw(map);      osm_gps_map_redraw(map);
1469        FOUT;
1470  }  }
1471    
1472  #endif // OSD_NAV  #endif // OSD_NAV
# Line 1431  osm_gps_map_osd_draw_nav (OsmGpsMap *map Line 1485  osm_gps_map_osd_draw_nav (OsmGpsMap *map
1485    
1486  static void  static void
1487  osd_render_crosshair_shape(cairo_t *cr) {  osd_render_crosshair_shape(cairo_t *cr) {
1488        FIN;
1489      cairo_arc (cr, OSD_CROSSHAIR_W/2, OSD_CROSSHAIR_H/2,      cairo_arc (cr, OSD_CROSSHAIR_W/2, OSD_CROSSHAIR_H/2,
1490                 OSD_CROSSHAIR_RADIUS, 0,  2*M_PI);                 OSD_CROSSHAIR_RADIUS, 0,  2*M_PI);
1491    
# Line 1449  osd_render_crosshair_shape(cairo_t *cr) Line 1504  osd_render_crosshair_shape(cairo_t *cr)
1504      cairo_rel_line_to (cr, 0, OSD_CROSSHAIR_TICK);      cairo_rel_line_to (cr, 0, OSD_CROSSHAIR_TICK);
1505    
1506      cairo_stroke (cr);      cairo_stroke (cr);
1507        FOUT;
1508  }  }
1509    
1510  static void  static void
1511  osd_render_crosshair(osm_gps_map_osd_t *osd)  osd_render_crosshair(osm_gps_map_osd_t *osd)
1512  {  {
1513        FIN;
1514      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
1515    
1516      if(priv->crosshair.rendered)      if(priv->crosshair.rendered)
# Line 1479  osd_render_crosshair(osm_gps_map_osd_t * Line 1536  osd_render_crosshair(osm_gps_map_osd_t *
1536      osd_render_crosshair_shape(cr);      osd_render_crosshair_shape(cr);
1537    
1538      cairo_destroy(cr);      cairo_destroy(cr);
1539        FOUT;
1540  }  }
1541  #endif  #endif
1542    
# Line 1500  osd_render_crosshair(osm_gps_map_osd_t * Line 1558  osd_render_crosshair(osm_gps_map_osd_t *
1558  static void  static void
1559  osd_render_scale(osm_gps_map_osd_t *osd)  osd_render_scale(osm_gps_map_osd_t *osd)
1560  {  {
1561        FIN;
1562      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
1563    
1564      /* this only needs to be rendered if the zoom has changed */      /* this only needs to be rendered if the zoom has changed */
# Line 1623  osd_render_scale(osm_gps_map_osd_t *osd) Line 1682  osd_render_scale(osm_gps_map_osd_t *osd)
1682      cairo_stroke(cr);      cairo_stroke(cr);
1683    
1684      cairo_destroy(cr);      cairo_destroy(cr);
1685        FOUT;
1686  }  }
1687  #endif  #endif
1688    
1689  static void  static void
1690  osd_render_controls(osm_gps_map_osd_t *osd)  osd_render_controls(osm_gps_map_osd_t *osd)
1691  {  {
1692        FIN;
1693      osd_priv_t *priv = (osd_priv_t*)osd->priv;      osd_priv_t *priv = (osd_priv_t*)osd->priv;
1694    
1695      if(priv->controls.rendered      if(priv->controls.rendered
# Line 1902  osd_draw(osm_gps_map_osd_t *osd, GdkDraw Line 1963  osd_draw(osm_gps_map_osd_t *osd, GdkDraw
1963  #endif  #endif
1964    
1965      cairo_destroy(cr);      cairo_destroy(cr);
1966        FOUT;
1967  }  }
1968    
1969  static void  static void
1970  osd_free(osm_gps_map_osd_t *osd)  osd_free(osm_gps_map_osd_t *osd)
1971  {  {
1972        FIN;
1973      osd_priv_t *priv = (osd_priv_t *)(osd->priv);      osd_priv_t *priv = (osd_priv_t *)(osd->priv);
1974    
1975      if (priv->controls.surface)      if (priv->controls.surface)
# Line 1946  osd_free(osm_gps_map_osd_t *osd) Line 2009  osd_free(osm_gps_map_osd_t *osd)
2009  #endif  #endif
2010    
2011      g_free(priv);      g_free(priv);
2012        FOUT;
2013  }  }
2014    
2015  static gboolean  static gboolean
2016  osd_busy(osm_gps_map_osd_t *osd)  osd_busy(osm_gps_map_osd_t *osd)
2017  {  {
2018        FIN;
2019  #ifdef OSD_SOURCE_SEL  #ifdef OSD_SOURCE_SEL
2020      osd_priv_t *priv = (osd_priv_t *)(osd->priv);      osd_priv_t *priv = (osd_priv_t *)(osd->priv);
2021      return (priv->source_sel.handler_id != 0);      return (priv->source_sel.handler_id != 0);
# Line 1961  osd_busy(osm_gps_map_osd_t *osd) Line 2026  osd_busy(osm_gps_map_osd_t *osd)
2026    
2027  static osd_button_t  static osd_button_t
2028  osd_check(osm_gps_map_osd_t *osd, gboolean down, gint x, gint y) {  osd_check(osm_gps_map_osd_t *osd, gboolean down, gint x, gint y) {
2029        FIN;
2030      return osd_check_int(osd, TRUE, down, x, y);      return osd_check_int(osd, TRUE, down, x, y);
2031  }  }
2032    
# Line 1983  static osm_gps_map_osd_t osd_classic = { Line 2049  static osm_gps_map_osd_t osd_classic = {
2049  void  void
2050  osm_gps_map_osd_classic_init(OsmGpsMap *map)  osm_gps_map_osd_classic_init(OsmGpsMap *map)
2051  {  {
2052        FIN;
2053      osd_priv_t *priv = osd_classic.priv = g_new0(osd_priv_t, 1);      osd_priv_t *priv = osd_classic.priv = g_new0(osd_priv_t, 1);
2054    
2055  #ifdef OSD_BALLOON  #ifdef OSD_BALLOON
# Line 1993  osm_gps_map_osd_classic_init(OsmGpsMap * Line 2060  osm_gps_map_osd_classic_init(OsmGpsMap *
2060      osd_classic.priv = priv;      osd_classic.priv = priv;
2061    
2062      osm_gps_map_register_osd(map, &osd_classic);      osm_gps_map_register_osd(map, &osd_classic);
2063        FOUT;
2064  }  }
2065    
2066  #ifdef OSD_GPS_BUTTON  #ifdef OSD_GPS_BUTTON
# Line 2000  osm_gps_map_osd_classic_init(OsmGpsMap * Line 2068  osm_gps_map_osd_classic_init(OsmGpsMap *
2068  /* but instead are to be used by the main application */  /* but instead are to be used by the main application */
2069  void osm_gps_map_osd_enable_gps (OsmGpsMap *map, OsmGpsMapOsdCallback cb,  void osm_gps_map_osd_enable_gps (OsmGpsMap *map, OsmGpsMapOsdCallback cb,
2070                                   gpointer data) {                                   gpointer data) {
2071        FIN;
2072      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);
2073      g_return_if_fail (osd);      g_return_if_fail (osd);
2074    
# Line 2011  void osm_gps_map_osd_enable_gps (OsmGpsM Line 2080  void osm_gps_map_osd_enable_gps (OsmGpsM
2080      osd->render(osd);      osd->render(osd);
2081    
2082      osm_gps_map_redraw(map);      osm_gps_map_redraw(map);
2083        FOUT;
2084  }  }
2085  #endif  #endif
2086    
2087  osd_button_t  osd_button_t
2088  osm_gps_map_osd_check(OsmGpsMap *map, gint x, gint y) {  osm_gps_map_osd_check(OsmGpsMap *map, gint x, gint y) {
2089        FIN;
2090      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);      osm_gps_map_osd_t *osd = osm_gps_map_osd_get(map);
2091      g_return_val_if_fail (osd, OSD_NONE);      g_return_val_if_fail (osd, OSD_NONE);
2092    

Legend:
Removed from v.136  
changed lines
  Added in v.143