Statistics
| Revision:

root / trunk / extensions / extGraph_predes / src / com / iver / cit / gvsig / graph / GenerateNetworkExtension.java @ 8646

History | View | Annotate | Download (8.16 KB)

1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2004 IVER T.I. and Generalitat Valenciana.
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., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
18
 *
19
 * For more information, contact:
20
 *
21
 *  Generalitat Valenciana
22
 *   Conselleria d'Infraestructures i Transport
23
 *   Av. Blasco Ib??ez, 50
24
 *   46010 VALENCIA
25
 *   SPAIN
26
 *
27
 *      +34 963862235
28
 *   gvsig@gva.es
29
 *      www.gvsig.gva.es
30
 *
31
 *    or
32
 *
33
 *   IVER T.I. S.A
34
 *   Salamanca 50
35
 *   46005 Valencia
36
 *   Spain
37
 *
38
 *   +34 963163400
39
 *   dac@iver.es
40
 */
41
package com.iver.cit.gvsig.graph;
42

    
43
import java.io.File;
44

    
45
import javax.swing.ImageIcon;
46
import javax.swing.JOptionPane;
47

    
48
import com.iver.andami.PluginServices;
49
import com.iver.andami.messages.NotificationManager;
50
import com.iver.andami.plugins.Extension;
51
import com.iver.andami.preferences.IPreference;
52
import com.iver.andami.preferences.IPreferenceExtension;
53
import com.iver.andami.ui.mdiManager.IWindow;
54
import com.iver.cit.gvsig.fmap.DriverException;
55
import com.iver.cit.gvsig.fmap.MapContext;
56
import com.iver.cit.gvsig.fmap.MapControl;
57
import com.iver.cit.gvsig.fmap.core.FShape;
58
import com.iver.cit.gvsig.fmap.drivers.DriverIOException;
59
import com.iver.cit.gvsig.fmap.edition.EditionException;
60
import com.iver.cit.gvsig.fmap.edition.writers.dbf.DbfWriter;
61
import com.iver.cit.gvsig.fmap.layers.FLayer;
62
import com.iver.cit.gvsig.fmap.layers.FLyrVect;
63
import com.iver.cit.gvsig.fmap.layers.SingleLayerIterator;
64
import com.iver.cit.gvsig.graph.core.writers.NetworkFileRedWriter;
65
import com.iver.cit.gvsig.graph.core.writers.NetworkGvTableWriter;
66
import com.iver.cit.gvsig.graph.gui.wizard.NetWizard;
67
import com.iver.cit.gvsig.graph.preferences.RoutePage;
68
import com.iver.cit.gvsig.project.documents.view.IProjectView;
69
import com.iver.cit.gvsig.project.documents.view.gui.IView;
70
import com.iver.cit.gvsig.project.documents.view.gui.View;
71
import com.iver.utiles.swing.threads.AbstractMonitorableTask;
72

    
73
public class GenerateNetworkExtension extends Extension implements IPreferenceExtension {
74
        private static final IPreference thePreferencePage = new RoutePage();
75
        
76

    
77
        public void initialize() {
78
        }
79

    
80
        public void execute(String actionCommand) {
81
                IView view = (View) PluginServices.getMDIManager().getActiveWindow();
82
                MapControl mapControl = view.getMapControl();
83
                MapContext map = mapControl.getMapContext();
84
                SingleLayerIterator lyrIterator = new SingleLayerIterator(map
85
                                .getLayers());
86
                while (lyrIterator.hasNext()) {
87
                        FLayer lyr = lyrIterator.next();
88
                        if ((lyr.isActive()) && (lyr instanceof FLyrVect))
89
                        {
90
                                FLyrVect lyrVect = (FLyrVect) lyr;
91
                                int shapeType;
92
                                try {
93
                                        shapeType = lyrVect.getShapeType();
94
                                        if (shapeType == FShape.LINE)
95
                                        {
96
                                                if (actionCommand.equalsIgnoreCase("GENERATE_RED")) {
97
                                                        generateRedNetwork(lyrVect);
98
                                                        return;
99
                                                }
100
                                        }
101
                                } catch (DriverException e) {
102
                                        e.printStackTrace();
103
                                        NotificationManager.addError(e);
104
                                }
105

    
106
                        }
107
                }
108

    
109

    
110
        }
111

    
112

    
113
        private void generateNetwork(FLyrVect lyr) {
114
                NetworkGvTableWriter netBuilder = new NetworkGvTableWriter();
115
                // Por ahora, a pelo, pero hay que sacar un cuadro
116
                // de di?logo para hecer el mapping.
117
                // Tambi?n un cuadro de di?logo para seleccionar
118
                // en qu? tablas quiere escribir, y su formato
119
                // (dbf, postgres, etc)
120
                String fieldType = "tipored"; String fieldDist = "length"; String fieldSense = "sen";
121
                String fieldCost = "cost";
122
                try {
123
                        netBuilder.setLayer(lyr);
124
                        netBuilder.setFieldType(fieldType);
125
                        netBuilder.setFieldDist(fieldDist);
126
                        netBuilder.setFieldSense(fieldSense);
127
                        netBuilder.setFieldCost(fieldCost);
128
                        DbfWriter nodeWriter = new DbfWriter();
129
                        nodeWriter.setFile(new File("c:/nodes.dbf"));
130

    
131
                        DbfWriter edgeWriter = new DbfWriter();
132
                        edgeWriter.setFile(new File("c:/edges.dbf"));
133

    
134
                        netBuilder.setEdgeWriter(edgeWriter);
135
                        netBuilder.setNodeWriter(nodeWriter);
136

    
137
                        netBuilder.writeNetwork();
138
                } catch (DriverException e1) {
139
                        // TODO Auto-generated catch block
140
                        e1.printStackTrace();
141
                } catch (EditionException e1) {
142
                        // TODO Auto-generated catch block
143
                        e1.printStackTrace();
144
                }
145
                JOptionPane.showMessageDialog(null, PluginServices.getText(this, "done"));
146
        }
147

    
148
        
149
        class GenerateRedNetworkTask extends AbstractMonitorableTask{
150
                FLyrVect layer;
151
                File redFile;
152
                NetworkFileRedWriter netBuilder;
153
                /**
154
                 * Constructor
155
                 * */
156
                GenerateRedNetworkTask(FLyrVect layer, File redFile, NetworkFileRedWriter netBuilder){
157
                        this.layer = layer;
158
                        this.redFile = redFile;
159
                        this.netBuilder = netBuilder;
160
                        setInitialStep(0);
161
                        int numShapes;
162
                        try {
163
                                numShapes = layer.getSource().getShapeCount();
164
                                setFinalStep(numShapes);
165
                                setDeterminatedProcess(true);
166
                                setStatusMessage(PluginServices.
167
                                                getText(this, "Generando_red_a_partir_de_capa_lineal"));
168
                        } catch (DriverIOException e) {
169
                                // TODO Auto-generated catch block
170
                                e.printStackTrace();
171
                        }
172
                        
173
                }
174
                
175
                public void run() throws Exception {
176
                        netBuilder.setLayer(layer);
177
                        netBuilder.setCancellableMonitorable(this);
178
                        netBuilder.setRedFile(redFile);
179
                        netBuilder.writeNetwork();
180
                        JOptionPane.showMessageDialog(null, PluginServices.getText(this, "done"));
181
                }        
182
                
183
                public String getNote() {
184
                        return "Procesando linea..."  + 
185
                        " " +
186
                        getCurrentStep()+ 
187
                        " "+
188
                        "de"+
189
                        " "+
190
                        getFinishStep();
191
                }
192

    
193
                public void cancel() {
194
                        setCanceled(true);
195
                }
196
        }
197
        
198
        
199
        private void generateRedNetwork(FLyrVect lyr) {
200
                lyr.createSpatialIndex();
201
                NetworkFileRedWriter netBuilder = new NetworkFileRedWriter();
202
                // Por ahora, a pelo, pero hay que sacar un cuadro
203
                // de di?logo para hecer el mapping.
204
                // Tambi?n un cuadro de di?logo para seleccionar
205
                // en qu? tablas quiere escribir, y su formato
206
                // (dbf, postgres, etc)
207

    
208
                ImageIcon icon = new ImageIcon(this.
209
                                getClass().
210
                                getClassLoader().
211
                                getResource("images/net-wizard-logo.jpg"));
212

    
213
                NetWizard wiz = new NetWizard(icon, lyr);
214
                PluginServices.getMDIManager().addWindow(wiz);
215
                if(!wiz.wasFinishPressed())
216
                        return;
217
//                try {
218
                        String fieldType = wiz.getFieldType();
219
                        String fieldLength = wiz.getFieldLength();
220
                        String fieldCost = wiz.getFieldCost();
221
                        String fieldSense = wiz.getFieldSense();
222
                        netBuilder.setLayer(lyr);
223
                        netBuilder.setFieldType(fieldType);
224
                        netBuilder.setFieldDist(fieldLength);
225
                        netBuilder.setFieldSense(fieldSense);
226
                        netBuilder.setFieldCost(fieldCost);
227
                        File redFile = NetworkUtils.getNetworkFile(lyr);
228
                        
229
                        
230
//                        netBuilder.createRedFile(lyr, redFile);
231
                        
232
                        GenerateRedNetworkTask task = new GenerateRedNetworkTask(lyr, redFile, netBuilder);
233
                        PluginServices.cancelableBackgroundExecution(task);
234
                        
235
                        
236
//                } catch (DriverException e1) {
237
//                        // TODO Auto-generated catch block
238
//                        e1.printStackTrace();
239
//
240
//                }
241
//                JOptionPane.showMessageDialog(null, PluginServices.getText(this, "done"));
242

    
243
        }
244

    
245

    
246
        public boolean isEnabled() {
247
                return true;
248
        }
249

    
250
        public boolean isVisible() {
251
                IWindow f = PluginServices.getMDIManager().getActiveWindow();
252

    
253
                if (f == null) {
254
                        return false;
255
                }
256

    
257
                if (f instanceof View) {
258
                        View vista = (View) f;
259
                        IProjectView model = vista.getModel();
260
                        MapContext mapa = model.getMapContext();
261
                        FLayer[] activeLayers = mapa.getLayers().getActives();
262
                        if (activeLayers.length > 0)
263
                                if (activeLayers[0] instanceof FLyrVect){
264
                                        FLyrVect lyrVect = (FLyrVect) activeLayers[0];
265
                                        int shapeType ;
266
                                        try {
267
                                                shapeType = lyrVect.getShapeType();
268
                                                if (shapeType == FShape.LINE)
269
                                                        return true;
270
                                        } catch (DriverException e) {
271
                                                // TODO Auto-generated catch block
272
                                                e.printStackTrace();
273
                                        }
274
                                }        
275
                }
276
                return false;
277

    
278
        }
279

    
280
        public IPreference getPreferencesPage() {
281
                return thePreferencePage;
282
        }
283

    
284
}