1 | // License: GPL. v2 and later. Copyright 2008-2009 by Pieren <pieren3@gmail.com> and others
|
---|
2 | package cadastre_fr;
|
---|
3 |
|
---|
4 | import static org.openstreetmap.josm.tools.I18n.tr;
|
---|
5 |
|
---|
6 | import java.awt.GridBagLayout;
|
---|
7 | import java.awt.event.ActionEvent;
|
---|
8 | import java.awt.event.ActionListener;
|
---|
9 | import javax.swing.*;
|
---|
10 |
|
---|
11 | import org.openstreetmap.josm.Main;
|
---|
12 | import org.openstreetmap.josm.gui.preferences.DefaultTabPreferenceSetting;
|
---|
13 | import org.openstreetmap.josm.gui.preferences.PreferenceTabbedPane;
|
---|
14 | import org.openstreetmap.josm.tools.GBC;
|
---|
15 | import org.openstreetmap.josm.tools.I18n;
|
---|
16 | import org.openstreetmap.josm.tools.ImageProvider;
|
---|
17 |
|
---|
18 | /**
|
---|
19 | * Preference settings for the French Cadastre plugin
|
---|
20 | *
|
---|
21 | * @author Pieren <pieren3@gmail.com>
|
---|
22 | */
|
---|
23 | public class CadastrePreferenceSetting extends DefaultTabPreferenceSetting {
|
---|
24 |
|
---|
25 | static final int TRANS_MIN = 1;
|
---|
26 | static final int TRANS_MAX = 10;
|
---|
27 | private JSlider sliderTrans = new JSlider(JSlider.HORIZONTAL, TRANS_MIN, TRANS_MAX, TRANS_MAX);
|
---|
28 |
|
---|
29 | private JTextField sourcing = new JTextField(20);
|
---|
30 |
|
---|
31 | private JCheckBox alterColors = new JCheckBox(tr("Replace original background by JOSM background color."));
|
---|
32 |
|
---|
33 | private JCheckBox reversGrey = new JCheckBox(tr("Reverse grey colors (for black backgrounds)."));
|
---|
34 |
|
---|
35 | private JCheckBox transparency = new JCheckBox(tr("Set background transparent."));
|
---|
36 |
|
---|
37 | private JCheckBox drawBoundaries = new JCheckBox(tr("Draw boundaries of downloaded data."));
|
---|
38 |
|
---|
39 | private JComboBox imageInterpolationMethod = new JComboBox();
|
---|
40 |
|
---|
41 | private JCheckBox disableImageCropping = new JCheckBox(tr("Disable image cropping during georeferencing."));
|
---|
42 |
|
---|
43 | private JCheckBox enableTableauAssemblage = new JCheckBox(tr("Use \"Tableau d''assemblage\""));
|
---|
44 |
|
---|
45 | private JCheckBox simplify2BitsColors = new JCheckBox(tr("Replace grey shades by white color only"));
|
---|
46 |
|
---|
47 | private JCheckBox autoFirstLayer = new JCheckBox(tr("Select first WMS layer in list."));
|
---|
48 |
|
---|
49 | private JCheckBox dontUseRelation = new JCheckBox(tr("Don''t use relation for addresses (but \"addr:street\" on elements)."));
|
---|
50 |
|
---|
51 | private JRadioButton grabMultiplier1 = new JRadioButton("", true);
|
---|
52 |
|
---|
53 | private JRadioButton grabMultiplier2 = new JRadioButton("", true);
|
---|
54 |
|
---|
55 | private JRadioButton grabMultiplier3 = new JRadioButton("", true);
|
---|
56 |
|
---|
57 | private JRadioButton grabMultiplier4 = new JRadioButton("", true);
|
---|
58 |
|
---|
59 | private JRadioButton crosspiece1 = new JRadioButton(tr("off"));
|
---|
60 |
|
---|
61 | private JRadioButton crosspiece2 = new JRadioButton(tr("25 m"));
|
---|
62 |
|
---|
63 | private JRadioButton crosspiece3 = new JRadioButton(tr("50 m"));
|
---|
64 |
|
---|
65 | private JRadioButton crosspiece4 = new JRadioButton(tr("100 m"));
|
---|
66 |
|
---|
67 | private JRadioButton grabRes1 = new JRadioButton(tr("high"));
|
---|
68 | private JRadioButton grabRes2 = new JRadioButton(tr("medium"));
|
---|
69 | private JRadioButton grabRes3 = new JRadioButton(tr("low"));
|
---|
70 |
|
---|
71 | private JCheckBox layerLS3 = new JCheckBox(tr("water"));
|
---|
72 | private JCheckBox layerLS2 = new JCheckBox(tr("building"));
|
---|
73 | private JCheckBox layerLS1 = new JCheckBox(tr("symbol"));
|
---|
74 | private JCheckBox layerParcel = new JCheckBox(tr("parcel"));
|
---|
75 | private JCheckBox layerLabel = new JCheckBox(tr("parcel number"));
|
---|
76 | private JCheckBox layerNumero = new JCheckBox(tr("address"));
|
---|
77 | private JCheckBox layerLieudit = new JCheckBox(tr("locality"));
|
---|
78 | private JCheckBox layerSection = new JCheckBox(tr("section"));
|
---|
79 | private JCheckBox layerCommune = new JCheckBox(tr("commune"));
|
---|
80 |
|
---|
81 | static final int DEFAULT_SQUARE_SIZE = 100;
|
---|
82 | private JTextField grabMultiplier4Size = new JTextField(5);
|
---|
83 |
|
---|
84 | private JCheckBox enableCache = new JCheckBox(tr("Enable automatic caching."));
|
---|
85 |
|
---|
86 | static final int DEFAULT_CACHE_SIZE = 0; // disabled by default
|
---|
87 | JLabel jLabelCacheSize = new JLabel(tr("Max. cache size (in MB)"));
|
---|
88 | private JTextField cacheSize = new JTextField(20);
|
---|
89 |
|
---|
90 | static final String DEFAULT_RASTER_DIVIDER = "7";
|
---|
91 | private JTextField rasterDivider = new JTextField(10);
|
---|
92 |
|
---|
93 | static final int DEFAULT_CROSSPIECES = 0;
|
---|
94 |
|
---|
95 | static final String DEFAULT_GRAB_MULTIPLIER = Scale.SQUARE_100M.value;
|
---|
96 |
|
---|
97 | public CadastrePreferenceSetting() {
|
---|
98 | super("cadastrewms.gif", I18n.tr("French cadastre WMS"),
|
---|
99 | tr("A special handler of the French cadastre wms at www.cadastre.gouv.fr" + "<BR><BR>"
|
---|
100 | + "Please read the Terms and Conditions of Use here (in French): <br>"
|
---|
101 | + "<a href=\"http://www.cadastre.gouv.fr/scpc/html/CU_01_ConditionsGenerales_fr.html\"> "
|
---|
102 | + "http://www.cadastre.gouv.fr/scpc/html/CU_01_ConditionsGenerales_fr.html</a> <BR>"
|
---|
103 | + "before any upload of data created by this plugin.")
|
---|
104 | );
|
---|
105 | }
|
---|
106 |
|
---|
107 |
|
---|
108 | public void addGui(final PreferenceTabbedPane gui) {
|
---|
109 | JPanel cadastrewmsMast = gui.createPreferenceTab(this);
|
---|
110 |
|
---|
111 | JPanel cadastrewms = new JPanel(new GridBagLayout());
|
---|
112 | cadastrewms.setBorder(BorderFactory.createEmptyBorder(0,0,0,0));
|
---|
113 |
|
---|
114 | // option to automatically set the source tag when uploading
|
---|
115 | sourcing.setText(CadastrePlugin.source);
|
---|
116 | sourcing.setToolTipText(tr("<html>Value of key \"source\" when autosourcing is enabled</html>"));
|
---|
117 | JLabel jLabelSource = new JLabel(tr("Source"));
|
---|
118 | cadastrewms.add(jLabelSource, GBC.eop().insets(0, 0, 0, 0));
|
---|
119 | cadastrewms.add(sourcing, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 0, 0, 5));
|
---|
120 |
|
---|
121 | // option to alter the original colors of the wms images
|
---|
122 | alterColors.setSelected(Main.pref.getBoolean("cadastrewms.alterColors", false));
|
---|
123 | alterColors.setToolTipText(tr("Replace the original white background by the background color defined in JOSM preferences."));
|
---|
124 | cadastrewms.add(alterColors, GBC.eop().insets(0, 0, 0, 0));
|
---|
125 |
|
---|
126 | // option to reverse the grey colors (to see texts background)
|
---|
127 | reversGrey.setSelected(Main.pref.getBoolean("cadastrewms.invertGrey", false));
|
---|
128 | reversGrey.setToolTipText(tr("Invert the original black and white colors (and all intermediate greys). Useful for texts on dark backgrounds."));
|
---|
129 | cadastrewms.add(reversGrey, GBC.eop().insets(0, 0, 0, 0));
|
---|
130 |
|
---|
131 | // option to enable transparency
|
---|
132 | transparency.addActionListener(new ActionListener() {
|
---|
133 | public void actionPerformed(ActionEvent e) {
|
---|
134 | sliderTrans.setEnabled(transparency.isSelected());
|
---|
135 | }
|
---|
136 | });
|
---|
137 | transparency.setSelected(Main.pref.getBoolean("cadastrewms.backgroundTransparent", false));
|
---|
138 | transparency.setToolTipText(tr("Allows multiple layers stacking"));
|
---|
139 | cadastrewms.add(transparency, GBC.eop().insets(0, 0, 0, 0));
|
---|
140 |
|
---|
141 | // slider for transparency level
|
---|
142 | sliderTrans.setSnapToTicks(true);
|
---|
143 | sliderTrans.setToolTipText(tr("Set WMS layers transparency. Right is opaque, left is transparent."));
|
---|
144 | sliderTrans.setMajorTickSpacing(10);
|
---|
145 | sliderTrans.setMinorTickSpacing(1);
|
---|
146 | sliderTrans.setValue((int)(Float.parseFloat(Main.pref.get("cadastrewms.brightness", "1.0f"))*10));
|
---|
147 | sliderTrans.setPaintTicks(true);
|
---|
148 | sliderTrans.setPaintLabels(false);
|
---|
149 | sliderTrans.setEnabled(transparency.isSelected());
|
---|
150 | cadastrewms.add(sliderTrans, GBC.eol().fill(GBC.HORIZONTAL).insets(20, 0, 250, 0));
|
---|
151 |
|
---|
152 | // option to draw boundaries of downloaded data
|
---|
153 | drawBoundaries.setSelected(Main.pref.getBoolean("cadastrewms.drawBoundaries", false));
|
---|
154 | drawBoundaries.setToolTipText(tr("Draw a rectangle around downloaded data from WMS server."));
|
---|
155 | cadastrewms.add(drawBoundaries, GBC.eop().insets(0, 0, 0, 5));
|
---|
156 |
|
---|
157 | // option to select the single grabbed image resolution
|
---|
158 | JLabel jLabelRes = new JLabel(tr("Image resolution:"));
|
---|
159 | cadastrewms.add(jLabelRes, GBC.std().insets(0, 5, 10, 0));
|
---|
160 | ButtonGroup bgResolution = new ButtonGroup();
|
---|
161 | grabRes1.setToolTipText(tr("High resolution (1000x800)"));
|
---|
162 | grabRes2.setToolTipText(tr("Medium resolution (800x600)"));
|
---|
163 | grabRes3.setToolTipText(tr("Low resolution (600x400)"));
|
---|
164 | bgResolution.add(grabRes1);
|
---|
165 | bgResolution.add(grabRes2);
|
---|
166 | bgResolution.add(grabRes3);
|
---|
167 | String currentResolution = Main.pref.get("cadastrewms.resolution", "high");
|
---|
168 | if (currentResolution.equals("high"))
|
---|
169 | grabRes1.setSelected(true);
|
---|
170 | if (currentResolution.equals("medium"))
|
---|
171 | grabRes2.setSelected(true);
|
---|
172 | if (currentResolution.equals("low"))
|
---|
173 | grabRes3.setSelected(true);
|
---|
174 | cadastrewms.add(grabRes1, GBC.std().insets(5, 0, 5, 0));
|
---|
175 | cadastrewms.add(grabRes2, GBC.std().insets(5, 0, 5, 0));
|
---|
176 | cadastrewms.add(grabRes3, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
|
---|
177 |
|
---|
178 | // option to select image zooming interpolation method
|
---|
179 | JLabel jLabelImageZoomInterpolation = new JLabel(tr("Image filter interpolation:"));
|
---|
180 | cadastrewms.add(jLabelImageZoomInterpolation, GBC.std().insets(0, 0, 10, 0));
|
---|
181 | imageInterpolationMethod.addItem(tr("Nearest-Neighbor (fastest) [ Default ]"));
|
---|
182 | imageInterpolationMethod.addItem(tr("Bilinear (fast)"));
|
---|
183 | imageInterpolationMethod.addItem(tr("Bicubic (slow)"));
|
---|
184 | String savedImageInterpolationMethod = Main.pref.get("cadastrewms.imageInterpolation", "standard");
|
---|
185 | if (savedImageInterpolationMethod.equals("bilinear"))
|
---|
186 | imageInterpolationMethod.setSelectedIndex(1);
|
---|
187 | else if (savedImageInterpolationMethod.equals("bicubic"))
|
---|
188 | imageInterpolationMethod.setSelectedIndex(2);
|
---|
189 | else
|
---|
190 | imageInterpolationMethod.setSelectedIndex(0);
|
---|
191 | cadastrewms.add(imageInterpolationMethod, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
|
---|
192 |
|
---|
193 | // separator
|
---|
194 | cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
|
---|
195 |
|
---|
196 | // the vectorized images multiplier
|
---|
197 | JLabel jLabelScale = new JLabel(tr("Vector images grab multiplier:"));
|
---|
198 | cadastrewms.add(jLabelScale, GBC.std().insets(0, 5, 10, 0));
|
---|
199 | ButtonGroup bgGrabMultiplier = new ButtonGroup();
|
---|
200 | ActionListener multiplierActionListener = new ActionListener() {
|
---|
201 | public void actionPerformed(ActionEvent actionEvent) {
|
---|
202 | AbstractButton button = (AbstractButton) actionEvent.getSource();
|
---|
203 | grabMultiplier4Size.setEnabled(button == grabMultiplier4);
|
---|
204 | }
|
---|
205 | };
|
---|
206 | grabMultiplier1.setIcon(ImageProvider.get("preferences", "unsel_box_1"));
|
---|
207 | grabMultiplier1.setSelectedIcon(ImageProvider.get("preferences", "sel_box_1"));
|
---|
208 | grabMultiplier1.addActionListener( multiplierActionListener);
|
---|
209 | grabMultiplier1.setToolTipText(tr("Grab one image full screen"));
|
---|
210 | grabMultiplier2.setIcon(ImageProvider.get("preferences", "unsel_box_2"));
|
---|
211 | grabMultiplier2.setSelectedIcon(ImageProvider.get("preferences", "sel_box_2"));
|
---|
212 | grabMultiplier2.addActionListener( multiplierActionListener);
|
---|
213 | grabMultiplier2.setToolTipText(tr("Grab smaller images (higher quality but use more memory)"));
|
---|
214 | grabMultiplier3.setIcon(ImageProvider.get("preferences", "unsel_box_3"));
|
---|
215 | grabMultiplier3.setSelectedIcon(ImageProvider.get("preferences", "sel_box_3"));
|
---|
216 | grabMultiplier3.addActionListener( multiplierActionListener);
|
---|
217 | grabMultiplier3.setToolTipText(tr("Grab smaller images (higher quality but use more memory)"));
|
---|
218 | grabMultiplier4.setIcon(ImageProvider.get("preferences", "unsel_box_4"));
|
---|
219 | grabMultiplier4.setSelectedIcon(ImageProvider.get("preferences", "sel_box_4"));
|
---|
220 | grabMultiplier4.addActionListener( multiplierActionListener);
|
---|
221 | grabMultiplier4.setToolTipText(tr("Fixed size square (default is 100m)"));
|
---|
222 | bgGrabMultiplier.add(grabMultiplier1);
|
---|
223 | bgGrabMultiplier.add(grabMultiplier2);
|
---|
224 | bgGrabMultiplier.add(grabMultiplier3);
|
---|
225 | bgGrabMultiplier.add(grabMultiplier4);
|
---|
226 | String currentScale = Main.pref.get("cadastrewms.scale", DEFAULT_GRAB_MULTIPLIER);
|
---|
227 | if (currentScale.equals(Scale.X1.value))
|
---|
228 | grabMultiplier1.setSelected(true);
|
---|
229 | if (currentScale.equals(Scale.X2.value))
|
---|
230 | grabMultiplier2.setSelected(true);
|
---|
231 | if (currentScale.equals(Scale.X3.value))
|
---|
232 | grabMultiplier3.setSelected(true);
|
---|
233 | if (currentScale.equals(Scale.SQUARE_100M.value))
|
---|
234 | grabMultiplier4.setSelected(true);
|
---|
235 | cadastrewms.add(grabMultiplier1, GBC.std().insets(5, 0, 5, 0));
|
---|
236 | cadastrewms.add(grabMultiplier2, GBC.std().insets(5, 0, 5, 0));
|
---|
237 | cadastrewms.add(grabMultiplier3, GBC.std().insets(5, 0, 5, 0));
|
---|
238 | cadastrewms.add(grabMultiplier4, GBC.std().insets(5, 0, 5, 0));
|
---|
239 | int squareSize = getNumber("cadastrewms.squareSize", DEFAULT_SQUARE_SIZE);
|
---|
240 | grabMultiplier4Size.setText(String.valueOf(squareSize));
|
---|
241 | grabMultiplier4Size.setToolTipText(tr("Fixed size (from 25 to 1000 meters)"));
|
---|
242 | grabMultiplier4Size.setEnabled(currentScale.equals(Scale.SQUARE_100M.value));
|
---|
243 | cadastrewms.add(grabMultiplier4Size, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
|
---|
244 |
|
---|
245 | // WMS layers selection
|
---|
246 | JLabel jLabelLayers = new JLabel(tr("Layers:"));
|
---|
247 | cadastrewms.add(jLabelLayers, GBC.std().insets(0, 5, 10, 0));
|
---|
248 | layerLS3.setSelected(Main.pref.getBoolean("cadastrewms.layerWater", true));
|
---|
249 | layerLS3.setToolTipText(tr("See, rivers, swimming pools."));
|
---|
250 | cadastrewms.add(layerLS3, GBC.std().insets(5, 0, 5, 0));
|
---|
251 | layerLS2.setSelected(Main.pref.getBoolean("cadastrewms.layerBuilding", true));
|
---|
252 | layerLS2.setToolTipText(tr("Buildings, covers, underground constructions."));
|
---|
253 | cadastrewms.add(layerLS2, GBC.std().insets(5, 0, 5, 0));
|
---|
254 | layerLS1.setSelected(Main.pref.getBoolean("cadastrewms.layerSymbol", true));
|
---|
255 | layerLS1.setToolTipText(tr("Symbols like cristian cross."));
|
---|
256 | cadastrewms.add(layerLS1, GBC.std().insets(5, 0, 5, 0));
|
---|
257 | layerParcel.setSelected(Main.pref.getBoolean("cadastrewms.layerParcel", true));
|
---|
258 | layerParcel.setToolTipText(tr("Parcels."));
|
---|
259 | cadastrewms.add(layerParcel, GBC.eop().insets(5, 0, 5, 0));
|
---|
260 | layerLabel.setSelected(Main.pref.getBoolean("cadastrewms.layerLabel", true));
|
---|
261 | layerLabel.setToolTipText(tr("Parcels numbers, street names."));
|
---|
262 | cadastrewms.add(layerLabel, GBC.std().insets(70, 0, 5, 0));
|
---|
263 | layerNumero.setSelected(Main.pref.getBoolean("cadastrewms.layerNumero", true));
|
---|
264 | layerNumero.setToolTipText(tr("Address, houses numbers."));
|
---|
265 | cadastrewms.add(layerNumero, GBC.std().insets(5, 0, 5, 0));
|
---|
266 | layerLieudit.setSelected(Main.pref.getBoolean("cadastrewms.layerLieudit", true));
|
---|
267 | layerLieudit.setToolTipText(tr("Locality, hamlet, place."));
|
---|
268 | cadastrewms.add(layerLieudit, GBC.std().insets(5, 0, 5, 0));
|
---|
269 | layerSection.setSelected(Main.pref.getBoolean("cadastrewms.layerSection", true));
|
---|
270 | layerSection.setToolTipText(tr("Cadastral sections and subsections."));
|
---|
271 | cadastrewms.add(layerSection, GBC.std().insets(5, 0, 5, 0));
|
---|
272 | layerCommune.setSelected(Main.pref.getBoolean("cadastrewms.layerCommune", true));
|
---|
273 | layerCommune.setToolTipText(tr("Municipality administrative borders."));
|
---|
274 | cadastrewms.add(layerCommune, GBC.eop().insets(5, 0, 5, 0));
|
---|
275 |
|
---|
276 | // separator
|
---|
277 | cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
|
---|
278 |
|
---|
279 | // for raster images (not vectorized), image grab divider (from 1 to 12)
|
---|
280 | String savedRasterDivider = Main.pref.get("cadastrewms.rasterDivider", DEFAULT_RASTER_DIVIDER);
|
---|
281 | JLabel jLabelRasterDivider = new JLabel(tr("Raster images grab multiplier:"));
|
---|
282 | rasterDivider.setText(savedRasterDivider);
|
---|
283 | rasterDivider.setToolTipText("Raster image grab division, from 1 to 12; 12 is very high definition");
|
---|
284 | cadastrewms.add(jLabelRasterDivider, GBC.std().insets(0, 5, 10, 0));
|
---|
285 | cadastrewms.add(rasterDivider, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
|
---|
286 | // option to disable image cropping during raster image georeferencing
|
---|
287 | disableImageCropping.setSelected(Main.pref.getBoolean("cadastrewms.noImageCropping", false));
|
---|
288 | disableImageCropping.setToolTipText(tr("Disable image cropping during georeferencing."));
|
---|
289 | cadastrewms.add(disableImageCropping, GBC.std().insets(0, 0, 10, 0));
|
---|
290 | // option to add the "Tableau d'assemblage" in list of sheets to grab
|
---|
291 | enableTableauAssemblage.setSelected(Main.pref.getBoolean("cadastrewms.useTA", false));
|
---|
292 | enableTableauAssemblage.setToolTipText(tr("Add the \"Tableau(x) d''assemblage\" in the list of cadastre sheets to grab."));
|
---|
293 | cadastrewms.add(enableTableauAssemblage, GBC.eop().insets(0, 0, 0, 0));
|
---|
294 | // option to use 2 bits colors only
|
---|
295 | simplify2BitsColors.setSelected(Main.pref.getBoolean("cadastrewms.raster2bitsColors", false));
|
---|
296 | simplify2BitsColors.setToolTipText(tr("Replace greyscale by white color (smaller files and memory usage)."));
|
---|
297 | cadastrewms.add(simplify2BitsColors, GBC.eop().insets(0, 0, 0, 0));
|
---|
298 | // the crosspiece display
|
---|
299 | JLabel jLabelCrosspieces = new JLabel(tr("Display crosspieces:"));
|
---|
300 | cadastrewms.add(jLabelCrosspieces, GBC.std().insets(0, 0, 10, 0));
|
---|
301 | ButtonGroup bgCrosspieces = new ButtonGroup();
|
---|
302 | int crosspieces = getNumber("cadastrewms.crosspieces", DEFAULT_CROSSPIECES);
|
---|
303 | if (crosspieces == 0) crosspiece1.setSelected(true);
|
---|
304 | if (crosspieces == 1) crosspiece2.setSelected(true);
|
---|
305 | if (crosspieces == 2) crosspiece3.setSelected(true);
|
---|
306 | if (crosspieces == 3) crosspiece4.setSelected(true);
|
---|
307 | bgCrosspieces.add(crosspiece1);
|
---|
308 | bgCrosspieces.add(crosspiece2);
|
---|
309 | bgCrosspieces.add(crosspiece3);
|
---|
310 | bgCrosspieces.add(crosspiece4);
|
---|
311 | cadastrewms.add(crosspiece1, GBC.std().insets(5, 0, 5, 0));
|
---|
312 | cadastrewms.add(crosspiece2, GBC.std().insets(5, 0, 5, 0));
|
---|
313 | cadastrewms.add(crosspiece3, GBC.std().insets(5, 0, 5, 0));
|
---|
314 | cadastrewms.add(crosspiece4, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
|
---|
315 |
|
---|
316 | // separator
|
---|
317 | cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
|
---|
318 |
|
---|
319 | // option to enable automatic caching
|
---|
320 | enableCache.addActionListener(new ActionListener() {
|
---|
321 | public void actionPerformed(ActionEvent e) {
|
---|
322 | jLabelCacheSize.setEnabled(enableCache.isSelected());
|
---|
323 | cacheSize.setEnabled(enableCache.isSelected());
|
---|
324 | }
|
---|
325 | });
|
---|
326 | enableCache.setSelected(Main.pref.getBoolean("cadastrewms.enableCaching", true));
|
---|
327 | enableCache.setToolTipText(tr("Allows an automatic caching"));
|
---|
328 | cadastrewms.add(enableCache, GBC.eop().insets(0, 0, 0, 0));
|
---|
329 |
|
---|
330 | // option to fix the cache size(in MB)
|
---|
331 | int size = getNumber("cadastrewms.cacheSize", DEFAULT_CACHE_SIZE);
|
---|
332 | cacheSize.setText(String.valueOf(size));
|
---|
333 | cacheSize.setToolTipText(tr("Oldest files are automatically deleted when this size is exceeded"));
|
---|
334 | cadastrewms.add(jLabelCacheSize, GBC.std().insets(20, 0, 0, 0));
|
---|
335 | cadastrewms.add(cacheSize, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
|
---|
336 |
|
---|
337 | // separator
|
---|
338 | cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
|
---|
339 |
|
---|
340 | // option to select the first WMS layer
|
---|
341 | autoFirstLayer.setSelected(Main.pref.getBoolean("cadastrewms.autoFirstLayer", false));
|
---|
342 | autoFirstLayer.setToolTipText(tr("Automatically selects the first WMS layer if multiple layers exist when grabbing."));
|
---|
343 | cadastrewms.add(autoFirstLayer, GBC.eop().insets(0, 0, 0, 0));
|
---|
344 |
|
---|
345 | // separator
|
---|
346 | cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
|
---|
347 |
|
---|
348 | // option to use or not relations in addresses
|
---|
349 | dontUseRelation.setSelected(Main.pref.getBoolean("cadastrewms.addr.dontUseRelation", false));
|
---|
350 | dontUseRelation.setToolTipText(tr("Enable this to use the tag \"add:street\" on nodes."));
|
---|
351 | cadastrewms.add(dontUseRelation, GBC.eop().insets(0, 0, 0, 0));
|
---|
352 |
|
---|
353 | // end of dialog, scroll bar
|
---|
354 | cadastrewms.add(Box.createVerticalGlue(), GBC.eol().fill(GBC.VERTICAL));
|
---|
355 | JScrollPane scrollpane = new JScrollPane(cadastrewms);
|
---|
356 | scrollpane.setBorder(BorderFactory.createEmptyBorder( 0, 0, 0, 0 ));
|
---|
357 | cadastrewmsMast.add(scrollpane, GBC.eol().fill(GBC.BOTH));
|
---|
358 | }
|
---|
359 |
|
---|
360 | public boolean ok() {
|
---|
361 | Main.pref.put("cadastrewms.source", sourcing.getText());
|
---|
362 | CadastrePlugin.source = sourcing.getText();
|
---|
363 | Main.pref.put("cadastrewms.alterColors", alterColors.isSelected());
|
---|
364 | Main.pref.put("cadastrewms.invertGrey", reversGrey.isSelected());
|
---|
365 | Main.pref.put("cadastrewms.backgroundTransparent", transparency.isSelected());
|
---|
366 | Main.pref.put("cadastrewms.brightness", Float.toString((float)sliderTrans.getValue()/10));
|
---|
367 | Main.pref.put("cadastrewms.drawBoundaries", drawBoundaries.isSelected());
|
---|
368 | if (grabRes1.isSelected())
|
---|
369 | Main.pref.put("cadastrewms.resolution", "high");
|
---|
370 | else if (grabRes2.isSelected())
|
---|
371 | Main.pref.put("cadastrewms.resolution", "medium");
|
---|
372 | else if (grabRes3.isSelected())
|
---|
373 | Main.pref.put("cadastrewms.resolution", "low");
|
---|
374 | if (imageInterpolationMethod.getSelectedIndex() == 2)
|
---|
375 | Main.pref.put("cadastrewms.imageInterpolation", "bicubic");
|
---|
376 | else if (imageInterpolationMethod.getSelectedIndex() == 1)
|
---|
377 | Main.pref.put("cadastrewms.imageInterpolation", "bilinear");
|
---|
378 | else
|
---|
379 | Main.pref.put("cadastrewms.imageInterpolation", "standard");
|
---|
380 | if (grabMultiplier1.isSelected())
|
---|
381 | Main.pref.put("cadastrewms.scale", Scale.X1.toString());
|
---|
382 | else if (grabMultiplier2.isSelected())
|
---|
383 | Main.pref.put("cadastrewms.scale", Scale.X2.toString());
|
---|
384 | else if (grabMultiplier3.isSelected())
|
---|
385 | Main.pref.put("cadastrewms.scale", Scale.X3.toString());
|
---|
386 | else {
|
---|
387 | Main.pref.put("cadastrewms.scale", Scale.SQUARE_100M.toString());
|
---|
388 | try {
|
---|
389 | int squareSize = Integer.parseInt(grabMultiplier4Size.getText());
|
---|
390 | if (squareSize >= 25 && squareSize <= 1000)
|
---|
391 | Main.pref.put("cadastrewms.squareSize", grabMultiplier4Size.getText());
|
---|
392 | } catch (NumberFormatException e) { // ignore the last input
|
---|
393 | }
|
---|
394 | }
|
---|
395 | Main.pref.put("cadastrewms.layerWater", layerLS3.isSelected());
|
---|
396 | Main.pref.put("cadastrewms.layerBuilding", layerLS2.isSelected());
|
---|
397 | Main.pref.put("cadastrewms.layerSymbol", layerLS1.isSelected());
|
---|
398 | Main.pref.put("cadastrewms.layerParcel", layerParcel.isSelected());
|
---|
399 | Main.pref.put("cadastrewms.layerLabel", layerLabel.isSelected());
|
---|
400 | Main.pref.put("cadastrewms.layerNumero", layerNumero.isSelected());
|
---|
401 | Main.pref.put("cadastrewms.layerLieudit", layerLieudit.isSelected());
|
---|
402 | Main.pref.put("cadastrewms.layerSection", layerSection.isSelected());
|
---|
403 | Main.pref.put("cadastrewms.layerCommune", layerCommune.isSelected());
|
---|
404 | try {
|
---|
405 | int i = Integer.parseInt(rasterDivider.getText());
|
---|
406 | if (i > 0 && i < 13)
|
---|
407 | Main.pref.put("cadastrewms.rasterDivider", String.valueOf(i));
|
---|
408 | } catch (NumberFormatException e) { // ignore the last input
|
---|
409 | }
|
---|
410 | Main.pref.put("cadastrewms.noImageCropping", disableImageCropping.isSelected());
|
---|
411 | Main.pref.put("cadastrewms.useTA", enableTableauAssemblage.isSelected());
|
---|
412 | Main.pref.put("cadastrewms.raster2bitsColors", simplify2BitsColors.isSelected());
|
---|
413 | if (crosspiece1.isSelected()) Main.pref.put("cadastrewms.crosspieces", "0");
|
---|
414 | else if (crosspiece2.isSelected()) Main.pref.put("cadastrewms.crosspieces", "1");
|
---|
415 | else if (crosspiece3.isSelected()) Main.pref.put("cadastrewms.crosspieces", "2");
|
---|
416 | else if (crosspiece4.isSelected()) Main.pref.put("cadastrewms.crosspieces", "3");
|
---|
417 | Main.pref.put("cadastrewms.enableCaching", enableCache.isSelected());
|
---|
418 |
|
---|
419 | // spread data into objects instead of restarting the application
|
---|
420 | try {
|
---|
421 | CacheControl.cacheSize = Integer.parseInt(cacheSize.getText());
|
---|
422 | Main.pref.put("cadastrewms.cacheSize", String.valueOf(CacheControl.cacheSize));
|
---|
423 | } catch (NumberFormatException e) { // ignore the last input
|
---|
424 | }
|
---|
425 | Main.pref.put("cadastrewms.autoFirstLayer", autoFirstLayer.isSelected());
|
---|
426 | CacheControl.cacheEnabled = enableCache.isSelected();
|
---|
427 | Main.pref.put("cadastrewms.addr.dontUseRelation", dontUseRelation.isSelected());
|
---|
428 | CadastrePlugin.refreshConfiguration();
|
---|
429 | CadastrePlugin.refreshMenu();
|
---|
430 |
|
---|
431 | return false;
|
---|
432 | }
|
---|
433 |
|
---|
434 | private int getNumber(String pref_parameter, int def_value) {
|
---|
435 | try {
|
---|
436 | return Integer.parseInt(Main.pref.get(pref_parameter, String.valueOf(def_value)));
|
---|
437 | } catch (NumberFormatException e) {
|
---|
438 | return def_value;
|
---|
439 | }
|
---|
440 | }
|
---|
441 | }
|
---|