]> git.street.me.uk Git - andy/viking.git/blame - src/datasource_bfilter.c
Add negative scales so that we can have bigger zoom on maps
[andy/viking.git] / src / datasource_bfilter.c
CommitLineData
40a8d1c2
EB
1/*
2 * viking -- GPS Data and Topo Analyzer, Explorer, and Manager
3 *
4 * Copyright (C) 2003-2005, Evan Battaglia <gtoevan@gmx.net>
5 *
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.
10 *
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.
15 *
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
19 *
20 */
4c77d5e0 21#ifdef HAVE_CONFIG_H
40a8d1c2 22#include "config.h"
4c77d5e0 23#endif
40a8d1c2 24#include <string.h>
4c77d5e0 25#include <glib/gi18n.h>
40a8d1c2
EB
26
27#include "viking.h"
28#include "babel.h"
29#include "gpx.h"
30#include "acquire.h"
31
32
33/************************************ Simplify ***********************************/
34
35static void datasource_bfilter_simplify_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename );
36
37/* TODO: shell_escape stuff */
38/* TODO: name is useless for filters */
39
40/* spin button scales */
41VikLayerParamScale simplify_params_scales[] = {
42 {1, 10000, 10, 0},
43};
44
45VikLayerParam bfilter_simplify_params[] = {
4c77d5e0 46 { "numberofpoints", VIK_LAYER_PARAM_UINT, VIK_LAYER_GROUP_NONE, N_("Max number of points:"), VIK_LAYER_WIDGET_SPINBUTTON, simplify_params_scales + 0 },
40a8d1c2
EB
47};
48
49VikLayerParamData bfilter_simplify_params_defaults[] = {
50 { 100 },
51};
52
53VikDataSourceInterface vik_datasource_bfilter_simplify_interface = {
4c77d5e0
GB
54 N_("Simplify All Tracks"),
55 N_("Simplified Tracks"),
40a8d1c2
EB
56 VIK_DATASOURCE_SHELL_CMD,
57 VIK_DATASOURCE_CREATENEWLAYER,
58 VIK_DATASOURCE_INPUTTYPE_TRWLAYER,
59 FALSE, /* keep dialog open after success */
60 NULL, NULL, NULL,
61 (VikDataSourceGetCmdStringFunc) datasource_bfilter_simplify_get_cmd_string,
62 NULL, NULL, NULL,
63
64 bfilter_simplify_params,
65 sizeof(bfilter_simplify_params)/sizeof(bfilter_simplify_params[0]),
66 bfilter_simplify_params_defaults,
67 NULL,
68 0
69};
70
71
72static void datasource_bfilter_simplify_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename )
73{
74 *input_file_type = NULL;
75 *cmd = g_strdup_printf ( "gpsbabel -i gpx -f %s -x simplify,count=%d -o gpx -F -", input_filename, paramdatas[0].u );
76}
77
78/************************************ Duplicate Location ***********************************/
79
80static void datasource_bfilter_dup_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename );
81
82/* TODO: shell_escape stuff */
83/* TODO: name is useless for filters */
84
85
86VikDataSourceInterface vik_datasource_bfilter_dup_interface = {
4c77d5e0
GB
87 N_("Remove Duplicate Waypoints"),
88 N_("Remove Duplicate Waypoints"),
40a8d1c2
EB
89 VIK_DATASOURCE_SHELL_CMD,
90 VIK_DATASOURCE_CREATENEWLAYER,
91 VIK_DATASOURCE_INPUTTYPE_TRWLAYER,
92 FALSE, /* keep dialog open after success */
93 NULL, NULL, NULL,
94 (VikDataSourceGetCmdStringFunc) datasource_bfilter_dup_get_cmd_string,
95 NULL, NULL, NULL,
96
97 NULL, 0, NULL, NULL, 0
98};
99
100
101static void datasource_bfilter_dup_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename )
102{
103 *input_file_type = NULL;
7de42638 104 *cmd = g_strdup_printf ( "gpsbabel -i gpx -f %s -x duplicate,location -o gpx -F -", input_filename );
40a8d1c2
EB
105}
106
107
108/************************************ Polygon ***********************************/
109
110static void datasource_bfilter_polygon_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename, const gchar *input_track_filename );
111
112/* TODO: shell_escape stuff */
113/* TODO: name is useless for filters */
114
115
116VikDataSourceInterface vik_datasource_bfilter_polygon_interface = {
4c77d5e0 117 N_("Waypoints Inside This"),
8a7788c9 118 N_("Polygonized Layer"),
40a8d1c2
EB
119 VIK_DATASOURCE_SHELL_CMD,
120 VIK_DATASOURCE_CREATENEWLAYER,
121 VIK_DATASOURCE_INPUTTYPE_TRWLAYER_TRACK,
122 FALSE, /* keep dialog open after success */
123 NULL, NULL, NULL,
124 (VikDataSourceGetCmdStringFunc) datasource_bfilter_polygon_get_cmd_string,
125 NULL, NULL, NULL,
126
127 NULL,
128 0,
129 NULL,
130 NULL,
131 0
132};
133
134
135static void datasource_bfilter_polygon_get_cmd_string ( VikLayerParamData *paramdatas, gchar **cmd, gchar **input_file_type, const gchar *input_filename, const gchar *input_track_filename )
136{
137 *input_file_type = NULL;
138 *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 );
139}
140
141/************************************ Exclude Polygon ***********************************/
142
143static 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 );
144
145/* TODO: shell_escape stuff */
146/* TODO: name is useless for filters */
147
148
149VikDataSourceInterface vik_datasource_bfilter_exclude_polygon_interface = {
4c77d5e0
GB
150 N_("Waypoints Outside This"),
151 N_("Polygonzied Layer"),
40a8d1c2
EB
152 VIK_DATASOURCE_SHELL_CMD,
153 VIK_DATASOURCE_CREATENEWLAYER,
154 VIK_DATASOURCE_INPUTTYPE_TRWLAYER_TRACK,
155 FALSE, /* keep dialog open after success */
156 NULL, NULL, NULL,
157 (VikDataSourceGetCmdStringFunc) datasource_bfilter_exclude_polygon_get_cmd_string,
158 NULL, NULL, NULL,
159
160 NULL,
161 0,
162 NULL,
163 NULL,
164 0
165};
166
167
168static 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 )
169{
170 *input_file_type = NULL;
171 *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 );
172}
173