]> git.street.me.uk Git - andy/viking.git/blobdiff - src/viktrwlayer.h
Remove the now unused viewport alpha pixbuf and gdk pixbuf compositing method.
[andy/viking.git] / src / viktrwlayer.h
index 86849bc1a345b7696a154c6f27832338cc0d867b..6be6d66555261bdebe2189ce5f3e33db3d9ff007 100644 (file)
@@ -57,6 +57,21 @@ GType vik_trw_layer_get_type ();
 
 typedef struct _VikTrwLayer VikTrwLayer;
 
+typedef struct {
+  gchar *description;
+  gchar *author;
+  //gboolean has_time;
+  gchar *timestamp; // TODO: Consider storing as proper time_t.
+  gchar *keywords; // TODO: handling/storing a GList of individual tags?
+} VikTRWMetadata;
+
+VikTRWMetadata *vik_trw_metadata_new();
+void vik_trw_metadata_free ( VikTRWMetadata *metadata);
+VikTRWMetadata *vik_trw_layer_get_metadata ( VikTrwLayer *vtl );
+void vik_trw_layer_set_metadata ( VikTrwLayer *vtl, VikTRWMetadata *metadata);
+
+gboolean vik_trw_layer_find_date ( VikTrwLayer *vtl, const gchar *date_str, VikCoord *position, VikViewport *vvp, gboolean do_tracks, gboolean select );
+
 /* These are meant for use in file loaders (gpspoint.c, gpx.c, etc).
  * These copy the name, so you should free it if necessary. */
 void vik_trw_layer_filein_add_waypoint ( VikTrwLayer *vtl, gchar *name, VikWaypoint *wp );
@@ -96,6 +111,10 @@ void trw_layer_cancel_tps_of_track ( VikTrwLayer *vtl, VikTrack *trk );
 
 void vik_trw_layer_reset_waypoints ( VikTrwLayer *vtl );
 
+void vik_trw_layer_draw_highlight ( VikTrwLayer *vtl, VikViewport *vvp );
+void vik_trw_layer_draw_highlight_item ( VikTrwLayer *vtl, VikTrack *trk, VikWaypoint *wpt, VikViewport *vvp );
+void vik_trw_layer_draw_highlight_items ( VikTrwLayer *vtl, GHashTable *trks, GHashTable *wpts, VikViewport *vvp );
+
 // For creating a list of tracks with the corresponding layer it is in
 //  (thus a selection of tracks may be from differing layers)
 typedef struct {
@@ -106,11 +125,26 @@ typedef struct {
 typedef GList* (*VikTrwlayerGetTracksAndLayersFunc) (VikLayer*, gpointer);
 GList *vik_trw_layer_build_track_list_t ( VikTrwLayer *vtl, GList *tracks );
 
+// For creating a list of waypoints with the corresponding layer it is in
+//  (thus a selection of waypoints may be from differing layers)
+typedef struct {
+  VikWaypoint *wpt;
+  VikTrwLayer *vtl;
+} vik_trw_waypoint_list_t;
+
+typedef GList* (*VikTrwlayerGetWaypointsAndLayersFunc) (VikLayer*, gpointer);
+GList *vik_trw_layer_build_waypoint_list_t ( VikTrwLayer *vtl, GList *waypoints );
+
+GdkPixbuf* get_wp_sym_small ( gchar *symbol );
+
 /* Exposed Layer Interface function definitions */
 // Intended only for use by other trw_layer subwindows
 void trw_layer_verify_thumbnails ( VikTrwLayer *vtl, GtkWidget *vp );
 // Other functions only for use by other trw_layer subwindows
 gchar *trw_layer_new_unique_sublayer_name ( VikTrwLayer *vtl, gint sublayer_type, const gchar *name );
+void trw_layer_waypoint_rename ( VikTrwLayer *vtl, VikWaypoint *wp, const gchar *new_name );
+void trw_layer_waypoint_reset_icon ( VikTrwLayer *vtl, VikWaypoint *wp );
+void trw_layer_calculate_bounds_waypoints ( VikTrwLayer *vtl );
 
 gboolean vik_trw_layer_get_tracks_visibility ( VikTrwLayer *vtl );
 gboolean vik_trw_layer_get_routes_visibility ( VikTrwLayer *vtl );
@@ -126,12 +160,20 @@ typedef struct {
 } trku_udata;
 gboolean trw_layer_track_find_uuid ( const gpointer id, const VikTrack *trk, gpointer udata );
 
+typedef struct {
+  VikWaypoint *wp; // input
+  gpointer uuid;   // output
+} wpu_udata;
+gboolean trw_layer_waypoint_find_uuid ( const gpointer id, const VikWaypoint *wp, gpointer udata );
+
 void trw_layer_zoom_to_show_latlons ( VikTrwLayer *vtl, VikViewport *vvp, struct LatLon maxmin[2] );
 
 GHashTable *vik_trw_layer_get_tracks_iters ( VikTrwLayer *vtl );
 GHashTable *vik_trw_layer_get_routes_iters ( VikTrwLayer *vtl );
 GHashTable *vik_trw_layer_get_waypoints_iters ( VikTrwLayer *vtl );
 
+#define VIK_SETTINGS_LIST_DATE_FORMAT "list_date_format"
+
 G_END_DECLS
 
 #endif