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

Last change on this file since 19949 was 19949, checked in by clementm, 15 years ago

WMSLayer image drawing filtering options:

  • Nearest Neighbor = Default, fastest : poor readability if zooming out
  • Bilinear, fast : good readability if low resolution, blury if zooming in
  • Bicubic, slow: best readability when zooming out, good readability if zooming in
  • Property svn:eol-style set to native
File size: 17.1 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 static final int DEFAULT_SQUARE_SIZE = 100;
61 private JTextField grabMultiplier4Size = new JTextField(5);
62
63 private JCheckBox enableCache = new JCheckBox(tr("Enable automatic caching."));
64
65 static final int DEFAULT_CACHE_SIZE = 500;
66 JLabel jLabelCacheSize = new JLabel(tr("Max. cache size (in MB)"));
67 private JTextField cacheSize = new JTextField(20);
68
69 static final String DEFAULT_RASTER_DIVIDER = "5";
70 private JTextField rasterDivider = new JTextField(10);
71
72 static final int DEFAULT_CROSSPIECES = 0;
73
74 public void addGui(final PreferenceTabbedPane gui) {
75
76 String description = tr("A special handler of the French cadastre wms at www.cadastre.gouv.fr" + "<BR><BR>"
77 + "Please read the Terms and Conditions of Use here (in French): <br>"
78 + "<a href=\"http://www.cadastre.gouv.fr/scpc/html/CU_01_ConditionsGenerales_fr.html\"> "
79 + "http://www.cadastre.gouv.fr/scpc/html/CU_01_ConditionsGenerales_fr.html</a> <BR>"
80 + "before any upload of data created by this plugin.");
81 JPanel cadastrewms = gui.createPreferenceTab("cadastrewms.gif", I18n.tr("French cadastre WMS"), description);
82
83 // option to automatically set the source tag when uploading
84 sourcing.setText(CadastrePlugin.source);
85 sourcing.setToolTipText(tr("<html>Value of key \"source\" when autosourcing is enabled</html>"));
86 JLabel jLabelSource = new JLabel(tr("Source"));
87 cadastrewms.add(jLabelSource, GBC.eop().insets(0, 0, 0, 0));
88 cadastrewms.add(sourcing, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 0, 0, 5));
89
90 // option to alter the original colors of the wms images
91 alterColors.setSelected(Main.pref.getBoolean("cadastrewms.alterColors", false));
92 alterColors.setToolTipText(tr("Replace the original white background by the backgound color defined in JOSM preferences."));
93 cadastrewms.add(alterColors, GBC.eop().insets(0, 0, 0, 0));
94
95 // option to reverse the grey colors (to see texts background)
96 reversGrey.setSelected(Main.pref.getBoolean("cadastrewms.invertGrey", false));
97 reversGrey.setToolTipText(tr("Invert the original black and white colors (and all intermediate greys). Useful for texts on dark backgrounds."));
98 cadastrewms.add(reversGrey, GBC.eop().insets(00, 0, 0, 0));
99
100 // option to enable transparency
101 transparency.addActionListener(new ActionListener() {
102 public void actionPerformed(ActionEvent e) {
103 sliderTrans.setEnabled(transparency.isSelected());
104 }
105 });
106 transparency.setSelected(Main.pref.getBoolean("cadastrewms.backgroundTransparent", false));
107 transparency.setToolTipText(tr("Allows multiple layers stacking"));
108 cadastrewms.add(transparency, GBC.eop().insets(0, 0, 0, 0));
109
110 // slider for transparency level
111 sliderTrans.setSnapToTicks(true);
112 sliderTrans.setToolTipText(tr("Set WMS layers transparency. Right is opaque, left is transparent."));
113 sliderTrans.setMajorTickSpacing(10);
114 sliderTrans.setMinorTickSpacing(1);
115 sliderTrans.setValue((int)(Float.parseFloat(Main.pref.get("cadastrewms.brightness", "1.0f"))*10));
116 sliderTrans.setPaintTicks(true);
117 sliderTrans.setPaintLabels(false);
118 sliderTrans.setEnabled(transparency.isSelected());
119 cadastrewms.add(sliderTrans, GBC.eol().fill(GBC.HORIZONTAL).insets(20, 0, 250, 0));
120
121 // option to draw boundaries of downloaded data
122 drawBoundaries.setSelected(Main.pref.getBoolean("cadastrewms.drawBoundaries", false));
123 drawBoundaries.setToolTipText(tr("Draw a rectangle around downloaded data from WMS server."));
124 cadastrewms.add(drawBoundaries, GBC.eop().insets(0, 0, 0, 5));
125
126 // option to select image zooming interpolation method
127 JLabel jLabelImageZoomInterpolation = new JLabel(tr("Image zoom interpolation:"));
128 cadastrewms.add(jLabelImageZoomInterpolation, GBC.std().insets(0, 0, 10, 0));
129 imageInterpolationMethod.addItem(tr("Nearest-Neighbor (fastest) [ Default ]"));
130 imageInterpolationMethod.addItem(tr("Bilinear (fast)"));
131 imageInterpolationMethod.addItem(tr("Bicubic (slow)"));
132 String savedImageInterpolationMethod = Main.pref.get("cadastrewms.imageInterpolation", "standard");
133 if (savedImageInterpolationMethod.equals("bilinear"))
134 imageInterpolationMethod.setSelectedIndex(1);
135 else if (savedImageInterpolationMethod.equals("bicubic"))
136 imageInterpolationMethod.setSelectedIndex(2);
137 else
138 imageInterpolationMethod.setSelectedIndex(0);
139 cadastrewms.add(imageInterpolationMethod, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
140
141 // separator
142 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
143
144 // the vectorized images multiplier
145 JLabel jLabelScale = new JLabel(tr("Vector images grab multiplier:"));
146 cadastrewms.add(jLabelScale, GBC.std().insets(0, 5, 10, 0));
147 ButtonGroup bgGrabMultiplier = new ButtonGroup();
148 ActionListener multiplierActionListener = new ActionListener() {
149 public void actionPerformed(ActionEvent actionEvent) {
150 AbstractButton button = (AbstractButton) actionEvent.getSource();
151 grabMultiplier4Size.setEnabled(button == grabMultiplier4);
152 }
153 };
154 grabMultiplier1.setIcon(ImageProvider.get("preferences", "unsel_box_1"));
155 grabMultiplier1.setSelectedIcon(ImageProvider.get("preferences", "sel_box_1"));
156 grabMultiplier1.addActionListener( multiplierActionListener);
157 grabMultiplier2.setIcon(ImageProvider.get("preferences", "unsel_box_2"));
158 grabMultiplier2.setSelectedIcon(ImageProvider.get("preferences", "sel_box_2"));
159 grabMultiplier2.addActionListener( multiplierActionListener);
160 grabMultiplier2.setToolTipText(tr("Grab smaller images (higher quality but use more memory)"));
161 grabMultiplier3.setIcon(ImageProvider.get("preferences", "unsel_box_3"));
162 grabMultiplier3.setSelectedIcon(ImageProvider.get("preferences", "sel_box_3"));
163 grabMultiplier3.addActionListener( multiplierActionListener);
164 grabMultiplier3.setToolTipText(tr("Grab smaller images (higher quality but use more memory)"));
165 grabMultiplier4.setIcon(ImageProvider.get("preferences", "unsel_box_4"));
166 grabMultiplier4.setSelectedIcon(ImageProvider.get("preferences", "sel_box_4"));
167 grabMultiplier4.addActionListener( multiplierActionListener);
168 grabMultiplier4.setToolTipText(tr("Fixed size square (default is 100m)"));
169 bgGrabMultiplier.add(grabMultiplier1);
170 bgGrabMultiplier.add(grabMultiplier2);
171 bgGrabMultiplier.add(grabMultiplier3);
172 bgGrabMultiplier.add(grabMultiplier4);
173 String currentScale = Main.pref.get("cadastrewms.scale", "1");
174 if (currentScale.equals(Scale.X1.value))
175 grabMultiplier1.setSelected(true);
176 if (currentScale.equals(Scale.X2.value))
177 grabMultiplier2.setSelected(true);
178 if (currentScale.equals(Scale.X3.value))
179 grabMultiplier3.setSelected(true);
180 if (currentScale.equals(Scale.SQUARE_100M.value))
181 grabMultiplier4.setSelected(true);
182 cadastrewms.add(grabMultiplier1, GBC.std().insets(5, 0, 5, 0));
183 cadastrewms.add(grabMultiplier2, GBC.std().insets(5, 0, 5, 0));
184 cadastrewms.add(grabMultiplier3, GBC.std().insets(5, 0, 5, 0));
185 cadastrewms.add(grabMultiplier4, GBC.std().insets(5, 0, 5, 0));
186 int squareSize = getNumber("cadastrewms.squareSize", DEFAULT_SQUARE_SIZE);
187 grabMultiplier4Size.setText(String.valueOf(squareSize));
188 grabMultiplier4Size.setToolTipText(tr("Fixed size (from 25 to 1000 meters)"));
189 grabMultiplier4Size.setEnabled(currentScale.equals(Scale.SQUARE_100M.value));
190 cadastrewms.add(grabMultiplier4Size, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
191
192 // separator
193 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
194
195 // for raster images (not vectorized), image grab divider (from 1 to 12)
196 String savedRasterDivider = Main.pref.get("cadastrewms.rasterDivider", DEFAULT_RASTER_DIVIDER);
197 JLabel jLabelRasterDivider = new JLabel(tr("Raster images grab multiplier:"));
198 rasterDivider.setText(savedRasterDivider);
199 rasterDivider.setToolTipText("Raster image grab division, from 1 to 12; 12 is very high definition");
200 cadastrewms.add(jLabelRasterDivider, GBC.std().insets(0, 5, 10, 0));
201 cadastrewms.add(rasterDivider, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
202 // option to disable image cropping during raster image georeferencing
203 disableImageCropping.setSelected(Main.pref.getBoolean("cadastrewms.noImageCropping", false));
204 disableImageCropping.setToolTipText(tr("Disable image cropping during georeferencing."));
205 cadastrewms.add(disableImageCropping, GBC.eop().insets(0, 0, 0, 0));
206 // the crosspiece display
207 JLabel jLabelCrosspieces = new JLabel(tr("Display crosspieces:"));
208 cadastrewms.add(jLabelCrosspieces, GBC.std().insets(0, 0, 10, 0));
209 ButtonGroup bgCrosspieces = new ButtonGroup();
210 int crosspieces = getNumber("cadastrewms.crosspieces", DEFAULT_CROSSPIECES);
211 if (crosspieces == 0) crosspiece1.setSelected(true);
212 if (crosspieces == 1) crosspiece2.setSelected(true);
213 if (crosspieces == 2) crosspiece3.setSelected(true);
214 if (crosspieces == 3) crosspiece4.setSelected(true);
215 bgCrosspieces.add(crosspiece1);
216 bgCrosspieces.add(crosspiece2);
217 bgCrosspieces.add(crosspiece3);
218 bgCrosspieces.add(crosspiece4);
219 cadastrewms.add(crosspiece1, GBC.std().insets(5, 0, 5, 0));
220 cadastrewms.add(crosspiece2, GBC.std().insets(5, 0, 5, 0));
221 cadastrewms.add(crosspiece3, GBC.std().insets(5, 0, 5, 0));
222 cadastrewms.add(crosspiece4, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 0, 5));
223
224 // separator
225 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
226
227 // option to enable automatic caching
228 enableCache.addActionListener(new ActionListener() {
229 public void actionPerformed(ActionEvent e) {
230 jLabelCacheSize.setEnabled(enableCache.isSelected());
231 cacheSize.setEnabled(enableCache.isSelected());
232 }
233 });
234 enableCache.setSelected(Main.pref.getBoolean("cadastrewms.enableCaching", true));
235 enableCache.setToolTipText(tr("Replace the original white background by the backgound color defined in JOSM preferences."));
236 cadastrewms.add(enableCache, GBC.eop().insets(0, 0, 0, 0));
237
238 // option to fix the cache size(in MB)
239 int size = getNumber("cadastrewms.cacheSize", DEFAULT_CACHE_SIZE);
240 cacheSize.setText(String.valueOf(size));
241 cacheSize.setToolTipText(tr("Oldest files are automatically deleted when this size is exceeded"));
242 cadastrewms.add(jLabelCacheSize, GBC.std().insets(20, 0, 0, 0));
243 cadastrewms.add(cacheSize, GBC.eol().fill(GBC.HORIZONTAL).insets(5, 5, 200, 5));
244 // separator
245 cadastrewms.add(new JSeparator(SwingConstants.HORIZONTAL), GBC.eol().fill(GBC.HORIZONTAL));
246 autoFirstLayer.setSelected(Main.pref.getBoolean("cadastrewms.autoFirstLayer", false));
247 autoFirstLayer.setToolTipText(tr("Automatically selects the first WMS layer if multiple layers exist when grabbing."));
248 cadastrewms.add(autoFirstLayer, GBC.eop().insets(0, 0, 0, 0));
249 cadastrewms.add(Box.createVerticalGlue(), GBC.eol().fill(GBC.VERTICAL));
250
251 }
252
253 public boolean ok() {
254 Main.pref.put("cadastrewms.source", sourcing.getText());
255 CadastrePlugin.source = sourcing.getText();
256 Main.pref.put("cadastrewms.alterColors", alterColors.isSelected());
257 Main.pref.put("cadastrewms.invertGrey", reversGrey.isSelected());
258 Main.pref.put("cadastrewms.backgroundTransparent", transparency.isSelected());
259 Main.pref.put("cadastrewms.brightness", Float.toString((float)sliderTrans.getValue()/10));
260 Main.pref.put("cadastrewms.drawBoundaries", drawBoundaries.isSelected());
261 if (imageInterpolationMethod.getSelectedIndex() == 2)
262 Main.pref.put("cadastrewms.imageInterpolation", "bicubic");
263 else if (imageInterpolationMethod.getSelectedIndex() == 1)
264 Main.pref.put("cadastrewms.imageInterpolation", "bilinear");
265 else
266 Main.pref.put("cadastrewms.imageInterpolation", "standard");
267 if (grabMultiplier1.isSelected())
268 Main.pref.put("cadastrewms.scale", Scale.X1.toString());
269 else if (grabMultiplier2.isSelected())
270 Main.pref.put("cadastrewms.scale", Scale.X2.toString());
271 else if (grabMultiplier3.isSelected())
272 Main.pref.put("cadastrewms.scale", Scale.X3.toString());
273 else {
274 Main.pref.put("cadastrewms.scale", Scale.SQUARE_100M.toString());
275 try {
276 int squareSize = Integer.parseInt(grabMultiplier4Size.getText());
277 if (squareSize >= 25 && squareSize <= 1000)
278 Main.pref.put("cadastrewms.squareSize", grabMultiplier4Size.getText());
279 } catch (NumberFormatException e) { // ignore the last input
280 }
281 }
282 try {
283 int i = Integer.parseInt(rasterDivider.getText());
284 if (i > 0 && i < 13)
285 Main.pref.put("cadastrewms.rasterDivider", String.valueOf(i));
286 } catch (NumberFormatException e) { // ignore the last input
287 }
288 Main.pref.put("cadastrewms.noImageCropping", disableImageCropping.isSelected());
289 if (crosspiece1.isSelected()) Main.pref.put("cadastrewms.crosspieces", "0");
290 else if (crosspiece2.isSelected()) Main.pref.put("cadastrewms.crosspieces", "1");
291 else if (crosspiece3.isSelected()) Main.pref.put("cadastrewms.crosspieces", "2");
292 else if (crosspiece4.isSelected()) Main.pref.put("cadastrewms.crosspieces", "3");
293 Main.pref.put("cadastrewms.enableCaching", enableCache.isSelected());
294
295 // spread data into objects instead of restarting the application
296 try {
297 CacheControl.cacheSize = Integer.parseInt(cacheSize.getText());
298 Main.pref.put("cadastrewms.cacheSize", String.valueOf(CacheControl.cacheSize));
299 } catch (NumberFormatException e) { // ignore the last input
300 }
301 Main.pref.put("cadastrewms.autoFirstLayer", autoFirstLayer.isSelected());
302 CacheControl.cacheEnabled = enableCache.isSelected();
303 CadastrePlugin.refreshConfiguration();
304 CadastrePlugin.refreshMenu();
305
306 return false;
307 }
308
309 private int getNumber(String pref_parameter, int def_value) {
310 try {
311 return Integer.parseInt(Main.pref.get(pref_parameter, String.valueOf(def_value)));
312 } catch (NumberFormatException e) {
313 return def_value;
314 }
315 }
316}
Note: See TracBrowser for help on using the repository browser.