Statistics
| Revision:

gvsig-raster / org.gvsig.raster / branches / org.gvsig.raster.2.4 / org.gvsig.wms / org.gvsig.wms.app / org.gvsig.wms.app.mainplugin / src / main / java / org / gvsig / wms / app / mainplugin / WMSAddLayerPanel.java @ 8841

History | View | Annotate | Download (8.02 KB)

1
/* gvSIG. Desktop Geographic Information System.
2
 *
3
 * Copyright ? 2007-2018 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.wms.app.mainplugin;
24

    
25
import java.awt.BorderLayout;
26
import java.io.File;
27
import java.util.List;
28

    
29
import javax.swing.JOptionPane;
30

    
31
import org.slf4j.Logger;
32
import org.slf4j.LoggerFactory;
33

    
34
import org.gvsig.andami.Launcher;
35
import org.gvsig.app.ApplicationLocator;
36
import org.gvsig.app.ApplicationManager;
37
import org.gvsig.app.gui.WizardPanel;
38
import org.gvsig.app.project.documents.view.toc.actions.LayerErrorsPanel;
39
import org.gvsig.fmap.dal.DALLocator;
40
import org.gvsig.fmap.dal.DataManager;
41
import org.gvsig.fmap.dal.DataStoreParameters;
42
import org.gvsig.fmap.dal.exception.DataException;
43
import org.gvsig.fmap.dal.raster.api.RasterCache;
44
import org.gvsig.fmap.dal.raster.api.RasterStore;
45
import org.gvsig.fmap.mapcontext.MapContext;
46
import org.gvsig.fmap.mapcontext.MapContextLocator;
47
import org.gvsig.fmap.mapcontext.MapContextManager;
48
import org.gvsig.fmap.mapcontext.layers.FLayer;
49
import org.gvsig.fmap.mapcontext.layers.FLayers;
50
import org.gvsig.tools.ToolsLocator;
51
import org.gvsig.tools.dispose.DisposeUtils;
52
import org.gvsig.tools.dynobject.DynObject;
53
import org.gvsig.tools.i18n.I18nManager;
54
import org.gvsig.tools.identitymanagement.UnauthorizedException;
55
import org.gvsig.tools.swing.api.ToolsSwingLocator;
56
import org.gvsig.tools.swing.api.windowmanager.WindowManager;
57
import org.gvsig.wms.provider.WMSLayerNode;
58
import org.gvsig.wms.provider.WMSRasterProviderParameters;
59
import org.gvsig.wms.swing.api.WMSParametersPanel;
60
import org.gvsig.wms.swing.api.WMSSwingLocator;
61

    
62
/**
63
 * @author fdiaz
64
 *
65
 */
