1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
/*!
\file vector/vedit/chtype.c
\brief Vedit library - change primitives type
(C) 2008 by the GRASS Development Team
This program is free software under the GNU General Public License
(>=v2). Read the file COPYING that comes with GRASS for details.
\author Martin Landa <landa.martin gmail.com>
*/
#include <grass/vedit.h>
/*!
\brief Change primitive type
Supported conversions:
- point <-> centroid
- line <-> boundary
\param Map pointer to Map_info
\param List list of selected primitives
\return number of modified primitives
\return -1 on error
*/
int Vedit_chtype_lines(struct Map_info *Map, struct ilist *List)
{
int i;
int nret, line;
int type, newtype;
struct line_pnts *Points;
struct line_cats *Cats;
nret = 0;
Points = Vect_new_line_struct();
Cats = Vect_new_cats_struct();
for (i = 0; i < List->n_values; i++) {
line = List->value[i];
if (!Vect_line_alive(Map, line))
continue;
type = Vect_read_line(Map, Points, Cats, line);
if (type < 0) {
return -1;
}
switch (type) {
case GV_POINT:
newtype = GV_CENTROID;
break;
case GV_CENTROID:
newtype = GV_POINT;
break;
case GV_LINE:
newtype = GV_BOUNDARY;
break;
case GV_BOUNDARY:
newtype = GV_LINE;
break;
default:
newtype = -1;
break;
}
G_debug(3, "Vedit_chtype_lines(): line=%d, from_type=%d, to_type=%d",
line, type, newtype);
if (newtype > 0) {
if (Vect_rewrite_line(Map, line, newtype, Points, Cats) < 0) {
return -1;
}
nret++;
}
}
Vect_destroy_line_struct(Points);
Vect_destroy_cats_struct(Cats);
return nret;
}
|