source: osm/applications/editors/josm/plugins/cadastre-fr/src/cadastre_fr/CadastrePreferenceSetting.java@ 20240

Last change on this file since 20240 was 20240, checked in by pieren, 14 years ago

Grabbed images resolution configurable + fixed minor issues

  • Property svn:eol-style set to native
File size: 19.2 KB
Line 
1// License: GPL. v2 and later. Copyright 2008-2009 by Pieren <pieren3@gmail.com> and others
2package cadastre_fr;
3
4import static org.openstreetmap.josm.tools.I18n.tr;
5
6import java.awt.event.ActionEvent;
7import java.awt.event.ActionListener;
8import javax.swing.*;
9
10import org.openstreetmap.josm.Main;
11import org.openstreetmap.josm.gui.preferences.PreferenceSetting;
12import org.openstreetmap.josm.gui.preferences.PreferenceTabbedPane;
13import org.openstreetmap.josm.tools.GBC;
14import org.openstreetmap.josm.tools.I18n;
15import org.openstreetmap.josm.tools.ImageProvider;
16
17/**
18 * Preference settings for the French Cadastre plugin
19 *
20 * @author Pieren <pieren3@gmail.com>
21 */
22public class CadastrePreferenceSetting implements PreferenceSetting {
23
24 static final int TRANS_MIN = 1;
25 static final int TRANS_MAX = 10;
26 private JSlider sliderTrans = new JSlider(JSlider.HORIZONTAL, TRANS_MIN, TRANS_MAX, TRANS_MAX);
27
28 private JTextField sourcing = new JTextField(20);
29
30 private JCheckBox alterColors = new JCheckBox(tr("Replace original background by JOSM background color."));
31
32 private JCheckBox reversGrey = new JCheckBox(tr("Reverse grey colors (for black backgrounds)."));
33
34 private JCheckBox transparency = new JCheckBox(tr("Set background transparent."));
35
36 private JCheckBox drawBoundaries = new JCheckBox(tr("Draw boundaries of downloaded data."));
37
38 private JComboBox imageInterpolationMethod = new JComboBox();
39
40 private JCheckBox disableImageCropping = new JCheckBox(tr("Disable image cropping during georeferencing."));
41
42 private JRadioButton grabMultiplier1 = new JRadioButton("", true);
43
44 private JRadioButton grabMultiplier2 = new JRadioButton("", true);
45
46 private JRadioButton grabMultiplier3 = new JRadioButton("", true);
47
48 private JRadioButton grabMultiplier4 = new JRadioButton("", true);
49
50 private JRadioButton crosspiece1 = new JRadioButton("off");
51
52 private JRadioButton crosspiece2 = new JRadioButton("25m");
53
54 private JRadioButton crosspiece3 = new JRadioButton("50m");
55
56 private JRadioButton crosspiece4 = new JRadioButton("100m");
57
58 private JCheckBox autoFirstLayer = new JCheckBox(tr("Automaticly select first WMS layer when grabing if multiple layers exist."));
59
60 private JRadioButton grabRes1 = new JRadioButton("high");
61
62 private JRadioButton grabRes2 = new JRadioButton("medium");
63
64 private JRadioButton grabRes3 = new JRadioButton("low");
65
66 static final int DEFAULT_SQUARE_SIZE = 100;
67 private JTextField grabMultiplier4Size = new JTextField(5);
68
69 private JCheckBox enableCache = new JCheckBox(tr("Enable automatic caching."));
70
71 static final int DEFAULT_CACHE_SIZE = 500;
72 JLabel jLabelCacheSize = new JLabel(tr("Max. cache size (in MB)"));
73 private JTextField cacheSize = new JTextField(20);
74
75 static final String DEFAULT_RASTER_DIVIDER = "5";
76 private JTextField rasterDivider = new JTextField(10);
77
78 static final int DEFAULT_CROSSPIECES = 0;
79
80 public void addGui(final PreferenceTabbedPane gui) {
81
82 String description = tr("A special handler of the French cadastre wms at www.cadastre.gouv.fr" + "<BR><BR>"
83 + "Please read the Terms and Conditions of Use here (in French): <br>"
84 + "<a href=\"http://www.cadastre.gouv.fr/scpc/html/CU_01_ConditionsGenerales_fr.html\"> "
85 + "http://www.cadastre.gouv.fr/scpc/html/CU_01_ConditionsGenerales_fr.html</a> <BR>"
86 + "before any upload of data created by this plugin.");
87 JPanel cadastrewms = gui.createPreferenceTab("cadastrewms.gif", I18n.tr("French cadastre WMS"), description);
88
89 // option to automatically set the source tag when uploading
90 sourcing.setText(CadastrePlugin.source);
91 sourcing.setToolTipText(tr("<html>Value of key \"source\" when autosourcing is enabled</html>"));
92 JLabel jLabelSource = new JLabel(tr("Source"));
93 cadastrewms.add(jLabelSource, GBC.eop().insets(0, 0, 0, 0));
94 cadastrewms.add(sourcing, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 0, 0, 5));
95
96 // option to alter the original colors of the wms images
97 alterColors.setSelected(Main.pref.getBoolean("cadastrewms.alterColors", false));
98 alterColors.setToolTipText(tr("Replace the original white background by the backgound color defined in JOSM preferences."));
99 cadastrewms.add(alterColors, GBC.eop().insets(0, 0, 0, 0));
100
101 // option to reverse the grey colors (to see texts background)
102 reversGrey.setSelected(Main.pref.getBoolean("cadastrewms.invertGrey", false));
103 reversGrey.setToolTipText(tr("Invert the original black and white colors (and all intermediate greys). Useful for texts on dark backgrounds."));
104 cadastrewms.add(reversGrey, GBC.eop().insets(00, 0, 0, 0));
105
106 // option to enable transparency
107 transparency.addActionListener(new ActionListener() {
108 public void actionPerformed(ActionEvent e) {
109 sliderTrans.setEnabled(transparency.isSelected());
110 }
111 });
112 transparency.setSelected(Main.pref.getBoolean("cadastrewms.backgroundTransparent", false));
113 transparency.setToolTipText(tr("Allows multiple layers stacking"));
114 cadastrewms.add(transparency, GBC.eop().insets(0, 0, 0, 0));
115
116 // slider for transparency level
117 sliderTrans.setSnapToTicks(true);
118 sliderTrans.setToolTipText(tr("Set WMS layers transparency. Right is opaque, left is transparent."));
119 sliderTrans.setMajorTickSpacing(10);
120 sliderTrans.setMinorTickSpacing(1);
121 sliderTrans.setValue((int)(Float.parseFloat(Main.pref.get("cadastrewms.brightness", "1.0f"))*10));
122 sliderTrans.setPaintTicks(true);
123 sliderTrans.setPaintLabels(false);
124 sliderTrans.setEnabled(transparency.isSelected());
125 cadastrewms.add(sliderTrans, GBC.eol().fill(GBC.HORIZONTAL).insets(20, 0, 250, 0));
126
127 // option to draw boundaries of downloaded data
128 drawBoundaries.setSelected(Main.pref.getBoolean("cadastrewms.drawBoundaries", false));
129 drawBoundaries.setToolTipText(tr("Draw a rectangle around downloaded data from WMS server."));
130 cadastrewms.add(drawBoundaries, GBC.eop().insets(0, 0, 0, 5));
131
132 // option to select the single grabbed image resolution
133 JLabel jLabelRes = new JLabel(tr("Image resolution:"));
134 cadastrewms.add(jLabelRes, GBC.std().insets(0, 5, 10, 0));
135 ButtonGroup bgResolution = new ButtonGroup();
136 ActionListener resActionListener = new ActionListener() {
137 public void actionPerformed(ActionEvent actionEvent) {
138 AbstractButton button = (AbstractButton) actionEvent.getSource();
139 grabMultiplier4Size.setEnabled(button == grabMultiplier4);
140 }
141 };
142 grabRes1.addActionListener( resActionListener);
143 grabRes1.setToolTipText(tr("High resolution (1000x800)"));
144 grabRes2.addActionListener( resActionListener);
145 grabRes2.setToolTipText(tr("Medium resolution (800x600)"));
146 grabRes3.addActionListener( resActionListener);
147 grabRes3.setToolTipText(tr("Low resolution (600x400)"));
148 bgResolution.add(grabRes1);
149 bgResolution.add(grabRes2);
150 bgResolution.add(grabRes3);
151 String currentResolution = Main.pref.get("cadastrewms.resolution", "high");
152 if (currentResolution.equals("high"))
153 grabRes1.setSelected(true);
154 if (currentResolution.equals("medium"))
155 grabRes2.setSelected(true);
156 if (currentResolution.equals("low"))
157 grabRes3.setSelected(true);
158 cadastrewms.add(grabRes1, GBC.std().insets(5, 0, 5, 0));
159 cadastrewms.add(grabRes2, GBC.std().insets(5, 0, 5, 0));
160 cadastrewms.add(grabRes3, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
161
162 // option to select image zooming interpolation method
163 JLabel jLabelImageZoomInterpolation = new JLabel(tr("Image filter interpolation:"));
164 cadastrewms.add(jLabelImageZoomInterpolation, GBC.std().insets(0, 0, 10, 0));
165 imageInterpolationMethod.addItem(tr("Nearest-Neighbor (fastest) [ Default ]"));
166 imageInterpolationMethod.addItem(tr("Bilinear (fast)"));
167 imageInterpolationMethod.addItem(tr("Bicubic (slow)"));
168 String savedImageInterpolationMethod = Main.pref.get("cadastrewms.imageInterpolation", "standard");
169 if (savedImageInterpolationMethod.equals("bilinear"))
170 imageInterpolationMethod.setSelectedIndex(1);
171 else if (savedImageInterpolationMethod.equals("bicubic"))
172 imageInterpolationMethod.setSelectedIndex(2);
173 else
174 imageInterpolationMethod.setSelectedIndex(0);
175 cadastrewms.add(imageInterpolationMethod, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
176
177 // separator
178 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
179
180 // the vectorized images multiplier
181 JLabel jLabelScale = new JLabel(tr("Vector images grab multiplier:"));
182 cadastrewms.add(jLabelScale, GBC.std().insets(0, 5, 10, 0));
183 ButtonGroup bgGrabMultiplier = new ButtonGroup();
184 ActionListener multiplierActionListener = new ActionListener() {
185 public void actionPerformed(ActionEvent actionEvent) {
186 AbstractButton button = (AbstractButton) actionEvent.getSource();
187 grabMultiplier4Size.setEnabled(button == grabMultiplier4);
188 }
189 };
190 grabMultiplier1.setIcon(ImageProvider.get("preferences", "unsel_box_1"));
191 grabMultiplier1.setSelectedIcon(ImageProvider.get("preferences", "sel_box_1"));
192 grabMultiplier1.addActionListener( multiplierActionListener);
193 grabMultiplier1.setToolTipText(tr("Grab one image full screen"));
194 grabMultiplier2.setIcon(ImageProvider.get("preferences", "unsel_box_2"));
195 grabMultiplier2.setSelectedIcon(ImageProvider.get("preferences", "sel_box_2"));
196 grabMultiplier2.addActionListener( multiplierActionListener);
197 grabMultiplier2.setToolTipText(tr("Grab smaller images (higher quality but use more memory)"));
198 grabMultiplier3.setIcon(ImageProvider.get("preferences", "unsel_box_3"));
199 grabMultiplier3.setSelectedIcon(ImageProvider.get("preferences", "sel_box_3"));
200 grabMultiplier3.addActionListener( multiplierActionListener);
201 grabMultiplier3.setToolTipText(tr("Grab smaller images (higher quality but use more memory)"));
202 grabMultiplier4.setIcon(ImageProvider.get("preferences", "unsel_box_4"));
203 grabMultiplier4.setSelectedIcon(ImageProvider.get("preferences", "sel_box_4"));
204 grabMultiplier4.addActionListener( multiplierActionListener);
205 grabMultiplier4.setToolTipText(tr("Fixed size square (default is 100m)"));
206 bgGrabMultiplier.add(grabMultiplier1);
207 bgGrabMultiplier.add(grabMultiplier2);
208 bgGrabMultiplier.add(grabMultiplier3);
209 bgGrabMultiplier.add(grabMultiplier4);
210 String currentScale = Main.pref.get("cadastrewms.scale", "1");
211 if (currentScale.equals(Scale.X1.value))
212 grabMultiplier1.setSelected(true);
213 if (currentScale.equals(Scale.X2.value))
214 grabMultiplier2.setSelected(true);
215 if (currentScale.equals(Scale.X3.value))
216 grabMultiplier3.setSelected(true);
217 if (currentScale.equals(Scale.SQUARE_100M.value))
218 grabMultiplier4.setSelected(true);
219 cadastrewms.add(grabMultiplier1, GBC.std().insets(5, 0, 5, 0));
220 cadastrewms.add(grabMultiplier2, GBC.std().insets(5, 0, 5, 0));
221 cadastrewms.add(grabMultiplier3, GBC.std().insets(5, 0, 5, 0));
222 cadastrewms.add(grabMultiplier4, GBC.std().insets(5, 0, 5, 0));
223 int squareSize = getNumber("cadastrewms.squareSize", DEFAULT_SQUARE_SIZE);
224 grabMultiplier4Size.setText(String.valueOf(squareSize));
225 grabMultiplier4Size.setToolTipText(tr("Fixed size (from 25 to 1000 meters)"));
226 grabMultiplier4Size.setEnabled(currentScale.equals(Scale.SQUARE_100M.value));
227 cadastrewms.add(grabMultiplier4Size, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
228
229 // separator
230 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
231
232 // for raster images (not vectorized), image grab divider (from 1 to 12)
233 String savedRasterDivider = Main.pref.get("cadastrewms.rasterDivider", DEFAULT_RASTER_DIVIDER);
234 JLabel jLabelRasterDivider = new JLabel(tr("Raster images grab multiplier:"));
235 rasterDivider.setText(savedRasterDivider);
236 rasterDivider.setToolTipText("Raster image grab division, from 1 to 12; 12 is very high definition");
237 cadastrewms.add(jLabelRasterDivider, GBC.std().insets(0, 5, 10, 0));
238 cadastrewms.add(rasterDivider, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
239 // option to disable image cropping during raster image georeferencing
240 disableImageCropping.setSelected(Main.pref.getBoolean("cadastrewms.noImageCropping", false));
241 disableImageCropping.setToolTipText(tr("Disable image cropping during georeferencing."));
242 cadastrewms.add(disableImageCropping, GBC.eop().insets(0, 0, 0, 0));
243 // the crosspiece display
244 JLabel jLabelCrosspieces = new JLabel(tr("Display crosspieces:"));
245 cadastrewms.add(jLabelCrosspieces, GBC.std().insets(0, 0, 10, 0));
246 ButtonGroup bgCrosspieces = new ButtonGroup();
247 int crosspieces = getNumber("cadastrewms.crosspieces", DEFAULT_CROSSPIECES);
248 if (crosspieces == 0) crosspiece1.setSelected(true);
249 if (crosspieces == 1) crosspiece2.setSelected(true);
250 if (crosspieces == 2) crosspiece3.setSelected(true);
251 if (crosspieces == 3) crosspiece4.setSelected(true);
252 bgCrosspieces.add(crosspiece1);
253 bgCrosspieces.add(crosspiece2);
254 bgCrosspieces.add(crosspiece3);
255 bgCrosspieces.add(crosspiece4);
256 cadastrewms.add(crosspiece1, GBC.std().insets(5, 0, 5, 0));
257 cadastrewms.add(crosspiece2, GBC.std().insets(5, 0, 5, 0));
258 cadastrewms.add(crosspiece3, GBC.std().insets(5, 0, 5, 0));
259 cadastrewms.add(crosspiece4, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
260
261 // separator
262 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
263
264 // option to enable automatic caching
265 enableCache.addActionListener(new ActionListener() {
266 public void actionPerformed(ActionEvent e) {
267 jLabelCacheSize.setEnabled(enableCache.isSelected());
268 cacheSize.setEnabled(enableCache.isSelected());
269 }
270 });
271 enableCache.setSelected(Main.pref.getBoolean("cadastrewms.enableCaching", true));
272 enableCache.setToolTipText(tr("Replace the original white background by the backgound color defined in JOSM preferences."));
273 cadastrewms.add(enableCache, GBC.eop().insets(0, 0, 0, 0));
274
275 // option to fix the cache size(in MB)
276 int size = getNumber("cadastrewms.cacheSize", DEFAULT_CACHE_SIZE);
277 cacheSize.setText(String.valueOf(size));
278 cacheSize.setToolTipText(tr("Oldest files are automatically deleted when this size is exceeded"));
279 cadastrewms.add(jLabelCacheSize, GBC.std().insets(20, 0, 0, 0));
280 cadastrewms.add(cacheSize, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
281 // separator
282 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
283 autoFirstLayer.setSelected(Main.pref.getBoolean("cadastrewms.autoFirstLayer", false));
284 autoFirstLayer.setToolTipText(tr("Automatically selects the first WMS layer if multiple layers exist when grabbing."));
285 cadastrewms.add(autoFirstLayer, GBC.eop().insets(0, 0, 0, 0));
286 cadastrewms.add(Box.createVerticalGlue(), GBC.eol().fill(GBC.VERTICAL));
287
288 }
289
290 public boolean ok() {
291 Main.pref.put("cadastrewms.source", sourcing.getText());
292 CadastrePlugin.source = sourcing.getText();
293 Main.pref.put("cadastrewms.alterColors", alterColors.isSelected());
294 Main.pref.put("cadastrewms.invertGrey", reversGrey.isSelected());
295 Main.pref.put("cadastrewms.backgroundTransparent", transparency.isSelected());
296 Main.pref.put("cadastrewms.brightness", Float.toString((float)sliderTrans.getValue()/10));
297 Main.pref.put("cadastrewms.drawBoundaries", drawBoundaries.isSelected());
298 if (grabRes1.isSelected())
299 Main.pref.put("cadastrewms.resolution", "high");
300 else if (grabRes2.isSelected())
301 Main.pref.put("cadastrewms.resolution", "medium");
302 else if (grabRes3.isSelected())
303 Main.pref.put("cadastrewms.resolution", "low");
304 if (imageInterpolationMethod.getSelectedIndex() == 2)
305 Main.pref.put("cadastrewms.imageInterpolation", "bicubic");
306 else if (imageInterpolationMethod.getSelectedIndex() == 1)
307 Main.pref.put("cadastrewms.imageInterpolation", "bilinear");
308 else
309 Main.pref.put("cadastrewms.imageInterpolation", "standard");
310 if (grabMultiplier1.isSelected())
311 Main.pref.put("cadastrewms.scale", Scale.X1.toString());
312 else if (grabMultiplier2.isSelected())
313 Main.pref.put("cadastrewms.scale", Scale.X2.toString());
314 else if (grabMultiplier3.isSelected())
315 Main.pref.put("cadastrewms.scale", Scale.X3.toString());
316 else {
317 Main.pref.put("cadastrewms.scale", Scale.SQUARE_100M.toString());
318 try {
319 int squareSize = Integer.parseInt(grabMultiplier4Size.getText());
320 if (squareSize >= 25 && squareSize <= 1000)
321 Main.pref.put("cadastrewms.squareSize", grabMultiplier4Size.getText());
322 } catch (NumberFormatException e) { // ignore the last input
323 }
324 }
325 try {
326 int i = Integer.parseInt(rasterDivider.getText());
327 if (i > 0 && i < 13)
328 Main.pref.put("cadastrewms.rasterDivider", String.valueOf(i));
329 } catch (NumberFormatException e) { // ignore the last input
330 }
331 Main.pref.put("cadastrewms.noImageCropping", disableImageCropping.isSelected());
332 if (crosspiece1.isSelected()) Main.pref.put("cadastrewms.crosspieces", "0");
333 else if (crosspiece2.isSelected()) Main.pref.put("cadastrewms.crosspieces", "1");
334 else if (crosspiece3.isSelected()) Main.pref.put("cadastrewms.crosspieces", "2");
335 else if (crosspiece4.isSelected()) Main.pref.put("cadastrewms.crosspieces", "3");
336 Main.pref.put("cadastrewms.enableCaching", enableCache.isSelected());
337
338 // spread data into objects instead of restarting the application
339 try {
340 CacheControl.cacheSize = Integer.parseInt(cacheSize.getText());
341 Main.pref.put("cadastrewms.cacheSize", String.valueOf(CacheControl.cacheSize));
342 } catch (NumberFormatException e) { // ignore the last input
343 }
344 Main.pref.put("cadastrewms.autoFirstLayer", autoFirstLayer.isSelected());
345 CacheControl.cacheEnabled = enableCache.isSelected();
346 CadastrePlugin.refreshConfiguration();
347 CadastrePlugin.refreshMenu();
348
349 return false;
350 }
351
352 private int getNumber(String pref_parameter, int def_value) {
353 try {
354 return Integer.parseInt(Main.pref.get(pref_parameter, String.valueOf(def_value)));
355 } catch (NumberFormatException e) {
356 return def_value;
357 }
358 }
359}
Note: See TracBrowser for help on using the repository browser.