Statistics
| Revision:

gvsig-vectorediting / org.gvsig.vectorediting / trunk / org.gvsig.vectorediting / org.gvsig.vectorediting.lib / org.gvsig.vectorediting.lib.prov / org.gvsig.vectorediting.lib.prov.autopolygon / src / main / java / org / gvsig / vectorediting / lib / prov / autopolygon / AutopolygonEditingProvider.java @ 2616

History | View | Annotate | Download (7.94 KB)

1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright ? 2007-2014 gvSIG Association
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 2
9
 * of the License, or (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., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24

    
25
package org.gvsig.vectorediting.lib.prov.autopolygon;
26

    
27
import java.util.ArrayList;
28
import java.util.List;
29
import org.cresques.cts.IProjection;
30
import org.gvsig.fmap.dal.exception.DataException;
31
import org.gvsig.fmap.dal.feature.Feature;
32
import org.gvsig.fmap.dal.feature.FeatureQuery;
33
import org.gvsig.fmap.dal.feature.FeatureSet;
34
import org.gvsig.fmap.dal.feature.FeatureStore;
35
import org.gvsig.fmap.dal.feature.FeatureType;
36
import org.gvsig.fmap.geom.Geometry;
37
import org.gvsig.fmap.geom.GeometryLocator;
38
import org.gvsig.fmap.geom.aggregate.MultiSurface;
39
import org.gvsig.fmap.geom.primitive.Point;
40
import org.gvsig.fmap.geom.primitive.Surface;
41
import org.gvsig.fmap.geom.type.GeometryType;
42
import org.gvsig.fmap.mapcontext.layers.vectorial.SpatialEvaluatorsFactory;
43
import org.gvsig.tools.dispose.DisposableIterator;
44
import org.gvsig.tools.dynobject.DynObject;
45
import org.gvsig.tools.evaluator.Evaluator;
46
import org.gvsig.tools.service.spi.ProviderServices;
47
import org.gvsig.vectorediting.lib.api.DrawingStatus;
48
import org.gvsig.vectorediting.lib.api.EditingServiceParameter;
49
import org.gvsig.vectorediting.lib.api.EditingServiceParameter.TYPE;
50
import org.gvsig.vectorediting.lib.api.exceptions.DrawServiceException;
51
import org.gvsig.vectorediting.lib.api.exceptions.FinishServiceException;
52
import org.gvsig.vectorediting.lib.api.exceptions.InvalidEntryException;
53
import org.gvsig.vectorediting.lib.api.exceptions.StartServiceException;
54
import org.gvsig.vectorediting.lib.api.exceptions.StopServiceException;
55
import org.gvsig.vectorediting.lib.spi.AbstractEditingProvider;
56
import org.gvsig.vectorediting.lib.spi.DefaultEditingServiceParameter;
57
import org.gvsig.vectorediting.lib.spi.EditingProvider;
58
import org.gvsig.vectorediting.lib.spi.EditingProviderFactory;
59
import org.gvsig.vectorediting.lib.spi.EditingProviderServices;
60

    
61
@SuppressWarnings("UseSpecificCatch")
62
public class AutopolygonEditingProvider extends AbstractEditingProvider
63
    implements EditingProvider {
64

    
65
    private final EditingServiceParameter geometryParameter;
66

    
67
    private final FeatureStore featureStore;
68

    
69
    private Geometry geometryValue;
70

    
71
    public AutopolygonEditingProvider(ProviderServices services,
72
        DynObject parameters) {
73
        super(services);
74
        this.featureStore =
75
            (FeatureStore) parameters
76
                .getDynValue(EditingProviderFactory.FEATURE_STORE_FIELD);
77

    
78
        this.geometryParameter =
79
            new DefaultEditingServiceParameter("Draw geometry",
80
                "draw_geometry_to_autopolygon", Geometry.TYPES.MULTISURFACE, TYPE.GEOMETRY);
81
    }
82

    
83
    @Override
84
    public EditingServiceParameter next() {
85
        if (geometryValue == null) {
86
            return geometryParameter;
87
        }
88

    
89
        return null;
90
    }
91

    
92
    @Override
93
    public DrawingStatus getDrawingStatus(Point mousePosition)
94
        throws DrawServiceException {
95
        return null;
96
    }
97

    
98
    @Override
99
    public void stop() throws StopServiceException {
100
        geometryValue = null;
101
    }
102

    
103
    @Override
104
    public List<EditingServiceParameter> getParameters() {
105
        List<EditingServiceParameter> list = new ArrayList<>();
106
        list.add(geometryParameter);
107
        return list;
108
    }
109

    
110
    @Override
111
    public void setValue(EditingServiceParameter parameter, Object value) throws InvalidEntryException {
112
        validateAndInsertValue(parameter, value);
113
    }
114

    
115
    @Override
116
    public void setValue(Object value) throws InvalidEntryException {
117
        EditingServiceParameter param = next();
118
        validateAndInsertValue(param, value);
119
    }
120

    
121
    private void validateAndInsertValue(EditingServiceParameter param,
122
        Object value) throws InvalidEntryException {
123

    
124
        if (param == geometryParameter) {
125
            if (value instanceof Geometry ) {
126
                Geometry geometry = (Geometry)value;
127
                GeometryType geometryType = geometry.getGeometryType();
128
                if (geometryType.isTypeOf(Geometry.TYPES.MULTISURFACE) ||
129
                    geometryType.isTypeOf(Geometry.TYPES.SURFACE)) {
130
                    geometryValue = geometry;
131
                    return;
132
                }
133
            }
134
        }
135
        throw new InvalidEntryException(null);
136
    }
137

    
138
    @Override
139
    public void finishAndStore() throws FinishServiceException {
140
        EditingProviderServices editingProviderServices =
141
            (EditingProviderServices) getProviderServices();
142
        Geometry geometry = finish();
143
        editingProviderServices.insertGeometryIntoFeatureStore(geometry,
144
            featureStore);
145
    }
146

    
147
    @Override
148
    public Geometry finish() throws FinishServiceException {
149
        EditingProviderServices editingProviderServices =
150
            (EditingProviderServices) getProviderServices();
151

    
152
        Geometry geometry = geometryValue.cloneGeometry();
153
        FeatureQuery query;
154
        try {
155
            query = queryByGeometry(geometry);
156
            if (query != null) {
157
                FeatureSet features = featureStore.getFeatureSet(query);
158
                DisposableIterator featuresIterator = features.fastIterator();
159
                while (featuresIterator.hasNext()) {
160
                    Feature feature = (Feature) featuresIterator.next();
161
                    geometry =
162
                        geometry.difference(feature.getDefaultGeometry());
163
                }
164
                featuresIterator.dispose();
165
                features.dispose();
166
            }
167
            GeometryType storeGeomType =
168
                editingProviderServices.getGeomType(featureStore);
169

    
170
            if (storeGeomType.isTypeOf(MULTISURFACE)) {
171
                MultiSurface multisurface;
172
                multisurface =
173
                    GeometryLocator.getGeometryManager().createMultiSurface(
174
                        storeGeomType.getSubType());
175
                multisurface.addSurface((Surface)geometry);
176
                return multisurface;
177
            }
178

    
179
        } catch (Exception e) {
180
            throw new FinishServiceException(e);
181
        }
182
        return geometry;
183
    }
184

    
185
    @Override
186
    public void start() throws StartServiceException, InvalidEntryException {
187
        geometryValue = null;
188
    }
189

    
190
    @Override
191
    public String getName() {
192
        return AutopolygonEditingProviderFactory.PROVIDER_NAME;
193
    }
194

    
195
    private FeatureQuery queryByGeometry(Geometry geometry) throws DataException {
196
        FeatureQuery featureQuery = featureStore.createFeatureQuery();
197
        FeatureType featureType = featureStore.getDefaultFeatureType();
198
        String geomName = featureType.getDefaultGeometryAttributeName();
199
        featureQuery.setFeatureType(featureType);
200

    
201
        IProjection query_proj = featureType.getDefaultSRS();
202
        Evaluator iee = SpatialEvaluatorsFactory.getInstance().intersects(
203
            geometry, 
204
            query_proj, 
205
            featureStore
206
        );
207
        featureQuery.setFilter(iee);
208
        featureQuery.setAttributeNames(null);
209
        return featureQuery;
210
    }
211

    
212
    @Override
213
    public Object getValue(EditingServiceParameter parameter) {
214
        if(parameter == this.geometryParameter){
215
            return geometryValue;
216
        }
217
        return null;
218
    }
219

    
220

    
221
}