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.converttopolyline / src / main / java / org / gvsig / vectorediting / lib / prov / converttopolyline / ConvertToPolylineEditingProvider.java @ 2444

History | View | Annotate | Download (8.89 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.vectorediting.lib.prov.converttopolyline;
24

    
25
import java.util.ArrayList;
26
import java.util.List;
27
import org.gvsig.fmap.dal.exception.DataException;
28
import org.gvsig.fmap.dal.feature.EditableFeature;
29
import org.gvsig.fmap.dal.feature.Feature;
30
import org.gvsig.fmap.dal.feature.FeatureSelection;
31
import org.gvsig.fmap.dal.feature.FeatureStore;
32
import org.gvsig.fmap.geom.Geometry;
33
import org.gvsig.fmap.geom.Geometry.TYPES;
34
import org.gvsig.fmap.geom.GeometryLocator;
35
import org.gvsig.fmap.geom.GeometryManager;
36
import org.gvsig.fmap.geom.exception.CreateGeometryException;
37
import org.gvsig.fmap.geom.primitive.Curve;
38
import org.gvsig.fmap.geom.primitive.Line;
39
import org.gvsig.fmap.geom.primitive.Point;
40
import org.gvsig.fmap.geom.type.GeometryType;
41
import org.gvsig.tools.ToolsLocator;
42
import org.gvsig.tools.dispose.DisposableIterator;
43
import org.gvsig.tools.dispose.DisposeUtils;
44
import org.gvsig.tools.dynobject.DynObject;
45
import org.gvsig.tools.exception.BaseException;
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
public class ConvertToPolylineEditingProvider extends AbstractEditingProvider
62
    implements EditingProvider {
63

    
64
    private EditingServiceParameter selectionParameter;
65

    
66
    private FeatureSelection featureSelection;
67

    
68
    private FeatureStore featureStore;
69

    
70
    public ConvertToPolylineEditingProvider(ProviderServices providerServices,
71
        DynObject parameters) {
72
        super(providerServices);
73

    
74
        this.featureStore =
75
            (FeatureStore) parameters
76
                .getDynValue(EditingProviderFactory.FEATURE_STORE_FIELD);
77

    
78
        this.selectionParameter =
79
            new DefaultEditingServiceParameter("selection", "selection",
80
                TYPE.SELECTION);
81
    }
82

    
83
    public EditingServiceParameter next() {
84
        if (this.featureSelection == null) {
85
            return selectionParameter;
86
        }
87
        return null;
88
    }
89

    
90
    public DrawingStatus getDrawingStatus(Point mousePosition)
91
        throws DrawServiceException {
92
        return null;
93
    }
94

    
95
    public void stop() throws StopServiceException {
96
        DisposeUtils.disposeQuietly(featureSelection);
97
        featureSelection = null;
98

    
99
    }
100

    
101
    public List<EditingServiceParameter> getParameters() {
102
        List<EditingServiceParameter> parameters =
103
            new ArrayList<EditingServiceParameter>();
104
        parameters.add(selectionParameter);
105
        return parameters;
106
    }
107

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

    
113
    public void setValue(Object value) throws InvalidEntryException {
114
        EditingServiceParameter parameter = next();
115
        validateAndInsertValue(parameter, value);
116

    
117
    }
118

    
119
    private void validateAndInsertValue(EditingServiceParameter parameter,
120
        Object value) throws InvalidEntryException {
121

    
122
        if (parameter == selectionParameter) {
123

    
124
            if (value instanceof FeatureSelection) {
125
                FeatureSelection fSelection = (FeatureSelection) value;
126

    
127
                if (fSelection.getSelectedCount() >= 1) {
128
                    DisposableIterator it = null;
129

    
130
                    try {
131
                        it = fSelection.fastIterator();
132

    
133
                        while (it.hasNext()) {
134

    
135
                            Feature feature = (Feature) it.next();
136
                            // Gets geometry type of first selected feature
137
                            GeometryType geometryType =
138
                                feature.getDefaultGeometry().getGeometryType();
139

    
140
                            if (!geometryType.isTypeOf(TYPES.CURVE)
141
                                && !geometryType.isTypeOf(TYPES.MULTICURVE)) {
142

    
143
                                throw new InvalidEntryException(null);
144
                            }
145
                        }
146
                        DisposeUtils.disposeQuietly(featureSelection);
147
                        ToolsLocator.getDisposableManager().bind(fSelection);
148
                        featureSelection = fSelection;
149
                        return;
150
                    } catch (DataException e) {
151
                        throw new InvalidEntryException(e);
152
                    } finally {
153
                        it.dispose();
154
                    }
155
                }
156
            }
157
        }
158
    }
159

    
160
    public Geometry finish() throws FinishServiceException {
161
        return null;
162
    }
163

    
164
    public void finishAndStore() throws FinishServiceException {
165

    
166
        if (featureSelection != null) {
167

    
168
            GeometryManager geometryManager =
169
                GeometryLocator.getGeometryManager();
170

    
171
            EditingProviderServices editingProviderServices =
172
                (EditingProviderServices) getProviderServices();
173

    
174
            DisposableIterator it = null;
175
            try {
176
                it = featureSelection.fastIterator();
177
                while (it.hasNext()) {
178
                    Feature feature = (Feature) it.next();
179
                    EditableFeature eFeature = feature.getEditable();
180
                    Geometry geometry = feature.getDefaultGeometry();
181

    
182
                    if (geometry.getGeometryType().isTypeOf(TYPES.CURVE)) {
183

    
184
                        eFeature.setDefaultGeometry(geometry.toLines().getPrimitiveAt(0));
185

    
186
                    } else if (geometry.getGeometryType().isTypeOf(TYPES.MULTICURVE)) {
187

    
188
                        eFeature.setDefaultGeometry(geometry.toLines());
189
                    }
190
                    DisposeUtils.disposeQuietly(featureSelection);
191
                    editingProviderServices.updateFeatureInFeatureStore(
192
                        eFeature, featureStore);
193
                }
194

    
195
                featureStore.getFeatureSelection().deselectAll();
196
            } catch (BaseException e) {
197
                throw new FinishServiceException(e);
198
            } finally {
199
                it.dispose();
200
            }
201

    
202
        }
203
    }
204

    
205
    private Line convertCurveToLine(Curve curve) throws CreateGeometryException {
206
        GeometryManager geometryManager = GeometryLocator.getGeometryManager();
207
        Line newLine =
208
            geometryManager.createLine(curve.getGeometryType().getSubType());
209
        for (int i = 0; i < curve.getNumVertices(); i++) {
210
            newLine.addVertex(curve.getVertex(i));
211
        }
212
        return newLine;
213
    }
214

    
215
    public void start() throws StartServiceException, InvalidEntryException {
216
        FeatureSelection selected = null;
217
        if (featureStore != null) {
218
            try {
219
                selected = featureStore.getFeatureSelection();
220
            } catch (DataException e) {
221
                throw new StartServiceException(e);
222
            }
223
            if (selected.getSelectedCount() >= 1) {
224
                try {
225
                    setValue(selected);
226
                } catch (InvalidEntryException e) {
227
                    throw new InvalidEntryException(e);
228
                }
229
            }
230
        }
231
    }
232

    
233
    public String getName() {
234
        return ConvertToPolylineEditingProviderFactory.PROVIDER_NAME;
235
    }
236

    
237
    @Override
238
    public Object getValue(EditingServiceParameter parameter) {
239
        if(parameter == this.selectionParameter){
240
            return featureSelection;
241
        }
242
        return null;
243
    }
244
}