Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.compat.cdc / org.gvsig.fmap.geometry / org.gvsig.fmap.geometry.jts / src / main / java / org / gvsig / fmap / geom / jts / aggregate / AbstractMultiLine.java @ 42358

History | View | Annotate | Download (2.91 KB)

1
/* gvSIG. Desktop Geographic Information System.
2
 *
3
 * Copyright ? 2007-2015 gvSIG Association
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
18
 * MA  02110-1301, USA.
19
 *
20
 * For any additional information, do not hesitate to contact us
21
 * at info AT gvsig.com, or visit our website www.gvsig.com.
22
 */
23
package org.gvsig.fmap.geom.jts.aggregate;
24

    
25
import java.awt.Shape;
26
import java.awt.geom.AffineTransform;
27
import java.awt.geom.PathIterator;
28
import java.util.ArrayList;
29
import java.util.Collections;
30
import java.util.Iterator;
31
import java.util.List;
32

    
33
import com.vividsolutions.jts.geom.LineString;
34

    
35
import org.gvsig.fmap.geom.Geometry;
36
import org.gvsig.fmap.geom.GeometryException;
37
import org.gvsig.fmap.geom.aggregate.MultiLine;
38
import org.gvsig.fmap.geom.jts.GeometryJTS;
39
import org.gvsig.fmap.geom.jts.gputils.DefaultGeneralPathX;
40
import org.gvsig.fmap.geom.jts.gputils.GeneralPathXIterator;
41
import org.gvsig.fmap.geom.jts.util.JTSUtils;
42
import org.gvsig.fmap.geom.operation.GeometryOperationException;
43
import org.gvsig.fmap.geom.operation.GeometryOperationNotSupportedException;
44
import org.gvsig.fmap.geom.primitive.GeneralPathX;
45
import org.gvsig.fmap.geom.primitive.Primitive;
46

    
47

    
48
/**
49
 * @author fdiaz
50
 *
51
 */
52
public abstract class AbstractMultiLine extends AbstractMultiCurve implements MultiLine {
53

    
54
    /**
55
     *
56
     */
57
    private static final long serialVersionUID = 3585059833766514177L;
58

    
59
    /**
60
     * @param type
61
     */
62
    public AbstractMultiLine(int subtype) {
63
        super(Geometry.TYPES.MULTILINE, subtype);
64
    }
65

    
66

    
67
    /* (non-Javadoc)
68
     * @see org.gvsig.fmap.geom.jts.GeometryJTS#getJTS()
69
     */
70
    public com.vividsolutions.jts.geom.Geometry getJTS() {
71
        LineString[] lineStrings = new LineString[primitives.size()];
72
        for(int i=0; i<primitives.size(); i++){
73
            lineStrings[i]=(LineString) ((GeometryJTS)primitives.get(i)).getJTS();
74
        }
75
        return JTSUtils.createJTSMultiLineString(lineStrings);
76
    }
77

    
78
    /* (non-Javadoc)
79
     * @see org.gvsig.fmap.geom.jts.GeometryJTS#flip()
80
     */
81
    public void flip() throws GeometryOperationNotSupportedException, GeometryOperationException {
82
        for (Iterator iterator = primitives.iterator(); iterator.hasNext();) {
83
            ((GeometryJTS)iterator.next()).flip();
84
        }
85
        Collections.reverse(primitives);
86
    }
87
}