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

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

revision 132 by harbaum, Thu Oct 1 08:09:00 2009 UTC revision 143 by harbaum, Mon Oct 26 19:55:00 2009 UTC
# Line 82  typedef struct { Line 82  typedef struct {
82          cairo_surface_t *surface;          cairo_surface_t *surface;
83          float lat, lon;          float lat, lon;
84          char *name;          char *name;
85            gboolean imperial;    // display distance imperial/metric
86      } nav;      } nav;
87  #endif  #endif
88    
# Line 134  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 141  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 169  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 265  osd_render_balloon(osm_gps_map_osd_t *os Line 274  osd_render_balloon(osm_gps_map_osd_t *os
274      cairo_stroke (cr);      cairo_stroke (cr);
275    
276      if (priv->balloon.cb) {      if (priv->balloon.cb) {
277            osm_gps_map_balloon_event_t event;
278    
279          /* clip in case application tries to draw in */          /* clip in case application tries to draw in */
280              /* exceed of the balloon */              /* exceed of the balloon */
281          cairo_rectangle (cr, priv->balloon.rect.x, priv->balloon.rect.y,          cairo_rectangle (cr, priv->balloon.rect.x, priv->balloon.rect.y,
282                           priv->balloon.rect.w, priv->balloon.rect.h);                           priv->balloon.rect.w, priv->balloon.rect.h);
283          cairo_clip (cr);          cairo_clip (cr);
284          cairo_new_path (cr);  /* current path is not          cairo_new_path (cr);  /* current path is not consumed by cairo_clip */
285                                   consumed by cairo_clip() */  
286            /* request the application to draw the balloon contents */
287            event.type = OSM_GPS_MAP_BALLOON_EVENT_TYPE_DRAW;
288            event.data.draw.rect = &priv->balloon.rect;
289            event.data.draw.cr = cr;
290    
291          priv->balloon.cb(cr, &priv->balloon.rect, priv->balloon.data);          priv->balloon.cb(&event, priv->balloon.data);
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 */
300  /* the given coordinate is within this balloon */  /* the given coordinate is within this balloon */
301  static gboolean  static gboolean
302  osd_balloon_check(osm_gps_map_osd_t *osd, 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 301  osd_balloon_check(osm_gps_map_osd_t *osd Line 320  osd_balloon_check(osm_gps_map_osd_t *osd
320          (x > xs) && (x < xs + priv->balloon.rect.w) &&          (x > xs) && (x < xs + priv->balloon.rect.w) &&
321          (y > ys) && (y < ys + priv->balloon.rect.h);          (y > ys) && (y < ys + priv->balloon.rect.h);
322    
323      /* handle the fact that the balloon may have been created by the */      /* is this a real click or is the application just checking for something? */
324      /* button down event */      if(click) {
     if(!is_in && !down && !priv->balloon.just_created) {  
         /* the user actually clicked outside the balloon */  
325    
326          /* close the balloon! */          /* handle the fact that the balloon may have been created by the */
327          osm_gps_map_osd_clear_balloon (OSM_GPS_MAP(osd->widget));          /* button down event */
328      }          if(!is_in && !down && !priv->balloon.just_created) {
329                /* the user actually clicked outside the balloon */
330    
331                /* close the balloon! */
332                osm_gps_map_osd_clear_balloon (OSM_GPS_MAP(osd->widget));
333    
334                /* and inform application about this */
335                if(priv->balloon.cb) {
336                    osm_gps_map_balloon_event_t event;
337                    event.type = OSM_GPS_MAP_BALLOON_EVENT_TYPE_REMOVED;
338                    priv->balloon.cb(&event, priv->balloon.data);
339                }
340    
341            }
342    
343            if(is_in && priv->balloon.cb) {
344                osm_gps_map_balloon_event_t event;
345    
346                /* notify application of click */
347                event.type = OSM_GPS_MAP_BALLOON_EVENT_TYPE_CLICK;
348                event.data.click.x = x - xs;
349                event.data.click.y = y - ys;
350                event.data.click.down = down;
351    
352                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 329  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 360  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 504  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 702  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 748  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 794  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 838  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 845  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 870  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 932  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(osm_gps_map_osd_t *osd, 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 985  osd_check(osm_gps_map_osd_t *osd, gboole Line 1046  osd_check(osm_gps_map_osd_t *osd, gboole
1046  #ifdef OSD_BALLOON  #ifdef OSD_BALLOON
1047      if(but == OSD_NONE) {      if(but == OSD_NONE) {
1048          /* check if user clicked into balloon */          /* check if user clicked into balloon */
1049          if(osd_balloon_check(osd, down, x, y))          if(osd_balloon_check(osd, click, down, x, y))
1050              but = OSD_BG;              but = OSD_BG;
1051      }      }
1052  #endif  #endif
1053    
1054        FOUT;
1055      return but;      return but;
1056  }  }
1057    
# Line 1133  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 1157  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 1204  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    
1289  #ifdef OSD_NAV  #ifdef OSD_NAV
1290  #define OSD_NAV_W  (8*OSD_COORDINATES_FONT_SIZE+2*OSD_COORDINATES_OFFSET)  #define OSD_NAV_W  (8*OSD_COORDINATES_FONT_SIZE+2*OSD_COORDINATES_OFFSET)
1291  #define OSD_NAV_H  (130)  #define OSD_NAV_H  (11*OSD_COORDINATES_FONT_SIZE)
1292    
1293  /* http://mathforum.org/library/drmath/view/55417.html */  /* http://mathforum.org/library/drmath/view/55417.html */
1294  static float get_bearing(float lat1, float lon1, float lat2, float lon2) {  static float get_bearing(float lat1, float lon1, float lat2, float lon2) {
# Line 1231  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 1312  osd_render_nav(osm_gps_map_osd_t *osd) Line 1392  osd_render_nav(osm_gps_map_osd_t *osd)
1392                          deg2rad(priv->nav.lat), deg2rad(priv->nav.lon));                          deg2rad(priv->nav.lat), deg2rad(priv->nav.lon));
1393    
1394          char *dist_str = NULL;          char *dist_str = NULL;
1395          if(dist<1000)          if(!priv->nav.imperial) {
1396              dist_str = g_strdup_printf("%u m", (int)dist);              /* metric is easy ... */
1397          else              if(dist<1000)
1398              dist_str = g_strdup_printf("%.1f km", dist/1000);                  dist_str = g_strdup_printf("%u m", (int)dist);
1399                else
1400                    dist_str = g_strdup_printf("%.1f km", dist/1000);
1401            } else {
1402                /* and now the hard part: scale for useful imperial values :-( */
1403                /* try to convert to feet, 1ft == 0.3048 m */
1404    
1405                if(dist/(3*0.3048) >= 1760.0)      /* more than 1760 yard? */
1406                    dist_str = g_strdup_printf("%.1f mi", dist/(0.3048*3*1760.0));
1407                else if(dist/0.3048 >= 100)        /* more than 100 feet? */
1408                    dist_str = g_strdup_printf("%.1f yd", dist/(0.3048*3));
1409                else
1410                    dist_str = g_strdup_printf("%.0f ft", dist/0.3048);
1411            }
1412    
1413          y = osd_render_centered_text(cr, y, OSD_NAV_W, dist_str);          y = osd_render_centered_text(cr, y, OSD_NAV_W, dist_str);
1414          g_free(dist_str);          g_free(dist_str);
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 1341  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, float latitude, float longitude,  osm_gps_map_osd_draw_nav (OsmGpsMap *map, gboolean imperial,
1444                            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 1364  osm_gps_map_osd_draw_nav (OsmGpsMap *map Line 1461  osm_gps_map_osd_draw_nav (OsmGpsMap *map
1461      priv->nav.lat = latitude;      priv->nav.lat = latitude;
1462      priv->nav.lon = longitude;      priv->nav.lon = longitude;
1463      priv->nav.name = g_strdup(name);      priv->nav.name = g_strdup(name);
1464        priv->nav.imperial = imperial;
1465    
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 1386  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 1404  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 1434  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 1455  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 1578  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 1857  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 1901  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 1914  osd_busy(osm_gps_map_osd_t *osd) Line 2024  osd_busy(osm_gps_map_osd_t *osd)
2024  #endif  #endif
2025  }  }
2026    
2027    static osd_button_t
2028    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);
2031    }
2032    
2033  static osm_gps_map_osd_t osd_classic = {  static osm_gps_map_osd_t osd_classic = {
2034      .widget     = NULL,      .widget     = NULL,
2035    
# Line 1933  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 1943  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 1950  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 1961  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    
2093      return osd_check(osd, TRUE, x, y);      return osd_check_int(osd, FALSE, TRUE, x, y);
2094  }  }

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