66
public class WMSAddLayerPanel extends WizardPanel {
67

    
68
    /**
69
     *
70
     */
71
    private static final long serialVersionUID = 208280947322242604L;
72
    private WMSParametersPanel panel = null;
73
    private static final Logger logger = LoggerFactory.getLogger(WMSAddLayerPanel.class);
74

    
75
    /**
76
     *
77
     */
78
    public WMSAddLayerPanel() {
79
        // TODO Auto-generated constructor stub
80
    }
81

    
82
    /*
83
     * (non-Javadoc)
84
     *
85
     * @see org.gvsig.app.gui.WizardPanel#initWizard()
86
     */
87
    @Override
88
    public void initWizard() {
89
        I18nManager i18nManager = ToolsLocator.getI18nManager();
90
        setTabName(i18nManager.getTranslation("WMS"));
91

    
92
        this.setLayout(new BorderLayout());
93
        panel = WMSSwingLocator.getManager().createWMSParametersPanel();
94

    
95
        if (this.getMapCtrl() == null) {
96
            throw new IllegalArgumentException("MapControl need");
97
        }
98
        MapContext mapContext = this.getMapContext();
99
        panel.setPreferredProjection(mapContext.getProjection());
100

    
101

    
102
        this.add(panel.asJComponent(), BorderLayout.CENTER);
103
    }
104

    
105
    /*
106
     * (non-Javadoc)
107
     *
108
     * @see org.gvsig.app.gui.WizardPanel#execute()
109
     */
110
    @Override
111
    public void execute() {
112
        if (this.getMapCtrl() == null) {
113
            throw new IllegalArgumentException("MapControl need");
114
        }
115
        final MapContext mapContext = this.getMapContext();
116

    
117
        final WMSLayerNode node = this.panel.getParameters();
118
        Thread task = new Thread(new Runnable() {
119

    
120
            @Override
121
            public void run() {
122
                FLayer layer = createLayersTree(mapContext, node);
123
                getMapCtrl().addLayer(layer);
124
                mapContext.invalidate();
125
                DisposeUtils.dispose(layer);
126
            }
127
        });
128
        task.start();
129
        logger.info("LayersTree added");
130

    
131
    }
132

    
133
    private FLayer createLayersTree(final MapContext mapContext, final WMSLayerNode node) {
134
        if (node.isLeaf()) {
135
            FLayer layer = createSingleLayer(node.getTitle(), node.getParameters());
136
            return layer;
137
        } else {
138
            FLayers group = mapContext.getNewGroupLayer(null);
139
            group.setName(node.getTitle());
140
            logger.info("addGroup('{}',...)", group.getName());
141
            for (int i = 0; i < node.getChildCount(); i++) {
142
                FLayer layer = createLayersTree(mapContext, (WMSLayerNode) node.getChildAt(i));
143
                group.addLayer(layer);
144
                DisposeUtils.disposeQuietly(layer);
145
            }
146
            return group;
147
        }
148
    }
149

    
150
    private FLayer createSingleLayer(final String layerName, final DataStoreParameters parameters) {
151
        final MapContextManager manager = MapContextLocator.getMapContextManager();
152

    
153
        logger.info("addLayer('{}',...)", layerName);
154

    
155
        FLayer layer = null;
156
        try {
157
            DataManager dataManager = DALLocator.getDataManager();
158
            RasterStore store = (RasterStore) dataManager.openStore(parameters.getDataStoreName(), parameters);
159

    
160
            if (panel.isTiled()) {
161
                DynObject tileParameters = dataManager.createStoreParameters("TileCache");
162

    
163
                File rootFolder = new File(Launcher.getAppHomeDir() + File.separator + "gvsig_rcache");
164

    
165
                if (tileParameters.getDynClass().getDynField("rootFolder") != null) {
166
                    tileParameters.setDynValue("rootFolder", rootFolder);
167
                }
168

    
169
                try {
170
                    store.useCache("TileCache", tileParameters);
171
                    if(panel.refreshLocalCache()){
172
                        RasterCache cache = store.getCache();
173
                        cache.deleteAll();
174
                    }
175
                } catch (DataException e) {
176
                    logger.warn("Can't cache the layer.", e);
177
                }
178

    
179
            }
180

    
181
            layer = manager.createLayer(layerName, store);
182
            DisposeUtils.disposeQuietly(store);
183
            return layer;
184
        } catch (UnauthorizedException e) {
185
            I18nManager i18nManager = ToolsLocator.getI18nManager();
186
            ApplicationManager application = ApplicationLocator.getManager();
187
            String resource = ""; // FIXME: coger el server de los parametros
188
            application.messageDialog(
189
                i18nManager.getTranslation("_User_0_is_not_authorized_to_1_on_resource_2_3", new String[] {
190
                    e.getIdentity().getID(), e.getActionName(), e.getResourceName(), resource }),
191
                i18nManager.getTranslation("_Unauthorized_access"), JOptionPane.WARNING_MESSAGE);
192
            logger.warn("Unauthorized access to layer '" + layerName + "'.", e);
193
        } catch (Exception e) {
194
            LayerErrorsPanel panel = new LayerErrorsPanel(layerName, e);
195
            panel.setLayer(layer);
196

    
197
            I18nManager i18nManager = ToolsLocator.getI18nManager();
198
            ToolsSwingLocator.getWindowManager().showWindow(panel,
199
                i18nManager.getTranslation("_Problems_loading_the_layer"), WindowManager.MODE.WINDOW);
200
            logger.warn("Can't load layer '" + layerName + "'.", e);
201

    
202
        }
203
        return null;
204

    
205
    }
206

    
207
    /*
208
     * (non-Javadoc)
209
     *
210
     * @see org.gvsig.app.gui.WizardPanel#close()
211
     */
212
    @Override
213
    public void close() {
214
        this.dispose();
215
    }
216

    
217
    /**
218
     * Dispose filters and explorer
219
     */
220
    public void dispose() {
221
        panel.dispose();
222
    }
223

    
224
    @Override
225
    public DataStoreParameters[] getParameters() {
226

    
227
        List<WMSRasterProviderParameters> parametersList = this.panel.getParameters().getAllChildren();
228
        return parametersList.toArray(new DataStoreParameters[parametersList.size()]);
229
    }
230

    
231

    
232
}