2 * viking -- GPS Data and Topo Analyzer, Explorer, and Manager
4 * Copyright (C) 2003-2007, Evan Battaglia <gtoevan@gmx.net>
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
25 #include <glib/gi18n.h>
33 /************************************ Simplify ***********************************/
35 static void datasource_bfilter_simplify_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename );
37 /* TODO: shell_escape stuff */
38 /* TODO: name is useless for filters */
40 /* spin button scales */
41 VikLayerParamScale simplify_params_scales[] = {
45 VikLayerParam bfilter_simplify_params[] = {
46 { "numberofpoints", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("Max number of points:"), VIK_LAYER_WIDGET_SPINBUTTON, simplify_params_scales, NULL },
49 VikLayerParamData bfilter_simplify_params_defaults[] = {
50 /* Annoyingly 'C' cannot initialize unions properly */
51 /* It's dependent on the standard used or the compiler support... */
52 #if defined __STDC_VERSION__ && __STDC_VERSION__ >= 199901L || __GNUC__
59 VikDataSourceInterface vik_datasource_bfilter_simplify_interface = {
60 N_("Simplify All Tracks..."),
61 N_("Simplified Tracks"),
62 VIK_DATASOURCE_SHELL_CMD,
63 VIK_DATASOURCE_CREATENEWLAYER,
64 VIK_DATASOURCE_INPUTTYPE_TRWLAYER,
66 FALSE, /* keep dialog open after success */
68 (VikDataSourceGetCmdStringFunc) datasource_bfilter_simplify_get_cmd_string,
70 (VikDataSourceOffFunc) NULL,
72 bfilter_simplify_params,
73 sizeof(bfilter_simplify_params)/sizeof(bfilter_simplify_params[0]),
74 bfilter_simplify_params_defaults,
80 static void datasource_bfilter_simplify_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename )
82 *input_file_type = NULL;
83 *cmd = g_strdup_printf ( "gpsbabel -i gpx -f %s -x simplify,count=%d -o gpx -F -", input_filename, paramdatas[0].u );
86 /************************************ Duplicate Location ***********************************/
88 static void datasource_bfilter_dup_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename );
90 /* TODO: shell_escape stuff */
91 /* TODO: name is useless for filters */
94 VikDataSourceInterface vik_datasource_bfilter_dup_interface = {
95 N_("Remove Duplicate Waypoints"),
96 N_("Remove Duplicate Waypoints"),
97 VIK_DATASOURCE_SHELL_CMD,
98 VIK_DATASOURCE_CREATENEWLAYER,
99 VIK_DATASOURCE_INPUTTYPE_TRWLAYER,
101 FALSE, /* keep dialog open after success */
103 (VikDataSourceGetCmdStringFunc) datasource_bfilter_dup_get_cmd_string,
105 (VikDataSourceOffFunc) NULL,
107 NULL, 0, NULL, NULL, 0
111 static void datasource_bfilter_dup_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename )
113 *input_file_type = NULL;
114 *cmd = g_strdup_printf ( "gpsbabel -i gpx -f %s -x duplicate,location -o gpx -F -", input_filename );
118 /************************************ Polygon ***********************************/
120 static void datasource_bfilter_polygon_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename, const gchar *input_track_filename );
122 /* TODO: shell_escape stuff */
123 /* TODO: name is useless for filters */
126 VikDataSourceInterface vik_datasource_bfilter_polygon_interface = {
127 N_("Waypoints Inside This"),
128 N_("Polygonized Layer"),
129 VIK_DATASOURCE_SHELL_CMD,
130 VIK_DATASOURCE_CREATENEWLAYER,
131 VIK_DATASOURCE_INPUTTYPE_TRWLAYER_TRACK,
133 FALSE, /* keep dialog open after success */
135 (VikDataSourceGetCmdStringFunc) datasource_bfilter_polygon_get_cmd_string,
137 (VikDataSourceOffFunc) NULL,
147 static void datasource_bfilter_polygon_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename, const gchar *input_track_filename )
149 *input_file_type = NULL;
150 *cmd = g_strdup_printf ( "gpsbabel -i gpx -f %s -o arc -F - | gpsbabel -i gpx -f %s -x polygon,file=- -o gpx -F -", input_track_filename, input_filename );
153 /************************************ Exclude Polygon ***********************************/
155 static void datasource_bfilter_exclude_polygon_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename, const gchar *input_track_filename );
157 /* TODO: shell_escape stuff */
158 /* TODO: name is useless for filters */
161 VikDataSourceInterface vik_datasource_bfilter_exclude_polygon_interface = {
162 N_("Waypoints Outside This"),
163 N_("Polygonzied Layer"),
164 VIK_DATASOURCE_SHELL_CMD,
165 VIK_DATASOURCE_CREATENEWLAYER,
166 VIK_DATASOURCE_INPUTTYPE_TRWLAYER_TRACK,
168 FALSE, /* keep dialog open after success */
170 (VikDataSourceGetCmdStringFunc) datasource_bfilter_exclude_polygon_get_cmd_string,
172 (VikDataSourceOffFunc) NULL,
182 static void datasource_bfilter_exclude_polygon_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename, const gchar *input_track_filename )
184 *input_file_type = NULL;
185 *cmd = g_strdup_printf ( "gpsbabel -i gpx -f %s -o arc -F - | gpsbabel -i gpx -f %s -x polygon,exclude,file=- -o gpx -F -", input_track_filename, input_filename );