Changeset 1865 in josm for trunk/src/org/openstreetmap/josm


Ignore:
Timestamp:
2009-07-28T19:48:39+02:00 (15 years ago)
Author:
Gubaer
Message:

replaced JOptionPane.show* by OptionPaneUtil.show*
ExtendeDialog now always on top, too

Location:
trunk/src/org/openstreetmap/josm
Files:
28 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/org/openstreetmap/josm/actions/SelectAllAction.java

    r1820 r1865  
    77import java.awt.event.KeyEvent;
    88
    9 import org.openstreetmap.josm.gui.layer.Layer;
    10 import org.openstreetmap.josm.gui.layer.Layer.LayerChangeListener;
    119import org.openstreetmap.josm.tools.Shortcut;
    1210
  • trunk/src/org/openstreetmap/josm/actions/UnselectAllAction.java

    r1820 r1865  
    66import java.awt.event.ActionEvent;
    77import java.awt.event.KeyEvent;
     8
    89import javax.swing.JComponent;
    910
    1011import org.openstreetmap.josm.Main;
    11 import org.openstreetmap.josm.gui.layer.Layer;
    12 import org.openstreetmap.josm.gui.layer.Layer.LayerChangeListener;
    1312import org.openstreetmap.josm.tools.Shortcut;
    1413
  • trunk/src/org/openstreetmap/josm/actions/UpdateDataAction.java

    r1857 r1865  
    1616import org.openstreetmap.josm.data.osm.DataSource;
    1717import org.openstreetmap.josm.gui.OptionPaneUtil;
    18 import org.openstreetmap.josm.gui.layer.Layer;
    19 import org.openstreetmap.josm.gui.layer.Layer.LayerChangeListener;
    2018import org.openstreetmap.josm.tools.Shortcut;
    2119
  • trunk/src/org/openstreetmap/josm/actions/UpdateSelectionAction.java

    r1857 r1865  
    1414
    1515import org.openstreetmap.josm.Main;
    16 import org.openstreetmap.josm.data.SelectionChangedListener;
    1716import org.openstreetmap.josm.data.osm.DataSet;
    1817import org.openstreetmap.josm.data.osm.OsmPrimitive;
    1918import org.openstreetmap.josm.gui.OptionPaneUtil;
    2019import org.openstreetmap.josm.gui.PleaseWaitRunnable;
    21 import org.openstreetmap.josm.gui.layer.Layer;
    22 import org.openstreetmap.josm.gui.layer.Layer.LayerChangeListener;
    2320import org.openstreetmap.josm.gui.progress.NullProgressMonitor;
    2421import org.openstreetmap.josm.gui.progress.ProgressMonitor;
     
    6360    protected void handleUpdateException(Exception e) {
    6461        e.printStackTrace();
    65         JOptionPane.showMessageDialog(
     62        OptionPaneUtil.showMessageDialog(
    6663                Main.parent,
    6764                tr("Failed to update the selected primitives."),
     
    7875     */
    7976    protected void handleMissingPrimitive(long id) {
    80         JOptionPane.showMessageDialog(
     77        OptionPaneUtil.showMessageDialog(
    8178                Main.parent,
    8279                tr("Could not find primitive with id {0} in the current dataset", new Long(id).toString()),
     
    114111                    msg = lastException.toString();
    115112                }
    116                 JOptionPane.showMessageDialog(
     113                OptionPaneUtil.showMessageDialog(
    117114                        Main.map,
    118115                        msg,
  • trunk/src/org/openstreetmap/josm/actions/UploadAction.java

    r1857 r1865  
    169169            return;
    170170        if (Main.map == null) {
    171             JOptionPane.showMessageDialog(Main.parent,tr("Nothing to upload. Get some data first."));
     171            OptionPaneUtil.showMessageDialog(
     172                    Main.parent,
     173                    tr("Nothing to upload. Get some data first."),
     174                    tr("Warning"),
     175                    JOptionPane.WARNING_MESSAGE
     176            );
    172177            return;
    173178        }
     
    203208
    204209        if (add.isEmpty() && update.isEmpty() && delete.isEmpty()) {
    205             JOptionPane.showMessageDialog(Main.parent,tr("No changes to upload."));
     210            OptionPaneUtil.showMessageDialog(
     211                    Main.parent,
     212                    tr("No changes to upload."),
     213                    tr("Warning"),
     214                    JOptionPane.WARNING_MESSAGE
     215            );
    206216            return;
    207217        }
     
    350360        );
    351361        int optionsType = JOptionPane.YES_NO_CANCEL_OPTION;
    352         int ret = JOptionPane.showOptionDialog(
     362        int ret = OptionPaneUtil.showOptionDialog(
    353363                null,
    354364                msg,
     
    356366                optionsType,
    357367                JOptionPane.ERROR_MESSAGE,
    358                 null,
    359368                options,
    360369                defaultOption
     
    390399        );
    391400        int optionsType = JOptionPane.YES_NO_OPTION;
    392         int ret = JOptionPane.showOptionDialog(
     401        int ret = OptionPaneUtil.showOptionDialog(
    393402                null,
    394403                msg,
     
    396405                optionsType,
    397406                JOptionPane.ERROR_MESSAGE,
    398                 null,
    399407                options,
    400408                defaultOption
     
    433441     */
    434442    protected void handlePreconditionFailed(OsmApiException e) {
    435         JOptionPane.showMessageDialog(
     443        OptionPaneUtil.showMessageDialog(
    436444                Main.parent,
    437445                tr("<html>Uploading to the server <strong>failed</strong> because your current<br>"
     
    483491                e.getMessage().replace("&", "&amp;").replace("<", "&lt;").replace(">", "&gt;")
    484492        );
    485         JOptionPane.showMessageDialog(
     493        OptionPaneUtil.showMessageDialog(
    486494                Main.parent,
    487495                msg,
     
    558566                        ex.getDisplayMessage()
    559567                );
    560                 JOptionPane.showMessageDialog(
     568                OptionPaneUtil.showMessageDialog(
    561569                        Main.map,
    562570                        msg,
     
    575583        }
    576584        e.printStackTrace();
    577         JOptionPane.showMessageDialog(
     585        OptionPaneUtil.showMessageDialog(
    578586                Main.map,
    579587                msg,
     
    589597     */
    590598    protected void handleOsmApiInitializationException(OsmApiInitializationException e) {
    591         JOptionPane.showMessageDialog(
     599        OptionPaneUtil.showMessageDialog(
    592600                Main.parent,
    593601                tr(   "Failed to initialize communication with the OSM server {0}.\n"
  • trunk/src/org/openstreetmap/josm/actions/mapmode/DeleteAction.java

    r1856 r1865  
    1313import org.openstreetmap.josm.command.Command;
    1414import org.openstreetmap.josm.command.DeleteCommand;
    15 import org.openstreetmap.josm.data.osm.DataSet;
    1615import org.openstreetmap.josm.data.osm.OsmPrimitive;
    1716import org.openstreetmap.josm.data.osm.Relation;
  • trunk/src/org/openstreetmap/josm/data/ServerSidePreferences.java

    r1857 r1865  
    106106        } catch (MalformedURLException e) {
    107107            e.printStackTrace();
    108             JOptionPane.showMessageDialog(Main.parent, tr("Could not load preferences from server."));
     108            OptionPaneUtil.showMessageDialog(
     109                    Main.parent,
     110                    tr("Could not load preferences from server."),
     111                    tr("Error"),
     112                    JOptionPane.ERROR_MESSAGE
     113            );
    109114        }
    110115        this.connection = connection;
  • trunk/src/org/openstreetmap/josm/gui/BookmarkList.java

    r1169 r1865  
    3737        model.removeAllElements();
    3838        try {
    39             for (Preferences.Bookmark b : Main.pref.loadBookmarks())
     39            for (Preferences.Bookmark b : Main.pref.loadBookmarks()) {
    4040                model.addElement(b);
     41            }
    4142        } catch (IOException e) {
    4243            e.printStackTrace();
    43             JOptionPane.showMessageDialog(Main.parent, tr("Could not read bookmarks.")+"\n"+e.getMessage());
     44            OptionPaneUtil.showMessageDialog(
     45                    Main.parent,
     46                    tr("<html>Could not read bookmarks.<br>{0}</html>", e.getMessage()),
     47                    tr("Error"),
     48                    JOptionPane.ERROR_MESSAGE
     49            );
    4450        }
    4551    }
     
    5157        try {
    5258            Collection<Preferences.Bookmark> bookmarks = new LinkedList<Preferences.Bookmark>();
    53             for (Object o : ((DefaultListModel)getModel()).toArray())
     59            for (Object o : ((DefaultListModel)getModel()).toArray()) {
    5460                bookmarks.add((Preferences.Bookmark)o);
     61            }
    5562            Main.pref.saveBookmarks(bookmarks);
    5663        } catch (IOException e) {
    57             JOptionPane.showMessageDialog(Main.parent,tr("Could not write bookmark.")+"\n"+e.getMessage());
     64            OptionPaneUtil.showMessageDialog(
     65                    Main.parent,
     66                    tr("<html>Could not write bookmark.<br>{0}</html>", e.getMessage()),
     67                    tr("Error"),
     68                    JOptionPane.ERROR_MESSAGE
     69            );
    5870        }
    5971    }
  • trunk/src/org/openstreetmap/josm/gui/ExtendedDialog.java

    r1861 r1865  
    6767        bTexts = buttonTexts;
    6868        setupDialog(lbl, buttonIcons);
    69         try {
    70             setAlwaysOnTop(true);
    71         } catch(SecurityException e) {
    72             System.out.println(tr("Warning: failed to put extended dialog always on top. Exception was: {0}", e.toString()));
    73         }
    7469        setVisible(true);
    7570    }
     
    143138        setSize(d);
    144139        setLocationRelativeTo(parent);
     140
     141        // try to put always on top
     142        //
     143        try {
     144            setAlwaysOnTop(true);
     145        } catch(SecurityException e) {
     146            System.out.println(tr("Warning: failed to bring extended dialog always on top. Exception: {0}", e.toString()));
     147        }
    145148    }
    146149
  • trunk/src/org/openstreetmap/josm/gui/OptionPaneUtil.java

    r1861 r1865  
    77import java.awt.HeadlessException;
    88
     9import javax.swing.Icon;
    910import javax.swing.JDialog;
    1011import javax.swing.JOptionPane;
     12import javax.swing.JRootPane;
     13import javax.swing.UIManager;
    1114
    1215import org.openstreetmap.josm.Main;
     
    212215        return JOptionPane.CLOSED_OPTION;
    213216    }
     217
     218    /**
     219     * Shows a dialog requesting input from the user parented to
     220     * <code>parentComponent</code> with the dialog having the title
     221     * <code>title</code> and message type <code>messageType</code>.
     222     *
     223     * @param parentComponent  the parent <code>Component</code> for the
     224     *          dialog
     225     * @param message  the <code>Object</code> to display
     226     * @param title    the <code>String</code> to display in the dialog
     227     *          title bar
     228     * @param messageType the type of message that is to be displayed:
     229     *                  <code>ERROR_MESSAGE</code>,
     230     *          <code>INFORMATION_MESSAGE</code>,
     231     *          <code>WARNING_MESSAGE</code>,
     232     *                  <code>QUESTION_MESSAGE</code>,
     233     *          or <code>PLAIN_MESSAGE</code>
     234     * @exception HeadlessException if
     235     *   <code>GraphicsEnvironment.isHeadless</code> returns
     236     *   <code>true</code>
     237     * @see java.awt.GraphicsEnvironment#isHeadless
     238     */
     239    public static String showInputDialog(Component parentComponent,
     240            Object message, String title, int messageType)
     241    throws HeadlessException {
     242        return (String)showInputDialog(parentComponent, message, title,
     243                messageType, null, null, null);
     244    }
     245
     246    /**
     247     * Prompts the user for input in a blocking dialog where the
     248     * initial selection, possible selections, and all other options can
     249     * be specified. The user will able to choose from
     250     * <code>selectionValues</code>, where <code>null</code> implies the
     251     * user can input
     252     * whatever they wish, usually by means of a <code>JTextField</code>.
     253     * <code>initialSelectionValue</code> is the initial value to prompt
     254     * the user with. It is up to the UI to decide how best to represent
     255     * the <code>selectionValues</code>, but usually a
     256     * <code>JComboBox</code>, <code>JList</code>, or
     257     * <code>JTextField</code> will be used.
     258     *
     259     * @param parentComponent  the parent <code>Component</code> for the
     260     *          dialog
     261     * @param message  the <code>Object</code> to display
     262     * @param title    the <code>String</code> to display in the
     263     *          dialog title bar
     264     * @param messageType the type of message to be displayed:
     265     *                  <code>ERROR_MESSAGE</code>,
     266     *          <code>INFORMATION_MESSAGE</code>,
     267     *          <code>WARNING_MESSAGE</code>,
     268     *                  <code>QUESTION_MESSAGE</code>,
     269     *          or <code>PLAIN_MESSAGE</code>
     270     * @param icon     the <code>Icon</code> image to display
     271     * @param selectionValues an array of <code>Object</code>s that
     272     *          gives the possible selections
     273     * @param initialSelectionValue the value used to initialize the input
     274     *                 field
     275     * @return user's input, or <code>null</code> meaning the user
     276     *          canceled the input
     277     * @exception HeadlessException if
     278     *   <code>GraphicsEnvironment.isHeadless</code> returns
     279     *   <code>true</code>
     280     * @see java.awt.GraphicsEnvironment#isHeadless
     281     */
     282    public static Object showInputDialog(Component parentComponent,
     283            Object message, String title, int messageType, Icon icon,
     284            Object[] selectionValues, Object initialSelectionValue)
     285    throws HeadlessException {
     286        JOptionPane    pane = new JOptionPane(message, messageType,
     287                JOptionPane.OK_CANCEL_OPTION, icon,
     288                null, null);
     289
     290        pane.setWantsInput(true);
     291        pane.setSelectionValues(selectionValues);
     292        pane.setInitialSelectionValue(initialSelectionValue);
     293        pane.setComponentOrientation(((parentComponent == null) ?
     294                JOptionPane.getRootFrame() : parentComponent).getComponentOrientation());
     295
     296        JDialog dialog = pane.createDialog(parentComponent, title);
     297        // this shows the dialog always on top and brings it to front
     298        //
     299        prepareDialog(dialog);
     300        pane.selectInitialValue();
     301        dialog.setVisible(true);
     302        dialog.dispose();
     303
     304        Object value = pane.getInputValue();
     305        if (value == JOptionPane.UNINITIALIZED_VALUE)
     306            return null;
     307        return value;
     308    }
    214309}
  • trunk/src/org/openstreetmap/josm/gui/download/BookmarkSelection.java

    r1847 r1865  
    8787                    return;
    8888                }
    89                 tempBookmark.name = JOptionPane.showInputDialog(Main.parent,tr("Please enter a name for the location."));
     89                tempBookmark.name = OptionPaneUtil.showInputDialog(
     90                        Main.parent,tr("Please enter a name for the location."),
     91                        tr("Name of location"),
     92                        JOptionPane.QUESTION_MESSAGE
     93                );
    9094                if (tempBookmark.name != null && !tempBookmark.name.equals("")) {
    9195                    ((DefaultListModel)bookmarks.getModel()).addElement(tempBookmark);
  • trunk/src/org/openstreetmap/josm/gui/layer/GeoImageLayer.java

    r1863 r1865  
    7070import org.openstreetmap.josm.gui.MapFrame;
    7171import org.openstreetmap.josm.gui.MapView;
     72import org.openstreetmap.josm.gui.OptionPaneUtil;
    7273import org.openstreetmap.josm.gui.PleaseWaitRunnable;
    7374import org.openstreetmap.josm.gui.dialogs.LayerListDialog;
     
    125126            if (cachedImageRef != null) {
    126127                Image cachedImage = cachedImageRef.get();
    127                 if (cachedImage != null) {
     128                if (cachedImage != null)
    128129                    return cachedImage;
    129                 }
    130130            }
    131131            return Toolkit.getDefaultToolkit().createImage(currentEntry.file.getAbsolutePath());
     
    147147        }
    148148        private void loadImage() {
    149             if (currentEntry != null) {
     149            if (currentEntry != null)
    150150                return;
    151             }
    152151            while (!queue.isEmpty()) {
    153152                currentEntry = queue.get(0);
     
    217216
    218217            while (true) {
    219                 if (entry.scaledImage != null) {
     218                if (entry.scaledImage != null)
    220219                    return entry.scaledImage;
    221                 }
    222220                try {
    223221                    wait();
     
    259257
    260258        public Image getIcon() {
    261             if (icon.scaledImage == null) {
     259            if (icon.scaledImage == null)
    262260                return EMPTY_IMAGE;
    263             } else {
     261            else
    264262                return icon.scaledImage;
    265             }
    266263        }
    267264
     
    330327            ArrayList<ImageEntry> data = new ArrayList<ImageEntry>(files.size());
    331328            for (File f : files) {
    332                 if (progressMonitor.isCancelled())
     329                if (progressMonitor.isCancelled()) {
    333330                    break;
     331                }
    334332                progressMonitor.subTask(tr("Reading {0}...",f.getName()));
    335333
     
    341339                    continue;
    342340                }
    343                 if (e.time == null)
     341                if (e.time == null) {
    344342                    continue;
     343                }
    345344
    346345                data.add(e);
     
    350349        }
    351350        @Override protected void finish() {
    352             if (layer != null)
     351            if (layer != null) {
    353352                Main.main.addLayer(layer);
     353            }
    354354        }
    355355        @Override
     
    412412                    return;
    413413                mousePressed  = true;
    414                 if (visible)
     414                if (visible) {
    415415                    Main.map.mapView.repaint();
     416                }
    416417            }
    417418            @Override public void mouseReleased(MouseEvent ev) {
     
    423424                for (int i = data.size(); i > 0; --i) {
    424425                    ImageEntry e = data.get(i-1);
    425                     if (e.pos == null)
     426                    if (e.pos == null) {
    426427                        continue;
     428                    }
    427429                    Point p = Main.map.mapView.getPoint(e.pos);
    428430                    Rectangle r = new Rectangle(p.x-ICON_SIZE/2, p.y-ICON_SIZE/2, ICON_SIZE, ICON_SIZE);
     
    440442            public void layerAdded(Layer newLayer) {}
    441443            public void layerRemoved(Layer oldLayer) {
    442                 if (oldLayer == self)
     444                if (oldLayer == self) {
    443445                    Main.map.mapView.removeMouseListener(mouseAdapter);
     446                }
    444447            }
    445448        });
     
    550553            nextButton.setEnabled(currentImage < data.size() - 1);
    551554
    552             if (scaleToggle.getModel().isSelected())
     555            if (scaleToggle.getModel().isSelected()) {
    553556                imageLabel.setIcon(new ImageIcon(imageLoader.waitForImage(currentImageEntry.image,
    554557                        Math.max(imageViewport.getWidth(), imageViewport.getHeight()))));
    555             else
     558            } else {
    556559                imageLabel.setIcon(new ImageIcon(imageLoader.waitForImage(currentImageEntry.image)));
    557 
    558             if (centerToggle.getModel().isSelected())
     560            }
     561
     562            if (centerToggle.getModel().isSelected()) {
    559563                Main.map.mapView.zoomTo(currentImageEntry.pos);
     564            }
    560565
    561566            dlg.setTitle(currentImageEntry.image +
     
    594599                setIcon(new ImageIcon(e.getIcon()));
    595600                setText(e.image.getName()+" ("+dateFormat.format(new Date(e.time.getTime()+(delta+gpstimezone)))+")");
    596                 if (e.pos == null)
     601                if (e.pos == null) {
    597602                    setForeground(Color.red);
     603                }
    598604                return this;
    599605            }
     
    607613        int i = 0;
    608614        for (ImageEntry e : data)
    609             if (e.pos != null)
     615            if (e.pos != null) {
    610616                i++;
     617            }
    611618        return data.size()+" "+trn("image","images",data.size())+". "+tr("{0} within the track.",i);
    612619    }
     
    662669
    663670    @Override public void visitBoundingBox(BoundingXYVisitor v) {
    664         for (ImageEntry e : data)
     671        for (ImageEntry e : data) {
    665672            v.visit(e.pos);
     673        }
    666674    }
    667675
     
    723731            exifDate = ExifReader.readTime(f);
    724732        } catch (ParseException e) {
    725             JOptionPane.showMessageDialog(Main.parent, tr("The date in file \"{0}\" could not be parsed.", f.getName()));
     733            OptionPaneUtil.showMessageDialog(
     734                    Main.parent,
     735                    tr("The date in file \"{0}\" could not be parsed.", f.getName()),
     736                    tr("Error"),
     737                    JOptionPane.ERROR_MESSAGE
     738            );
    726739            return;
    727740        }
    728741        if (exifDate == null) {
    729             JOptionPane.showMessageDialog(Main.parent, tr("There is no EXIF time within the file \"{0}\".", f.getName()));
     742            OptionPaneUtil.showMessageDialog(
     743                    Main.parent,
     744                    tr("There is no EXIF time within the file \"{0}\".", f.getName()),
     745                    tr("Error"),
     746                    JOptionPane.ERROR_MESSAGE
     747            );
    730748            return;
    731749        }
     
    738756        p.add(new JLabel(tr("GPS unit timezone (difference to photo)")), GBC.eol());
    739757        String t = Main.pref.get("tagimages.gpstimezone", "0");
    740         if (t.charAt(0) != '-')
     758        if (t.charAt(0) != '-') {
    741759            t = "+"+t;
     760        }
    742761        JTextField gpsTimezone = new JTextField(t);
    743762        p.add(gpsTimezone, GBC.eol().fill(GBC.HORIZONTAL));
    744763
    745764        while (true) {
    746             int answer = JOptionPane.showConfirmDialog(Main.parent, p, tr("Synchronize Time with GPS Unit"), JOptionPane.OK_CANCEL_OPTION);
     765            int answer = OptionPaneUtil.showConfirmationDialog(
     766                    Main.parent,
     767                    p,
     768                    tr("Synchronize Time with GPS Unit"),
     769                    JOptionPane.OK_CANCEL_OPTION,
     770                    JOptionPane.QUESTION_MESSAGE
     771            );
    747772            if (answer != JOptionPane.OK_OPTION || gpsText.getText().equals(""))
    748773                return;
     
    750775                delta = DateParser.parse(gpsText.getText()).getTime() - exifDate.getTime();
    751776                String time = gpsTimezone.getText();
    752                 if (!time.equals("") && time.charAt(0) == '+')
     777                if (!time.equals("") && time.charAt(0) == '+') {
    753778                    time = time.substring(1);
    754                 if (time.equals(""))
     779                }
     780                if (time.equals("")) {
    755781                    time = "0";
     782                }
    756783                gpstimezone = Long.valueOf(time)*60*60*1000;
    757784                Main.pref.put("tagimages.delta", ""+delta);
     
    760787                return;
    761788            } catch (NumberFormatException x) {
    762                 JOptionPane.showMessageDialog(Main.parent, tr("Time entered could not be parsed."));
     789                OptionPaneUtil.showMessageDialog(
     790                        Main.parent,
     791                        tr("Time entered could not be parsed."),
     792                        tr("Error"),
     793                        JOptionPane.ERROR_MESSAGE
     794                );
    763795            } catch (ParseException x) {
    764                 JOptionPane.showMessageDialog(Main.parent, tr("Time entered could not be parsed."));
     796                OptionPaneUtil.showMessageDialog(
     797                        Main.parent,
     798                        tr("Time entered could not be parsed."),
     799                        tr("Error"),
     800                        JOptionPane.ERROR_MESSAGE
     801                );
    765802            }
    766803        }
  • trunk/src/org/openstreetmap/josm/gui/layer/GpxLayer.java

    r1838 r1865  
    5959import org.openstreetmap.josm.gui.ConditionalOptionPaneUtil;
    6060import org.openstreetmap.josm.gui.MapView;
     61import org.openstreetmap.josm.gui.OptionPaneUtil;
    6162import org.openstreetmap.josm.gui.dialogs.LayerListDialog;
    6263import org.openstreetmap.josm.gui.dialogs.LayerListPopup;
     
    99100    }
    100101
    101     @Override public Icon getIcon() {
     102    @Override
     103    public Icon getIcon() {
    102104        return ImageProvider.get("layer", "gpx_small");
    103105    }
    104106
    105     @Override public Object getInfoComponent() {
     107    @Override
     108    public Object getInfoComponent() {
    106109        return getToolTipText();
    107110    }
    108111
    109     static public Color getColor(String name)
    110     {
    111         return Main.pref.getColor(marktr("gps point"), name != null ? "layer "+name : null, Color.gray);
    112     }
    113 
    114     @Override public Component[] getMenuEntries() {
     112    static public Color getColor(String name) {
     113        return Main.pref.getColor(marktr("gps point"), name != null ? "layer " + name : null, Color.gray);
     114    }
     115
     116    @Override
     117    public Component[] getMenuEntries() {
    115118        JMenuItem line = new JMenuItem(tr("Customize line drawing"), ImageProvider.get("mapmode/addsegment"));
    116119        line.addActionListener(new ActionListener() {
     
    126129                    panel.add(b);
    127130                }
    128                 String propName = "draw.rawgps.lines.layer "+name;
     131                String propName = "draw.rawgps.lines.layer " + name;
    129132                if (Main.pref.hasKey(propName)) {
    130                     group.setSelected(r[Main.pref.getBoolean(propName) ? 1:2].getModel(), true);
     133                    group.setSelected(r[Main.pref.getBoolean(propName) ? 1 : 2].getModel(), true);
    131134                } else {
    132135                    group.setSelected(r[0].getModel(), true);
    133136                }
    134                 int answer = JOptionPane.showConfirmDialog(Main.parent, panel, tr("Select line drawing options"), JOptionPane.OK_CANCEL_OPTION);
    135                 if (answer == JOptionPane.CANCEL_OPTION)
    136                     return;
     137                int answer = OptionPaneUtil.showConfirmationDialog(Main.parent, panel,
     138                        tr("Select line drawing options"), JOptionPane.OK_CANCEL_OPTION, JOptionPane.QUESTION_MESSAGE);
     139                switch (answer) {
     140                    case JOptionPane.CANCEL_OPTION:
     141                    case JOptionPane.CLOSED_OPTION:
     142                        return;
     143                    default:
     144                        // continue
     145                }
    137146                if (group.getSelection() == r[0].getModel()) {
    138147                    Main.pref.put(propName, null);
     
    149158            public void actionPerformed(ActionEvent e) {
    150159                JColorChooser c = new JColorChooser(getColor(name));
    151                 Object[] options = new Object[]{tr("OK"), tr("Cancel"), tr("Default")};
    152                 int answer = JOptionPane.showOptionDialog(Main.parent, c, tr("Choose a color"), JOptionPane.OK_CANCEL_OPTION,
    153                         JOptionPane.PLAIN_MESSAGE, null, options, options[0]);
     160                Object[] options = new Object[] { tr("OK"), tr("Cancel"), tr("Default") };
     161                int answer = OptionPaneUtil.showOptionDialog(
     162                        Main.parent,
     163                        c,
     164                        tr("Choose a color"),
     165                        JOptionPane.OK_CANCEL_OPTION,
     166                        JOptionPane.PLAIN_MESSAGE,
     167                        options, options[0]
     168                );
    154169                switch (answer) {
    155                 case 0:
    156                     Main.pref.putColor("layer "+name, c.getColor());
    157                     break;
    158                 case 1:
    159                     return;
    160                 case 2:
    161                     Main.pref.putColor("layer "+name, null);
    162                     break;
     170                    case 0:
     171                        Main.pref.putColor("layer " + name, c.getColor());
     172                        break;
     173                    case 1:
     174                        return;
     175                    case 2:
     176                        Main.pref.putColor("layer " + name, null);
     177                        break;
    163178                }
    164179                Main.map.repaint();
     
    166181        });
    167182
    168         JMenuItem markersFromNamedTrackpoints = new JMenuItem(tr("Markers From Named Points"), ImageProvider.get("addmarkers"));
     183        JMenuItem markersFromNamedTrackpoints = new JMenuItem(tr("Markers From Named Points"), ImageProvider
     184                .get("addmarkers"));
    169185        markersFromNamedTrackpoints.putClientProperty("help", "Action/MarkersFromNamedPoints");
    170186        markersFromNamedTrackpoints.addActionListener(new ActionListener() {
     
    180196                }
    181197
    182                 MarkerLayer ml = new MarkerLayer(namedTrackPoints, tr("Named Trackpoints from {0}", name), getAssociatedFile(), me);
     198                MarkerLayer ml = new MarkerLayer(namedTrackPoints, tr("Named Trackpoints from {0}", name),
     199                        getAssociatedFile(), me);
    183200                if (ml.data.size() > 0) {
    184201                    Main.main.addLayer(ml);
     
    195212                fc.setFileSelectionMode(JFileChooser.FILES_ONLY);
    196213                fc.setAcceptAllFileFilterUsed(false);
    197                 fc.setFileFilter(new FileFilter(){
    198                     @Override public boolean accept(File f) {
     214                fc.setFileFilter(new FileFilter() {
     215                    @Override
     216                    public boolean accept(File f) {
    199217                        return f.isDirectory() || f.getName().toLowerCase().endsWith(".wav");
    200218                    }
    201                     @Override public String getDescription() {
     219
     220                    @Override
     221                    public String getDescription() {
    202222                        return tr("Wave Audio files (*.wav)");
    203223                    }
    204224                });
    205225                fc.setMultiSelectionEnabled(true);
    206                 if(fc.showOpenDialog(Main.parent) == JFileChooser.APPROVE_OPTION) {
     226                if (fc.showOpenDialog(Main.parent) == JFileChooser.APPROVE_OPTION) {
    207227                    if (!fc.getCurrentDirectory().getAbsolutePath().equals(dir)) {
    208228                        Main.pref.put("markers.lastaudiodirectory", fc.getCurrentDirectory().getAbsolutePath());
     
    210230
    211231                    File sel[] = fc.getSelectedFiles();
    212                     if(sel != null) {
    213                         // sort files in increasing order of timestamp (this is the end time, but so long as they don't overlap, that's fine)
     232                    if (sel != null) {
     233                        // sort files in increasing order of timestamp (this is the end time, but so
     234                        // long as they don't overlap, that's fine)
    214235                        if (sel.length > 1) {
    215236                            Arrays.sort(sel, new Comparator<File>() {
     
    223244                    String names = null;
    224245                    for (int i = 0; i < sel.length; i++) {
    225                         if(names == null) {
     246                        if (names == null) {
    226247                            names = " (";
    227248                        } else {
     
    230251                        names += sel[i].getName();
    231252                    }
    232                     if(names != null) {
     253                    if (names != null) {
    233254                        names += ")";
    234255                    } else {
     
    237258                    MarkerLayer ml = new MarkerLayer(new GpxData(), tr("Audio markers from {0}", name) + names,
    238259                            getAssociatedFile(), me);
    239                     if(sel != null)
    240                     {
    241                         double firstStartTime = sel[0].lastModified()/1000.0 /* ms -> seconds */ - AudioUtil.getCalibratedDuration(sel[0]);
     260                    if (sel != null) {
     261                        double firstStartTime = sel[0].lastModified() / 1000.0 /* ms -> seconds */
     262                        - AudioUtil.getCalibratedDuration(sel[0]);
    242263                        for (int i = 0; i < sel.length; i++) {
    243264                            importAudio(sel[i], ml, firstStartTime);
     
    259280                fc.setAcceptAllFileFilterUsed(false);
    260281                fc.setFileFilter(new FileFilter() {
    261                     @Override public boolean accept(File f) {
     282                    @Override
     283                    public boolean accept(File f) {
    262284                        return f.isDirectory() || f.getName().toLowerCase().endsWith(".jpg");
    263285                    }
    264                     @Override public String getDescription() {
     286
     287                    @Override
     288                    public String getDescription() {
    265289                        return tr("JPEG images (*.jpg)");
    266290                    }
     
    288312
    289313        if (Main.applet)
    290             return new Component[] {
    291                 new JMenuItem(new LayerListDialog.ShowHideLayerAction(this)),
    292                 new JMenuItem(new LayerListDialog.DeleteLayerAction(this)),
    293                 new JSeparator(),
    294                 color,
    295                 line,
    296                 new JMenuItem(new ConvertToDataLayerAction()),
    297                 new JSeparator(),
    298                 new JMenuItem(new RenameLayerAction(getAssociatedFile(), this)),
    299                 new JSeparator(),
    300                 new JMenuItem(new LayerListPopup.InfoAction(this))};
    301         return new Component[] {
    302                 new JMenuItem(new LayerListDialog.ShowHideLayerAction(this)),
    303                 new JMenuItem(new LayerListDialog.DeleteLayerAction(this)),
    304                 new JSeparator(),
    305                 new JMenuItem(new LayerSaveAction(this)),
    306                 new JMenuItem(new LayerSaveAsAction(this)),
    307                 color,
    308                 line,
    309                 tagimage,
    310                 importAudio,
    311                 markersFromNamedTrackpoints,
    312                 new JMenuItem(new ConvertToDataLayerAction()),
    313                 new JMenuItem(new DownloadAlongTrackAction()),
    314                 new JSeparator(),
    315                 new JMenuItem(new RenameLayerAction(getAssociatedFile(), this)),
    316                 new JSeparator(),
    317                 new JMenuItem(new LayerListPopup.InfoAction(this))};
    318     }
    319 
    320     @Override public String getToolTipText() {
     314            return new Component[] { new JMenuItem(new LayerListDialog.ShowHideLayerAction(this)),
     315                new JMenuItem(new LayerListDialog.DeleteLayerAction(this)), new JSeparator(), color, line,
     316                new JMenuItem(new ConvertToDataLayerAction()), new JSeparator(),
     317                new JMenuItem(new RenameLayerAction(getAssociatedFile(), this)), new JSeparator(),
     318                new JMenuItem(new LayerListPopup.InfoAction(this)) };
     319        return new Component[] { new JMenuItem(new LayerListDialog.ShowHideLayerAction(this)),
     320                new JMenuItem(new LayerListDialog.DeleteLayerAction(this)), new JSeparator(),
     321                new JMenuItem(new LayerSaveAction(this)), new JMenuItem(new LayerSaveAsAction(this)), color, line,
     322                tagimage, importAudio, markersFromNamedTrackpoints, new JMenuItem(new ConvertToDataLayerAction()),
     323                new JMenuItem(new DownloadAlongTrackAction()), new JSeparator(),
     324                new JMenuItem(new RenameLayerAction(getAssociatedFile(), this)), new JSeparator(),
     325                new JMenuItem(new LayerListPopup.InfoAction(this)) };
     326    }
     327
     328    @Override
     329    public String getToolTipText() {
    321330        StringBuilder info = new StringBuilder().append("<html>");
    322331
    323         info.append(trn("{0} track, ", "{0} tracks, ",
    324                 data.tracks.size(), data.tracks.size())).append(trn("{0} route, ", "{0} routes, ",
    325                         data.routes.size(), data.routes.size())).append(trn("{0} waypoint", "{0} waypoints",
    326                                 data.waypoints.size(), data.waypoints.size())).append("<br>");
     332        info.append(trn("{0} track, ", "{0} tracks, ", data.tracks.size(), data.tracks.size())).append(
     333                trn("{0} route, ", "{0} routes, ", data.routes.size(), data.routes.size())).append(
     334                        trn("{0} waypoint", "{0} waypoints", data.waypoints.size(), data.waypoints.size())).append("<br>");
    327335
    328336        if (data.attr.containsKey("name")) {
     
    334342        }
    335343
    336         if(data.tracks.size() > 0){
     344        if (data.tracks.size() > 0) {
    337345            boolean first = true;
    338346            WayPoint earliest = null, latest = null;
    339347
    340             for(GpxTrack trk: data.tracks){
    341                 for(Collection<WayPoint> seg:trk.trackSegs){
    342                     for(WayPoint pnt:seg){
    343                         if(first){
     348            for (GpxTrack trk : data.tracks) {
     349                for (Collection<WayPoint> seg : trk.trackSegs) {
     350                    for (WayPoint pnt : seg) {
     351                        if (first) {
    344352                            latest = earliest = pnt;
    345353                            first = false;
    346                         }else{
    347                             if(pnt.compareTo(earliest) < 0){
     354                        } else {
     355                            if (pnt.compareTo(earliest) < 0) {
    348356                                earliest = pnt;
    349                             }else{
     357                            } else {
    350358                                latest = pnt;
    351359                            }
     
    356364            if (earliest != null && latest != null) {
    357365                DateFormat df = DateFormat.getDateTimeInstance(DateFormat.MEDIUM, DateFormat.SHORT);
    358                 info.append(tr("Timespan: ") + df.format(new Date((long)(earliest.time * 1000))) + " - "
    359                         + df.format(new Date((long)(latest.time * 1000))));
    360                 int diff = (int)(latest.time - earliest.time);
    361                 info.append(" (" + (diff / 3600) + ":" + ((diff % 3600)/60) + ")");
     366                info.append(tr("Timespan: ") + df.format(new Date((long) (earliest.time * 1000))) + " - "
     367                        + df.format(new Date((long) (latest.time * 1000))));
     368                int diff = (int) (latest.time - earliest.time);
     369                info.append(" (" + (diff / 3600) + ":" + ((diff % 3600) / 60) + ")");
    362370                info.append("<br>");
    363371            }
     
    369377    }
    370378
    371     @Override public boolean isMergable(Layer other) {
     379    @Override
     380    public boolean isMergable(Layer other) {
    372381        return other instanceof GpxLayer;
    373382    }
    374383
    375     @Override public void mergeFrom(Layer from) {
    376         data.mergeFrom(((GpxLayer)from).data);
     384    @Override
     385    public void mergeFrom(Layer from) {
     386        data.mergeFrom(((GpxLayer) from).data);
    377387        computeCacheInSync = false;
    378388    }
     
    381391    static {
    382392        for (int i = 0; i < colors.length; i++) {
    383             colors[i] = Color.getHSBColor(i/300.0f, 1, 1);
     393            colors[i] = Color.getHSBColor(i / 300.0f, 1, 1);
    384394        }
    385395    }
     
    389399    private static int sl4 = 5;
    390400    private static int sl9 = 3;
    391     private static int[][] dir = {
    392         {+sl4,+ll0,+ll0,+sl4},
    393         {-sl9,+ll0,+sl9,+ll0},
    394         {-ll0,+sl4,-sl4,+ll0},
    395         {-ll0,-sl9,-ll0,+sl9},
    396         {-sl4,-ll0,-ll0,-sl4},
    397         {+sl9,-ll0,-sl9,-ll0},
    398         {+ll0,-sl4,+sl4,-ll0},
    399         {+ll0,+sl9,+ll0,-sl9},
    400         {+sl4,+ll0,+ll0,+sl4},
    401         {-sl9,+ll0,+sl9,+ll0},
    402         {-ll0,+sl4,-sl4,+ll0},
    403         {-ll0,-sl9,-ll0,+sl9}
    404     };
     401    private static int[][] dir = { { +sl4, +ll0, +ll0, +sl4 }, { -sl9, +ll0, +sl9, +ll0 }, { -ll0, +sl4, -sl4, +ll0 },
     402        { -ll0, -sl9, -ll0, +sl9 }, { -sl4, -ll0, -ll0, -sl4 }, { +sl9, -ll0, -sl9, -ll0 },
     403        { +ll0, -sl4, +sl4, -ll0 }, { +ll0, +sl9, +ll0, -sl9 }, { +sl4, +ll0, +ll0, +sl4 },
     404        { -sl9, +ll0, +sl9, +ll0 }, { -ll0, +sl4, -sl4, +ll0 }, { -ll0, -sl9, -ll0, +sl9 } };
    405405
    406406    // the different color modes
    407     enum colorModes { none, velocity, dilution }
    408 
    409     @Override public void paint(Graphics g, MapView mv) {
     407    enum colorModes {
     408        none, velocity, dilution
     409    }
     410
     411    @Override
     412    public void paint(Graphics g, MapView mv) {
    410413
    411414        /****************************************************************
     
    426429        }
    427430        // draw line between points, global setting
    428         boolean lines = (Main.pref.getBoolean("draw.rawgps.lines", true) || (Main.pref.getBoolean("draw.rawgps.lines.localfiles") && this.isLocalFile));
    429         String linesKey = "draw.rawgps.lines.layer "+name;
     431        boolean lines = (Main.pref.getBoolean("draw.rawgps.lines", true) || (Main.pref
     432                .getBoolean("draw.rawgps.lines.localfiles") && this.isLocalFile));
     433        String linesKey = "draw.rawgps.lines.layer " + name;
    430434        // draw lines, per-layer setting
    431435        if (Main.pref.hasKey(linesKey)) {
     
    438442        try {
    439443            colored = colorModes.values()[Main.pref.getInteger("draw.rawgps.colors", 0)];
    440         } catch(Exception e) { }
     444        } catch (Exception e) {
     445        }
    441446        // paint direction arrow with alternate math. may be faster
    442447        boolean alternatedirection = Main.pref.getBoolean("draw.rawgps.alternatedirection");
     
    448453         ********** STEP 2a - CHECK CACHE VALIDITY **********************
    449454         ****************************************************************/
    450         if (computeCacheInSync && ((computeCacheMaxLineLengthUsed != maxLineLength) ||
    451                 (!neutralColor.equals(computeCacheColorUsed)) ||
    452                 (computeCacheColored != colored) ||
    453                 (computeCacheColorTracksTune != colorTracksTune))) {
    454             //          System.out.println("(re-)computing gpx line styles, reason: CCIS=" + computeCacheInSync + " CCMLLU=" + (computeCacheMaxLineLengthUsed != maxLineLength) + " CCCU=" +  (!neutralColor.equals(computeCacheColorUsed)) + " CCC=" + (computeCacheColored != colored));
     455        if (computeCacheInSync
     456                && ((computeCacheMaxLineLengthUsed != maxLineLength) || (!neutralColor.equals(computeCacheColorUsed))
     457                        || (computeCacheColored != colored) || (computeCacheColorTracksTune != colorTracksTune))) {
     458            // System.out.println("(re-)computing gpx line styles, reason: CCIS=" +
     459            // computeCacheInSync + " CCMLLU=" + (computeCacheMaxLineLengthUsed != maxLineLength) +
     460            // " CCCU=" + (!neutralColor.equals(computeCacheColorUsed)) + " CCC=" +
     461            // (computeCacheColored != colored));
    455462            computeCacheMaxLineLengthUsed = maxLineLength;
    456463            computeCacheInSync = false;
     
    479486                            double dist = c.greatCircleDistance(oldWp.getCoor());
    480487
    481                             switch(colored) {
    482                             case velocity:
    483                                 double dtime = trkPnt.time - oldWp.time;
    484                                 double vel = dist/dtime;
    485                                 double velColor = vel/colorTracksTune*255;
    486                                 // Bad case first
    487                                 if (dtime <= 0 || vel < 0 || velColor > 255) {
    488                                     trkPnt.customColoring = colors[255];
    489                                 } else {
    490                                     trkPnt.customColoring = colors[(int) (velColor)];
    491                                 }
    492                                 break;
    493 
    494                             case dilution:
    495                                 if(trkPnt.attr.get("hdop") != null) {
    496                                     float hdop = ((Float)trkPnt.attr.get("hdop")).floatValue();
    497                                     if (hdop < 0) {
    498                                         hdop = 0;
     488                            switch (colored) {
     489                                case velocity:
     490                                    double dtime = trkPnt.time - oldWp.time;
     491                                    double vel = dist / dtime;
     492                                    double velColor = vel / colorTracksTune * 255;
     493                                    // Bad case first
     494                                    if (dtime <= 0 || vel < 0 || velColor > 255) {
     495                                        trkPnt.customColoring = colors[255];
     496                                    } else {
     497                                        trkPnt.customColoring = colors[(int) (velColor)];
    499498                                    }
    500                                     int hdoplvl = Math.round(hdop * Main.pref.getInteger("hdop.factor", 25));
    501                                     // High hdop is bad, but high values in colors are green.
    502                                     // Therefore inverse the logic
    503                                     int hdopcolor = 255 - (hdoplvl > 255 ? 255 : hdoplvl);
    504                                     trkPnt.customColoring = colors[hdopcolor];
    505                                 }
    506                                 break;
     499                                    break;
     500
     501                                case dilution:
     502                                    if (trkPnt.attr.get("hdop") != null) {
     503                                        float hdop = ((Float) trkPnt.attr.get("hdop")).floatValue();
     504                                        if (hdop < 0) {
     505                                            hdop = 0;
     506                                        }
     507                                        int hdoplvl = Math.round(hdop * Main.pref.getInteger("hdop.factor", 25));
     508                                        // High hdop is bad, but high values in colors are green.
     509                                        // Therefore inverse the logic
     510                                        int hdopcolor = 255 - (hdoplvl > 255 ? 255 : hdoplvl);
     511                                        trkPnt.customColoring = colors[hdopcolor];
     512                                    }
     513                                    break;
    507514                            }
    508515
    509516                            if (maxLineLength == -1 || dist <= maxLineLength) {
    510517                                trkPnt.drawLine = true;
    511                                 trkPnt.dir = (int)oldWp.getCoor().heading(trkPnt.getCoor());
     518                                trkPnt.dir = (int) oldWp.getCoor().heading(trkPnt.getCoor());
    512519                            } else {
    513520                                trkPnt.drawLine = false;
     
    565572                            Point screen = mv.getPoint(trkPnt.getEastNorth());
    566573                            // skip points that are on the same screenposition
    567                             if (old != null && (oldA == null || screen.x < oldA.x-delta || screen.x > oldA.x+delta || screen.y < oldA.y-delta || screen.y > oldA.y+delta)) {
     574                            if (old != null
     575                                    && (oldA == null || screen.x < oldA.x - delta || screen.x > oldA.x + delta
     576                                            || screen.y < oldA.y - delta || screen.y > oldA.y + delta)) {
    568577                                g.setColor(trkPnt.customColoring);
    569                                 double t = Math.atan2(screen.y-old.y, screen.x-old.x) + Math.PI;
    570                                 g.drawLine(screen.x,screen.y, (int)(screen.x + 10*Math.cos(t-PHI)), (int)(screen.y
    571                                         + 10*Math.sin(t-PHI)));
    572                                 g.drawLine(screen.x,screen.y, (int)(screen.x + 10*Math.cos(t+PHI)), (int)(screen.y
    573                                         + 10*Math.sin(t+PHI)));
     578                                double t = Math.atan2(screen.y - old.y, screen.x - old.x) + Math.PI;
     579                                g.drawLine(screen.x, screen.y, (int) (screen.x + 10 * Math.cos(t - PHI)),
     580                                        (int) (screen.y + 10 * Math.sin(t - PHI)));
     581                                g.drawLine(screen.x, screen.y, (int) (screen.x + 10 * Math.cos(t + PHI)),
     582                                        (int) (screen.y + 10 * Math.sin(t + PHI)));
    574583                                oldA = screen;
    575584                            }
     
    597606                            Point screen = mv.getPoint(trkPnt.getEastNorth());
    598607                            // skip points that are on the same screenposition
    599                             if (old != null && (oldA == null || screen.x < oldA.x-delta || screen.x > oldA.x+delta || screen.y < oldA.y-delta || screen.y > oldA.y+delta)) {
     608                            if (old != null
     609                                    && (oldA == null || screen.x < oldA.x - delta || screen.x > oldA.x + delta
     610                                            || screen.y < oldA.y - delta || screen.y > oldA.y + delta)) {
    600611                                g.setColor(trkPnt.customColoring);
    601                                 g.drawLine(screen.x, screen.y, screen.x + dir[trkPnt.dir][0], screen.y + dir[trkPnt.dir][1]);
    602                                 g.drawLine(screen.x, screen.y, screen.x + dir[trkPnt.dir][2], screen.y + dir[trkPnt.dir][3]);
     612                                g.drawLine(screen.x, screen.y, screen.x + dir[trkPnt.dir][0], screen.y
     613                                        + dir[trkPnt.dir][1]);
     614                                g.drawLine(screen.x, screen.y, screen.x + dir[trkPnt.dir][2], screen.y
     615                                        + dir[trkPnt.dir][3]);
    603616                                oldA = screen;
    604617                            }
     
    624637                        Point screen = mv.getPoint(trkPnt.getEastNorth());
    625638                        g.setColor(trkPnt.customColoring);
    626                         g.fillRect(screen.x-1, screen.y-1, 3, 3);
     639                        g.fillRect(screen.x - 1, screen.y - 1, 3, 3);
    627640                    } // end for trkpnt
    628641                } // end for segment
     
    633646         ********** STEP 3e - DRAW SMALL POINTS FOR LINES ***************
    634647         ****************************************************************/
    635         if (!large && lines){
     648        if (!large && lines) {
    636649            g.setColor(neutralColor);
    637650            for (GpxTrack trk : data.tracks) {
     
    654667         ********** STEP 3f - DRAW SMALL POINTS INSTEAD OF LINES ********
    655668         ****************************************************************/
    656         if (!large && !lines){
     669        if (!large && !lines) {
    657670            g.setColor(neutralColor);
    658671            for (GpxTrack trk : data.tracks) {
     
    671684        } // end if large
    672685
    673         //Long duration = System.currentTimeMillis() - startTime;
    674         //System.out.println(duration);
     686        // Long duration = System.currentTimeMillis() - startTime;
     687        // System.out.println(duration);
    675688    } // end paint
    676689
    677     @Override public void visitBoundingBox(BoundingXYVisitor v) {
     690    @Override
     691    public void visitBoundingBox(BoundingXYVisitor v) {
    678692        v.visit(data.recalculateBounds());
    679693    }
     
    683697            super(tr("Convert to data layer"), ImageProvider.get("converttoosm"));
    684698        }
     699
    685700        public void actionPerformed(ActionEvent e) {
    686701            JPanel msg = new JPanel(new GridBagLayout());
    687             msg.add(new JLabel(tr("<html>Upload of unprocessed GPS data as map data is considered harmful.<br>If you want to upload traces, look here:")), GBC.eol());
     702            msg
     703            .add(
     704                    new JLabel(
     705                            tr("<html>Upload of unprocessed GPS data as map data is considered harmful.<br>If you want to upload traces, look here:")),
     706                            GBC.eol());
    688707            msg.add(new UrlLabel(tr("http://www.openstreetmap.org/traces")), GBC.eop());
    689             if (!ConditionalOptionPaneUtil.showConfirmationDialog(
    690                     "convert_to_data",
    691                     Main.parent,
    692                     msg,
    693                     tr("Warning"),
    694                     JOptionPane.OK_CANCEL_OPTION,
    695                     JOptionPane.WARNING_MESSAGE,
    696                     JOptionPane.OK_OPTION))
     708            if (!ConditionalOptionPaneUtil.showConfirmationDialog("convert_to_data", Main.parent, msg, tr("Warning"),
     709                    JOptionPane.OK_CANCEL_OPTION, JOptionPane.WARNING_MESSAGE, JOptionPane.OK_OPTION))
    697710                return;
    698711            DataSet ds = new DataSet();
     
    703716                        Node n = new Node(p.getCoor());
    704717                        String timestr = p.getString("time");
    705                         if(timestr != null)
    706                         {
     718                        if (timestr != null) {
    707719                            n.setTimestamp(DateUtils.fromString(timestr));
    708720                        }
     
    713725                }
    714726            }
    715             Main.main.addLayer(new OsmDataLayer(ds, tr("Converted from: {0}", GpxLayer.this.name),
    716                     getAssociatedFile()));
     727            Main.main
     728            .addLayer(new OsmDataLayer(ds, tr("Converted from: {0}", GpxLayer.this.name), getAssociatedFile()));
    717729            Main.main.removeLayer(GpxLayer.this);
    718730        }
     
    720732
    721733    @Override
    722     public File getAssociatedFile() { return data.storageFile; }
     734    public File getAssociatedFile() {
     735        return data.storageFile;
     736    }
     737
    723738    @Override
    724     public void setAssociatedFile(File file) { data.storageFile = file; }
     739    public void setAssociatedFile(File file) {
     740        data.storageFile = file;
     741    }
    725742
    726743    /**
    727744     * Action that issues a series of download requests to the API, following the GPX track.
    728      *
     745     * 
    729746     * @author fred
    730747     */
     
    733750            super(tr("Download from OSM along this track"), ImageProvider.get("downloadalongtrack"));
    734751        }
     752
    735753        public void actionPerformed(ActionEvent e) {
    736754            JPanel msg = new JPanel(new GridBagLayout());
    737             Integer dist[] = {5000, 500, 50};
    738             Integer area[] = {20, 10, 5, 1};
     755            Integer dist[] = { 5000, 500, 50 };
     756            Integer area[] = { 20, 10, 5, 1 };
    739757
    740758            msg.add(new JLabel(tr("Download everything within:")), GBC.eol());
    741759            String s[] = new String[dist.length];
    742             for(int i = 0; i < dist.length; ++i) {
     760            for (int i = 0; i < dist.length; ++i) {
    743761                s[i] = tr("{0} meters", dist[i]);
    744762            }
     
    747765            msg.add(new JLabel(tr("Maximum area per request:")), GBC.eol());
    748766            s = new String[area.length];
    749             for(int i = 0; i < area.length; ++i) {
     767            for (int i = 0; i < area.length; ++i) {
    750768                s[i] = tr("{0} sq km", area[i]);
    751769            }
     
    753771            msg.add(maxRect, GBC.eol());
    754772
    755             if (JOptionPane.showConfirmDialog(Main.parent, msg,
     773            int ret = OptionPaneUtil.showConfirmationDialog(
     774                    Main.parent,
     775                    msg,
    756776                    tr("Download from OSM along this track"),
    757                     JOptionPane.OK_CANCEL_OPTION) == JOptionPane.CANCEL_OPTION)
    758                 return;
     777                    JOptionPane.OK_CANCEL_OPTION,
     778                    JOptionPane.QUESTION_MESSAGE
     779            );
     780            switch(ret) {
     781                case JOptionPane.CANCEL_OPTION:
     782                case JOptionPane.CLOSED_OPTION:
     783                    return;
     784                default:
     785                    // continue
     786            }
    759787
    760788            /*
    761              * Find the average latitude for the data we're contemplating, so we can
    762              * know how many metres per degree of longitude we have.
     789             * Find the average latitude for the data we're contemplating, so we can know how many
     790             * metres per degree of longitude we have.
    763791             */
    764792            double latsum = 0;
     
    769797                    for (WayPoint p : segment) {
    770798                        latsum += p.getCoor().lat();
    771                         latcnt ++;
     799                        latcnt++;
    772800                    }
    773801                }
     
    778806
    779807            /*
    780              * Compute buffer zone extents and maximum bounding box size. Note that the
    781              * maximum we ever offer is a bbox area of 0.002, while the API theoretically
    782              * supports 0.25, but as soon as you touch any built-up area, that kind of
    783              * bounding box will download forever and then stop because it has more than
    784              * 50k nodes.
     808             * Compute buffer zone extents and maximum bounding box size. Note that the maximum we
     809             * ever offer is a bbox area of 0.002, while the API theoretically supports 0.25, but as
     810             * soon as you touch any built-up area, that kind of bounding box will download forever
     811             * and then stop because it has more than 50k nodes.
    785812             */
    786813            Integer i = buffer.getSelectedIndex();
     
    794821
    795822            /*
    796              * Collect the combined area of all gpx points plus buffer zones around them.
    797              * We ignore points that lie closer to the previous point than the given buffer
    798              * size because otherwise this operation takes ages.
     823             * Collect the combined area of all gpx points plus buffer zones around them. We ignore
     824             * points that lie closer to the previous point than the given buffer size because
     825             * otherwise this operation takes ages.
    799826             */
    800827            LatLon previous = null;
     
    805832                        if (previous == null || c.greatCircleDistance(previous) > buffer_dist) {
    806833                            // we add a buffer around the point.
    807                             r.setRect(c.lon()-buffer_x, c.lat()-buffer_y, 2*buffer_x, 2*buffer_y);
     834                            r.setRect(c.lon() - buffer_x, c.lat() - buffer_y, 2 * buffer_x, 2 * buffer_y);
    808835                            a.add(new Area(r));
    809836                            previous = c;
     
    814841
    815842            /*
    816              * Area "a" now contains the hull that we would like to download data for.
    817              * however we can only download rectangles, so the following is an attempt at
    818              * finding a number of rectangles to download.
    819              *
    820              * The idea is simply: Start out with the full bounding box. If it is too large,
    821              * then split it in half and repeat recursively for each half until you arrive
    822              * at something small enough to download. The algorithm is improved
    823              * by always using the intersection between the rectangle and the actual desired
    824              * area. For example, if you have a track that goes like this:
    825              * +----+
    826              * |   /|
    827              * |  / |
    828              * | /  |
    829              * |/   |
    830              * +----+
    831              * then we would first look at downloading the whole rectangle (assume it's too big),
    832              * after that we split it in half (upper and lower half), but we do *not* request the
    833              * full upper and lower rectangle, only the part of the upper/lower rectangle that
    834              * actually has something in it.
     843             * Area "a" now contains the hull that we would like to download data for. however we
     844             * can only download rectangles, so the following is an attempt at finding a number of
     845             * rectangles to download.
     846             *
     847             * The idea is simply: Start out with the full bounding box. If it is too large, then
     848             * split it in half and repeat recursively for each half until you arrive at something
     849             * small enough to download. The algorithm is improved by always using the intersection
     850             * between the rectangle and the actual desired area. For example, if you have a track
     851             * that goes like this: +----+ | /| | / | | / | |/ | +----+ then we would first look at
     852             * downloading the whole rectangle (assume it's too big), after that we split it in half
     853             * (upper and lower half), but we donot request the full upper and lower rectangle, only
     854             * the part of the upper/lower rectangle that actually has something in it.
    835855             */
    836856
     
    841861            msg = new JPanel(new GridBagLayout());
    842862
    843             msg.add(new JLabel(tr("<html>This action will require {0} individual<br>download requests. Do you wish<br>to continue?</html>",
    844                     toDownload.size())), GBC.eol());
    845 
    846             if (toDownload.size() > 1 && JOptionPane.showConfirmDialog(Main.parent, msg,
    847                     tr("Download from OSM along this track"),
    848                     JOptionPane.OK_CANCEL_OPTION) == JOptionPane.CANCEL_OPTION)
    849                 return;
    850 
     863            msg
     864            .add(
     865                    new JLabel(
     866                            tr(
     867                                    "<html>This action will require {0} individual<br>download requests. Do you wish<br>to continue?</html>",
     868                                    toDownload.size())), GBC.eol());
     869
     870            if (toDownload.size() > 1) {
     871                ret = OptionPaneUtil.showConfirmationDialog(
     872                        Main.parent,
     873                        msg,
     874                        tr("Download from OSM along this track"),
     875                        JOptionPane.OK_CANCEL_OPTION,
     876                        JOptionPane.PLAIN_MESSAGE
     877                );
     878                switch(ret) {
     879                    case JOptionPane.CANCEL_OPTION:
     880                    case JOptionPane.CLOSED_OPTION:
     881                        return;
     882                    default:
     883                        // continue
     884                }
     885            }
    851886            new DownloadOsmTaskList().download(false, toDownload, new PleaseWaitProgressMonitor());
    852887        }
     
    857892        // intersect with sought-after area
    858893        tmp.intersect(a);
    859         if (tmp.isEmpty()) return;
     894        if (tmp.isEmpty())
     895            return;
    860896        Rectangle2D bounds = tmp.getBounds2D();
    861897        if (bounds.getWidth() * bounds.getHeight() > max_area) {
     
    865901            if (bounds.getWidth() > bounds.getHeight()) {
    866902                // rectangles that are wider than high are split into a left and right half,
    867                 r1 = new Rectangle2D.Double(bounds.getX(), bounds.getY(), bounds.getWidth()/2, bounds.getHeight());
    868                 r2 = new Rectangle2D.Double(bounds.getX()+bounds.getWidth()/2, bounds.getY(), bounds.getWidth()/2, bounds.getHeight());
     903                r1 = new Rectangle2D.Double(bounds.getX(), bounds.getY(), bounds.getWidth() / 2, bounds.getHeight());
     904                r2 = new Rectangle2D.Double(bounds.getX() + bounds.getWidth() / 2, bounds.getY(),
     905                        bounds.getWidth() / 2, bounds.getHeight());
    869906            } else {
    870907                // others into a top and bottom half.
    871                 r1 = new Rectangle2D.Double(bounds.getX(), bounds.getY(), bounds.getWidth(), bounds.getHeight()/2);
    872                 r2 = new Rectangle2D.Double(bounds.getX(), bounds.getY()+bounds.getHeight()/2, bounds.getWidth(), bounds.getHeight()/2);
     908                r1 = new Rectangle2D.Double(bounds.getX(), bounds.getY(), bounds.getWidth(), bounds.getHeight() / 2);
     909                r2 = new Rectangle2D.Double(bounds.getX(), bounds.getY() + bounds.getHeight() / 2, bounds.getWidth(),
     910                        bounds.getHeight() / 2);
    873911            }
    874912            addToDownload(a, r1, results, max_area);
     
    880918
    881919    /**
    882      * Makes a new marker layer derived from this GpxLayer containing at least one
    883      * audio marker which the given audio file is associated with.
    884      * Markers are derived from the following
    885      * (a) explict waypoints in the GPX layer, or
    886      * (b) named trackpoints in the GPX layer, or
    887      * (d) timestamp on the wav file
    888      * (e) (in future) voice recognised markers in the sound recording
    889      * (f) a single marker at the beginning of the track
     920     * Makes a new marker layer derived from this GpxLayer containing at least one audio marker
     921     * which the given audio file is associated with. Markers are derived from the following (a)
     922     * explict waypoints in the GPX layer, or (b) named trackpoints in the GPX layer, or (d)
     923     * timestamp on the wav file (e) (in future) voice recognised markers in the sound recording (f)
     924     * a single marker at the beginning of the track
    890925     * @param wavFile : the file to be associated with the markers in the new marker layer
    891926     */
     
    895930        boolean timedMarkersOmitted = false;
    896931        boolean untimedMarkersOmitted = false;
    897         double snapDistance = Main.pref.getDouble("marker.audiofromuntimedwaypoints.distance", 1.0e-3); /* about 25m */
     932        double snapDistance = Main.pref.getDouble("marker.audiofromuntimedwaypoints.distance", 1.0e-3); /*
     933         * about
     934         * 25
     935         * m
     936         */
    898937        WayPoint wayPointFromTimeStamp = null;
    899938
    900939        // determine time of first point in track
    901940        double firstTime = -1.0;
    902         if (data.tracks != null && ! data.tracks.isEmpty()) {
     941        if (data.tracks != null && !data.tracks.isEmpty()) {
    903942            for (GpxTrack track : data.tracks) {
    904943                if (track.trackSegs == null) {
     
    920959        }
    921960        if (firstTime < 0.0) {
    922             JOptionPane.showMessageDialog(Main.parent, tr("No GPX track available in layer to associate audio with."));
     961            OptionPaneUtil.showMessageDialog(
     962                    Main.parent,
     963                    tr("No GPX track available in layer to associate audio with."),
     964                    tr("Error"),
     965                    JOptionPane.ERROR_MESSAGE
     966            );
    923967            return;
    924968        }
    925969
    926970        // (a) try explicit timestamped waypoints - unless suppressed
    927         if (Main.pref.getBoolean("marker.audiofromexplicitwaypoints", true) &&
    928                 data.waypoints != null && ! data.waypoints.isEmpty())
    929         {
     971        if (Main.pref.getBoolean("marker.audiofromexplicitwaypoints", true) && data.waypoints != null
     972                && !data.waypoints.isEmpty()) {
    930973            for (WayPoint w : data.waypoints) {
    931974                if (w.time > firstTime) {
     
    938981
    939982        // (b) try explicit waypoints without timestamps - unless suppressed
    940         if (Main.pref.getBoolean("marker.audiofromuntimedwaypoints", true) &&
    941                 data.waypoints != null && ! data.waypoints.isEmpty())
    942         {
     983        if (Main.pref.getBoolean("marker.audiofromuntimedwaypoints", true) && data.waypoints != null
     984                && !data.waypoints.isEmpty()) {
    943985            for (WayPoint w : data.waypoints) {
    944                 if (waypoints.contains(w)) { continue; }
     986                if (waypoints.contains(w)) {
     987                    continue;
     988                }
    945989                WayPoint wNear = nearestPointOnTrack(w.getEastNorth(), snapDistance);
    946990                if (wNear != null) {
     
    9581002
    9591003        // (c) use explicitly named track points, again unless suppressed
    960         if ((Main.pref.getBoolean("marker.audiofromnamedtrackpoints", false)) &&
    961                 data.tracks != null && ! data.tracks.isEmpty())
    962         {
     1004        if ((Main.pref.getBoolean("marker.audiofromnamedtrackpoints", false)) && data.tracks != null
     1005                && !data.tracks.isEmpty()) {
    9631006            for (GpxTrack track : data.tracks) {
    9641007                if (track.trackSegs == null) {
     
    9761019
    9771020        // (d) use timestamp of file as location on track
    978         if ((Main.pref.getBoolean("marker.audiofromwavtimestamps", false)) &&
    979                 data.tracks != null && ! data.tracks.isEmpty())
    980         {
    981             double lastModified = wavFile.lastModified() / 1000.0; // lastModified is in milliseconds
     1021        if ((Main.pref.getBoolean("marker.audiofromwavtimestamps", false)) && data.tracks != null
     1022                && !data.tracks.isEmpty()) {
     1023            double lastModified = wavFile.lastModified() / 1000.0; // lastModified is in
     1024            // milliseconds
    9821025            double duration = AudioUtil.getCalibratedDuration(wavFile);
    9831026            double startTime = lastModified - duration;
    984             startTime = firstStartTime + (startTime - firstStartTime) /
    985             Main.pref.getDouble("audio.calibration", "1.0" /* default, ratio */);
     1027            startTime = firstStartTime + (startTime - firstStartTime)
     1028            / Main.pref.getDouble("audio.calibration", "1.0" /* default, ratio */);
    9861029            WayPoint w1 = null;
    9871030            WayPoint w2 = null;
     
    10081051                timedMarkersOmitted = true;
    10091052            } else {
    1010                 wayPointFromTimeStamp = new WayPoint(w1.getCoor().interpolate(
    1011                         w2.getCoor(), (startTime - w1.time)/(w2.time - w1.time)));
     1053                wayPointFromTimeStamp = new WayPoint(w1.getCoor().interpolate(w2.getCoor(),
     1054                        (startTime - w1.time) / (w2.time - w1.time)));
    10121055                wayPointFromTimeStamp.time = startTime;
    10131056                String name = wavFile.getName();
    10141057                int dot = name.lastIndexOf(".");
    1015                 if (dot > 0) { name = name.substring(0, dot); }
     1058                if (dot > 0) {
     1059                    name = name.substring(0, dot);
     1060                }
    10161061                wayPointFromTimeStamp.attr.put("name", name);
    10171062                waypoints.add(wayPointFromTimeStamp);
     
    10221067
    10231068        // (f) simply add a single marker at the start of the track
    1024         if ((Main.pref.getBoolean("marker.audiofromstart") || waypoints.isEmpty()) &&
    1025                 data.tracks != null && ! data.tracks.isEmpty())
    1026         {
     1069        if ((Main.pref.getBoolean("marker.audiofromstart") || waypoints.isEmpty()) && data.tracks != null
     1070                && !data.tracks.isEmpty()) {
    10271071            boolean gotOne = false;
    10281072            for (GpxTrack track : data.tracks) {
     
    10711115                name = AudioMarker.inventName(offset);
    10721116            }
    1073             AudioMarker am = AudioMarker.create(w.getCoor(),
    1074                     name, uri, ml, w.time, offset);
    1075             /* timeFromAudio intended for future use to shift markers of this type on synchronization */
     1117            AudioMarker am = AudioMarker.create(w.getCoor(), name, uri, ml, w.time, offset);
     1118            /*
     1119             * timeFromAudio intended for future use to shift markers of this type on
     1120             * synchronization
     1121             */
    10761122            if (w == wayPointFromTimeStamp) {
    10771123                am.timeFromAudio = true;
     
    10811127
    10821128        if (timedMarkersOmitted) {
    1083             JOptionPane.showMessageDialog(Main.parent,
     1129            JOptionPane
     1130            .showMessageDialog(
     1131                    Main.parent,
    10841132                    tr("Some waypoints with timestamps from before the start of the track or after the end were omitted or moved to the start."));
    10851133        }
    10861134        if (untimedMarkersOmitted) {
    1087             JOptionPane.showMessageDialog(Main.parent,
     1135            JOptionPane
     1136            .showMessageDialog(
     1137                    Main.parent,
    10881138                    tr("Some waypoints which were too far from the track to sensibly estimate their time were omitted."));
    10891139        }
     
    10911141
    10921142    /**
    1093      * Makes a WayPoint at the projection of point P onto the track providing P is
    1094      * less than tolerance away from the track
    1095 
     1143     * Makes a WayPoint at the projection of point P onto the track providing P is less than
     1144     * tolerance away from the track
     1145     *
    10961146     * @param P : the point to determine the projection for
    10971147     * @param tolerance : must be no further than this from the track
    1098      * @return the closest point on the track to P, which may be the
    1099      * first or last point if off the end of a segment, or may be null if
    1100      * nothing close enough
     1148     * @return the closest point on the track to P, which may be the first or last point if off the
     1149     * end of a segment, or may be null if nothing close enough
    11011150     */
    11021151    public WayPoint nearestPointOnTrack(EastNorth P, double tolerance) {
    11031152        /*
    1104          * assume the coordinates of P are xp,yp, and those of a section of track
    1105          * between two trackpoints are R=xr,yr and S=xs,ys. Let N be the projected point.
    1106          *
    1107          * The equation of RS is Ax + By + C = 0 where
    1108          * A = ys - yr
    1109          * B = xr - xs
    1110          * C = - Axr - Byr
    1111          *
     1153         * assume the coordinates of P are xp,yp, and those of a section of track between two
     1154         * trackpoints are R=xr,yr and S=xs,ys. Let N be the projected point.
     1155         *
     1156         * The equation of RS is Ax + By + C = 0 where A = ys - yr B = xr - xs C = - Axr - Byr
     1157         *
    11121158         * Also, note that the distance RS^2 is A^2 + B^2
    1113          *
     1159         * 
    11141160         * If RS^2 == 0.0 ignore the degenerate section of track
    1115          *
    1116          * PN^2 = (Axp + Byp + C)^2 / RS^2
    1117          * that is the distance from P to the line
    1118          *
    1119          * so if PN^2 is less than PNmin^2 (initialized to tolerance) we can reject
    1120          * the line; otherwise...
    1121          * determine if the projected poijnt lies within the bounds of the line:
    1122          * PR^2 - PN^2 <= RS^2 and PS^2 - PN^2 <= RS^2
    1123          *
    1124          * where PR^2 = (xp - xr)^2 + (yp-yr)^2
    1125          * and   PS^2 = (xp - xs)^2 + (yp-ys)^2
    1126          *
    1127          * If so, calculate N as
    1128          * xn = xr + (RN/RS) B
    1129          * yn = y1 + (RN/RS) A
    1130          *
     1161         *
     1162         * PN^2 = (Axp + Byp + C)^2 / RS^2 that is the distance from P to the line
     1163         *
     1164         * so if PN^2 is less than PNmin^2 (initialized to tolerance) we can reject the line;
     1165         * otherwise... determine if the projected poijnt lies within the bounds of the line: PR^2 -
     1166         * PN^2 <= RS^2 and PS^2 - PN^2 <= RS^2
     1167         *
     1168         * where PR^2 = (xp - xr)^2 + (yp-yr)^2 and PS^2 = (xp - xs)^2 + (yp-ys)^2
     1169         *
     1170         * If so, calculate N as xn = xr + (RN/RS) B yn = y1 + (RN/RS) A
     1171         *
    11311172         * where RN = sqrt(PR^2 - PN^2)
    11321173         */
     
    11381179        double py = P.north();
    11391180        double rx = 0.0, ry = 0.0, sx, sy, x, y;
    1140         if (data.tracks == null) return null;
     1181        if (data.tracks == null)
     1182            return null;
    11411183        for (GpxTrack track : data.tracks) {
    11421184            if (track.trackSegs == null) {
     
    11641206                        double A = sy - ry;
    11651207                        double B = rx - sx;
    1166                         double C = - A * rx - B * ry;
     1208                        double C = -A * rx - B * ry;
    11671209                        double RSsq = A * A + B * B;
    11681210                        if (RSsq == 0.0) {
     
    11791221                            double PSsq = x * x + y * y;
    11801222                            if (PRsq - PNsq <= RSsq && PSsq - PNsq <= RSsq) {
    1181                                 double RNoverRS = Math.sqrt((PRsq - PNsq)/RSsq);
     1223                                double RNoverRS = Math.sqrt((PRsq - PNsq) / RSsq);
    11821224                                double nx = rx - RNoverRS * B;
    11831225                                double ny = ry + RNoverRS * A;
     
    12081250            }
    12091251        }
    1210         if (bestEN == null) return null;
     1252        if (bestEN == null)
     1253            return null;
    12111254        WayPoint best = new WayPoint(Main.proj.eastNorth2latlon(bestEN));
    12121255        best.time = bestTime;
  • trunk/src/org/openstreetmap/josm/gui/layer/OsmDataLayer.java

    r1843 r1865  
    5858import org.openstreetmap.josm.data.osm.visitor.SimplePaintVisitor;
    5959import org.openstreetmap.josm.gui.MapView;
     60import org.openstreetmap.josm.gui.OptionPaneUtil;
    6061import org.openstreetmap.josm.gui.dialogs.LayerListDialog;
    6162import org.openstreetmap.josm.gui.dialogs.LayerListPopup;
     
    295296        }
    296297        if (numNewConflicts > 0) {
    297             JOptionPane.showMessageDialog(Main.parent,tr("There were {0} conflicts during import.", numNewConflicts));
     298            OptionPaneUtil.showMessageDialog(
     299                    Main.parent,
     300                    tr("There were {0} conflicts during import.", numNewConflicts),
     301                    tr("Warning"),
     302                    JOptionPane.WARNING_MESSAGE
     303            );
    298304        }
    299305    }
  • trunk/src/org/openstreetmap/josm/gui/layer/RawGpsLayer.java

    r1838 r1865  
    3434import javax.swing.JSeparator;
    3535import javax.swing.JTextField;
     36import javax.swing.text.html.Option;
    3637
    3738import org.openstreetmap.josm.Main;
     
    4748import org.openstreetmap.josm.gui.ConditionalOptionPaneUtil;
    4849import org.openstreetmap.josm.gui.MapView;
     50import org.openstreetmap.josm.gui.OptionPaneUtil;
    4951import org.openstreetmap.josm.gui.dialogs.LayerListDialog;
    5052import org.openstreetmap.josm.gui.dialogs.LayerListPopup;
     
    218220                    group.setSelected(r[0].getModel(), true);
    219221                }
    220                 int answer = JOptionPane.showConfirmDialog(Main.parent, panel, tr("Select line drawing options"), JOptionPane.OK_CANCEL_OPTION);
     222                int answer = OptionPaneUtil.showConfirmationDialog(
     223                        Main.parent,
     224                        panel,
     225                        tr("Select line drawing options"),
     226                        JOptionPane.OK_CANCEL_OPTION,
     227                        JOptionPane.PLAIN_MESSAGE
     228                );
    221229                if (answer == JOptionPane.CANCEL_OPTION)
    222230                    return;
     
    235243                JColorChooser c = new JColorChooser(Main.pref.getColor(marktr("gps point"), "layer "+name, Color.gray));
    236244                Object[] options = new Object[]{tr("OK"), tr("Cancel"), tr("Default")};
    237                 int answer = JOptionPane.showOptionDialog(Main.parent, c, tr("Choose a color"), JOptionPane.OK_CANCEL_OPTION,
    238                         JOptionPane.PLAIN_MESSAGE, null, options, options[0]);
     245                int answer = OptionPaneUtil.showOptionDialog(
     246                        Main.parent,
     247                        c,
     248                        tr("Choose a color"),
     249                        JOptionPane.OK_CANCEL_OPTION,
     250                        JOptionPane.PLAIN_MESSAGE, options, options[0]);
    239251                switch (answer) {
    240                 case 0:
    241                     Main.pref.putColor("layer "+name, c.getColor());
    242                     break;
    243                 case 1:
    244                     return;
    245                 case 2:
    246                     Main.pref.putColor("layer "+name, null);
    247                     break;
     252                    case 0:
     253                        Main.pref.putColor("layer "+name, c.getColor());
     254                        break;
     255                    case 1:
     256                        return;
     257                    case 2:
     258                        Main.pref.putColor("layer "+name, null);
     259                        break;
    248260                }
    249261                Main.map.repaint();
  • trunk/src/org/openstreetmap/josm/gui/layer/markerlayer/MarkerLayer.java

    r1724 r1865  
    3434import org.openstreetmap.josm.data.osm.visitor.BoundingXYVisitor;
    3535import org.openstreetmap.josm.gui.MapView;
     36import org.openstreetmap.josm.gui.OptionPaneUtil;
    3637import org.openstreetmap.josm.gui.dialogs.LayerListDialog;
    3738import org.openstreetmap.josm.gui.dialogs.LayerListPopup;
     
    9091            if (wpt_has_link) {
    9192                for (GpxLink oneLink : (Collection<GpxLink>) wpt.attr.get(GpxData.META_LINKS)) {
    92                     if (!oneLink.uri.equals(lastLinkedFile))firstTime = time;
     93                    if (!oneLink.uri.equals(lastLinkedFile)) {
     94                        firstTime = time;
     95                    }
    9396                    lastLinkedFile = oneLink.uri;
    9497                    break;
     
    9699            }
    97100            Marker m = Marker.createMarker(wpt, indata.storageFile, this, time, time - firstTime);
    98             if (m != null)
     101            if (m != null) {
    99102                data.add(m);
     103            }
    100104        }
    101105
     
    118122                            return;
    119123                        mousePressed  = true;
    120                         if (visible)
     124                        if (visible) {
    121125                            Main.map.mapView.repaint();
     126                        }
    122127                    }
    123128                    @Override public void mouseReleased(MouseEvent ev) {
     
    129134                        if (ev.getPoint() != null) {
    130135                            for (Marker mkr : data) {
    131                                 if (mkr.containsPoint(ev.getPoint()))
     136                                if (mkr.containsPoint(ev.getPoint())) {
    132137                                    mkr.actionPerformed(new ActionEvent(this, 0, null));
     138                                }
    133139                            }
    134140                        }
     
    183189
    184190    @Override public void visitBoundingBox(BoundingXYVisitor v) {
    185         for (Marker mkr : data)
     191        for (Marker mkr : data) {
    186192            v.visit(mkr.getEastNorth());
     193        }
    187194    }
    188195
     
    198205                JColorChooser c = new JColorChooser(getColor(name));
    199206                Object[] options = new Object[]{tr("OK"), tr("Cancel"), tr("Default")};
    200                 int answer = JOptionPane.showOptionDialog(Main.parent, c, tr("Choose a color"), JOptionPane.OK_CANCEL_OPTION,
    201                 JOptionPane.PLAIN_MESSAGE, null, options, options[0]);
     207                int answer = OptionPaneUtil.showOptionDialog(
     208                        Main.parent,
     209                        c,
     210                        tr("Choose a color"),
     211                        JOptionPane.OK_CANCEL_OPTION,
     212                        JOptionPane.PLAIN_MESSAGE,
     213                        options,
     214                        options[0]
     215                );
    202216                switch (answer) {
    203217                case 0:
     
    219233            public void actionPerformed(ActionEvent e) {
    220234                if (! AudioPlayer.paused()) {
    221                     JOptionPane.showMessageDialog(Main.parent,tr("You need to pause audio at the moment when you hear your synchronization cue."));
     235                    OptionPaneUtil.showMessageDialog(
     236                            Main.parent,
     237                            tr("You need to pause audio at the moment when you hear your synchronization cue."),
     238                            tr("Warning"),
     239                            JOptionPane.WARNING_MESSAGE
     240                    );
    222241                    return;
    223242                }
    224243                AudioMarker recent = AudioMarker.recentlyPlayedMarker();
    225244                if (synchronizeAudioMarkers(recent)) {
    226                     JOptionPane.showMessageDialog(Main.parent, tr("Audio synchronized at point {0}.", recent.text));
     245                    OptionPaneUtil.showMessageDialog(
     246                            Main.parent,
     247                            tr("Audio synchronized at point {0}.", recent.text),
     248                            tr("Information"),
     249                            JOptionPane.INFORMATION_MESSAGE
     250                    );
    227251                } else {
    228                     JOptionPane.showMessageDialog(Main.parent,tr("Unable to synchronize in layer being played."));
     252                    OptionPaneUtil.showMessageDialog(
     253                            Main.parent,
     254                            tr("Unable to synchronize in layer being played."),
     255                            tr("Error"),
     256                            JOptionPane.ERROR_MESSAGE
     257                    );
    229258                }
    230259            }
     
    236265            public void actionPerformed(ActionEvent e) {
    237266                if (! AudioPlayer.paused()) {
    238                     JOptionPane.showMessageDialog(Main.parent,tr("You need to have paused audio at the point on the track where you want the marker."));
     267                    OptionPaneUtil.showMessageDialog(
     268                            Main.parent,
     269                            tr("You need to have paused audio at the point on the track where you want the marker."),
     270                            tr("Warning"),
     271                            JOptionPane.WARNING_MESSAGE
     272                    );
    239273                    return;
    240274                }
     
    285319        URL url = startMarker.url();
    286320        for (Marker m : data) {
    287             if (m == startMarker)
     321            if (m == startMarker) {
    288322                seenStart = true;
     323            }
    289324            if (seenStart) {
    290325                AudioMarker ma = (AudioMarker) m; // it must be an AudioMarker
    291                 if (ma.url().equals(url))
     326                if (ma.url().equals(url)) {
    292327                    ma.adjustOffset(adjustment);
     328                }
    293329            }
    294330        }
     
    308344        }
    309345        if (am == null) {
    310             JOptionPane.showMessageDialog(Main.parent,tr("No existing audio markers in this layer to offset from."));
     346            OptionPaneUtil.showMessageDialog(
     347                    Main.parent,
     348                    tr("No existing audio markers in this layer to offset from."),
     349                    tr("Error"),
     350                    JOptionPane.ERROR_MESSAGE
     351            );
    311352            return null;
    312353        }
     
    314355        // make our new marker
    315356        AudioMarker newAudioMarker = AudioMarker.create(coor,
    316             AudioMarker.inventName(offset), AudioPlayer.url().toString(), this, time, offset);
     357                AudioMarker.inventName(offset), AudioPlayer.url().toString(), this, time, offset);
    317358
    318359        // insert it at the right place in a copy the collection
     
    333374
    334375        if (newAudioMarker != null) {
    335             if (am != null)
     376            if (am != null) {
    336377                newAudioMarker.adjustOffset(am.syncOffset()); // i.e. same as predecessor
     378            }
    337379            newData.add(newAudioMarker); // insert at end
    338380        }
     
    363405            for (Marker marker : markerLayer.data) {
    364406                if (marker == startMarker) {
    365                     if (next)
     407                    if (next) {
    366408                        nextTime = true;
    367                     else {
    368                         if (previousMarker == null)
     409                    } else {
     410                        if (previousMarker == null) {
    369411                            previousMarker = startMarker; // if no previous one, play the first one again
     412                        }
    370413                        return previousMarker;
    371414                    }
     
    389432            return;
    390433        Layer l = Main.map.mapView.getActiveLayer();
    391         if(l != null)
     434        if(l != null) {
    392435            m = getAdjacentMarker(startMarker, next, l);
     436        }
    393437        if(m == null)
    394438        {
     
    396440            {
    397441                m = getAdjacentMarker(startMarker, next, layer);
    398                 if(m != null)
    399                     break;
    400             }
    401         }
    402         if(m != null)
     442                if(m != null) {
     443                    break;
     444                }
     445            }
     446        }
     447        if(m != null) {
    403448            ((AudioMarker)m).play();
     449        }
    404450    }
    405451
  • trunk/src/org/openstreetmap/josm/gui/layer/markerlayer/PlayHeadMarker.java

    r1724 r1865  
    2626import org.openstreetmap.josm.data.gpx.WayPoint;
    2727import org.openstreetmap.josm.gui.MapView;
     28import org.openstreetmap.josm.gui.OptionPaneUtil;
    2829import org.openstreetmap.josm.gui.layer.GpxLayer;
    2930import org.openstreetmap.josm.tools.AudioPlayer;
     
    6162    private PlayHeadMarker() {
    6263        super(new LatLon(0.0,0.0), "",
    63               Main.pref.get("marker.audiotracericon", "audio-tracer"),
    64               null, -1.0, 0.0);
     64                Main.pref.get("marker.audiotracericon", "audio-tracer"),
     65                null, -1.0, 0.0);
    6566        enabled = Main.pref.getBoolean("marker.traceaudio", true);
    6667        if (! enabled) return;
     
    8788        Point screen = Main.map.mapView.getPoint(getEastNorth());
    8889        Rectangle r = new Rectangle(screen.x, screen.y, symbol.getIconWidth(),
    89         symbol.getIconHeight());
     90                symbol.getIconHeight());
    9091        return r.contains(p);
    9192    }
     
    9697     */
    9798    public void startDrag() {
    98         if (timer != null)
     99        if (timer != null) {
    99100            timer.stop();
     101        }
    100102        wasPlaying = AudioPlayer.playing();
    101103        if (wasPlaying) {
     
    109111     */
    110112    private void endDrag(boolean reset) {
    111         if (! wasPlaying || reset)
     113        if (! wasPlaying || reset) {
    112114            try { AudioPlayer.pause(); }
    113115            catch (Exception ex) { AudioPlayer.audioMalfunction(ex);}
    114         if (reset)
     116        }
     117        if (reset) {
    115118            setCoor(oldCoor);
     119        }
    116120        Main.map.selectMapMode(oldMode);
    117121        Main.map.mapView.repaint();
     
    153157                    if (m instanceof AudioMarker) {
    154158                        AudioMarker a = (AudioMarker) m;
    155                         if (a.time > cw.time)
     159                        if (a.time > cw.time) {
    156160                            break;
     161                        }
    157162                        ca = a;
    158163                    }
     
    163168        if (ca == null) {
    164169            /* Not close enough to track, or no audio marker found for some other reason */
    165             JOptionPane.showMessageDialog(Main.parent, tr("You need to drag the play head near to the GPX track whose associated sound track you were playing (after the first marker)."));
     170            OptionPaneUtil.showMessageDialog(
     171                    Main.parent,
     172                    tr("You need to drag the play head near to the GPX track whose associated sound track you were playing (after the first marker)."),
     173                    tr("Warning"),
     174                    JOptionPane.WARNING_MESSAGE
     175            );
    166176            endDrag(true);
    167177        } else {
     
    202212
    203213        /* We found the closest marker: did we actually hit it? */
    204         if (ca != null && ! ca.containsPoint(startPoint)) ca = null;
     214        if (ca != null && ! ca.containsPoint(startPoint)) {
     215            ca = null;
     216        }
    205217
    206218        /* If we didn't hit an audio marker, we need to create one at the nearest point on the track */
     
    211223            WayPoint cw = recent.parentLayer.fromLayer.nearestPointOnTrack(en, enPlus25px.east() - en.east());
    212224            if (cw == null) {
    213                 JOptionPane.showMessageDialog(Main.parent, tr("You need to SHIFT-drag the play head onto an audio marker or onto the track point where you want to synchronize."));
     225                OptionPaneUtil.showMessageDialog(
     226                        Main.parent,
     227                        tr("You need to SHIFT-drag the play head onto an audio marker or onto the track point where you want to synchronize."),
     228                        tr("Warning"),
     229                        JOptionPane.WARNING_MESSAGE
     230                );
    214231                endDrag(true);
    215232                return;
     
    221238        if(ca == null)
    222239        {
    223             JOptionPane.showMessageDialog(Main.parent,tr("Unable to create new audio marker."));
     240            OptionPaneUtil.showMessageDialog(
     241                    Main.parent,
     242                    tr("Unable to create new audio marker."),
     243                    tr("Error"),
     244                    JOptionPane.ERROR_MESSAGE
     245            );
    224246            endDrag(true);
    225247        }
    226248        else if (recent.parentLayer.synchronizeAudioMarkers(ca)) {
    227             JOptionPane.showMessageDialog(Main.parent, tr("Audio synchronized at point {0}.", ca.text));
     249            OptionPaneUtil.showMessageDialog(
     250                    Main.parent,
     251                    tr("Audio synchronized at point {0}.", ca.text),
     252                    tr("Information"),
     253                    JOptionPane.INFORMATION_MESSAGE
     254            );
    228255            setCoor(ca.getCoor());
    229256            endDrag(false);
    230257        } else {
    231             JOptionPane.showMessageDialog(Main.parent,tr("Unable to synchronize in layer being played."));
     258            OptionPaneUtil.showMessageDialog(
     259                    Main.parent,
     260                    tr("Unable to synchronize in layer being played."),
     261                    tr("Error"),
     262                    JOptionPane.ERROR_MESSAGE
     263            );
    232264            endDrag(true);
    233265        }
     
    264296            return;
    265297        double audioTime = recentlyPlayedMarker.time +
    266             AudioPlayer.position() -
    267             recentlyPlayedMarker.offset -
    268             recentlyPlayedMarker.syncOffset;
     298        AudioPlayer.position() -
     299        recentlyPlayedMarker.offset -
     300        recentlyPlayedMarker.syncOffset;
    269301        if (Math.abs(audioTime - time) < animationInterval)
    270302            return;
     
    289321                    w1 = w;
    290322                }
    291                 if (w2 != null) break;
    292             }
    293             if (w2 != null) break;
     323                if (w2 != null) {
     324                    break;
     325                }
     326            }
     327            if (w2 != null) {
     328                break;
     329            }
    294330        }
    295331
     
    297333            return;
    298334        setEastNorth(w2 == null ?
    299             w1.getEastNorth() :
    300             w1.getEastNorth().interpolate(w2.getEastNorth(),
    301                     (audioTime - w1.time)/(w2.time - w1.time)));
     335                w1.getEastNorth() :
     336                    w1.getEastNorth().interpolate(w2.getEastNorth(),
     337                            (audioTime - w1.time)/(w2.time - w1.time)));
    302338        time = audioTime;
    303339        Main.map.mapView.repaint();
  • trunk/src/org/openstreetmap/josm/gui/layer/markerlayer/WebMarker.java

    r1169 r1865  
    1111import org.openstreetmap.josm.Main;
    1212import org.openstreetmap.josm.data.coor.LatLon;
     13import org.openstreetmap.josm.gui.OptionPaneUtil;
    1314import org.openstreetmap.josm.tools.OpenBrowser;
    1415
     
    3940        String error = OpenBrowser.displayUrl(webUrl.toString());
    4041        if (error != null) {
    41             JOptionPane.showMessageDialog(Main.parent,
     42            OptionPaneUtil.showMessageDialog(Main.parent,
    4243                    "<html><b>" +
    4344                    tr("There was an error while trying to display the URL for this marker") +
  • trunk/src/org/openstreetmap/josm/gui/preferences/AdvancedPreference.java

    r1742 r1865  
    3030
    3131import org.openstreetmap.josm.Main;
     32import org.openstreetmap.josm.gui.OptionPaneUtil;
    3233import org.openstreetmap.josm.tools.GBC;
    3334
     
    8384                {
    8485                    data.put((String) model.getValueAt(row, 0),
    85                     (String) model.getValueAt(row, 1));
     86                            (String) model.getValueAt(row, 1));
    8687                }
    8788            }
     
    8990        };
    9091        DefaultTableCellRenderer renderer = new DefaultTableCellRenderer(){
     92            @Override
    9193            public Component getTableCellRendererComponent(JTable table, Object value,
    92                 boolean isSelected, boolean hasFocus, int row, int column)
     94                    boolean isSelected, boolean hasFocus, int row, int column)
    9395            {
    9496                JLabel label=new JLabel();
     
    9698                if(s != null)
    9799                {
    98                     if(s.equals(model.getValueAt(row, 1)))
     100                    if(s.equals(model.getValueAt(row, 1))) {
    99101                        label.setToolTipText(tr("Current value is default."));
    100                     else
     102                    } else {
    101103                        label.setToolTipText(tr("Default value is ''{0}''.", s));
    102                 }
    103                 else
     104                    }
     105                } else {
    104106                    label.setToolTipText(tr("Default value currently unknown (setting has not been used yet)."));
     107                }
    105108                label.setText((String)value);
    106109                return label;
     
    147150        list.addMouseListener(new MouseAdapter(){
    148151            @Override public void mouseClicked(MouseEvent e) {
    149                 if (e.getClickCount() == 2)
     152                if (e.getClickCount() == 2) {
    150153                    editPreference(gui, list);
     154                }
    151155            }
    152156        });
     
    157161        for (String s : defaults.keySet())
    158162        {
    159             if(!ts.contains(s))
     163            if(!ts.contains(s)) {
    160164                ts.add(s);
     165            }
    161166        }
    162167        data = new TreeMap<String, String>();
     
    164169        {
    165170            String val = Main.pref.get(s);
    166             if(val == null) val = "";
     171            if(val == null) {
     172                val = "";
     173            }
    167174            data.put(s, val);
    168175        }
     
    180187            // Make 'wmsplugin cache' search for e.g. 'cache.wmsplugin'
    181188            for (String bit : input) {
    182                 if (!prefKey.contains(bit) && !prefValue.contains(bit))
     189                if (!prefKey.contains(bit) && !prefValue.contains(bit)) {
    183190                    canHas = false;
     191                }
    184192            }
    185193
     
    196204            {
    197205                String origValue = orig.get(key);
    198                 if (origValue == null || !origValue.equals(value))
     206                if (origValue == null || !origValue.equals(value)) {
    199207                    Main.pref.put(key, value);
     208                }
    200209                orig.remove(key); // processed.
    201210            }
    202211        }
    203         for (Entry<String, String> e : orig.entrySet())
     212        for (Entry<String, String> e : orig.entrySet()) {
    204213            Main.pref.put(e.getKey(), null);
     214        }
    205215        return false;
    206216    }
     
    209219    private void editPreference(final PreferenceDialog gui, final JTable list) {
    210220        if (list.getSelectedRowCount() != 1) {
    211             JOptionPane.showMessageDialog(gui, tr("Please select the row to edit."));
     221            OptionPaneUtil.showMessageDialog(
     222                    gui,
     223                    tr("Please select the row to edit."),
     224                    tr("Warning"),
     225                    JOptionPane.WARNING_MESSAGE
     226            );
    212227            return;
    213228        }
    214         String v = JOptionPane.showInputDialog(tr("New value for {0}", model.getValueAt(list.getSelectedRow(), 0)), model.getValueAt(list.getSelectedRow(), 1));
     229        String v = (String) OptionPaneUtil.showInputDialog(
     230                Main.parent,
     231                tr("New value for {0}", model.getValueAt(list.getSelectedRow(), 0)),
     232                tr("New value"),
     233                JOptionPane.QUESTION_MESSAGE,
     234                null,
     235                null,
     236                model.getValueAt(list.getSelectedRow(), 1)
     237        );
    215238        if (v != null) {
    216239            data.put((String) model.getValueAt(list.getSelectedRow(), 0), v);
     
    221244    private void removePreference(final PreferenceDialog gui, final JTable list) {
    222245        if (list.getSelectedRowCount() == 0) {
    223             JOptionPane.showMessageDialog(gui, tr("Please select the row to delete."));
     246            OptionPaneUtil.showMessageDialog(
     247                    gui,
     248                    tr("Please select the row to delete."),
     249                    tr("Warning"),
     250                    JOptionPane.WARNING_MESSAGE
     251            );
    224252            return;
    225253        }
     
    238266        p.add(new JLabel(tr("Value")), GBC.std().insets(0,0,5,0));
    239267        p.add(value, GBC.eol().insets(5,0,0,0).fill(GBC.HORIZONTAL));
    240         int answer = JOptionPane.showConfirmDialog(gui, p, tr("Enter a new key/value pair"), JOptionPane.OK_CANCEL_OPTION);
     268        int answer = OptionPaneUtil.showConfirmationDialog(
     269                gui, p,
     270                tr("Enter a new key/value pair"),
     271                JOptionPane.OK_CANCEL_OPTION,
     272                JOptionPane.PLAIN_MESSAGE
     273        );
    241274        if (answer == JOptionPane.OK_OPTION) {
    242275            data.put(key.getText(), value.getText());
  • trunk/src/org/openstreetmap/josm/gui/preferences/ColorPreference.java

    r1742 r1865  
    3636import org.openstreetmap.josm.data.osm.visitor.MapPaintVisitor;
    3737import org.openstreetmap.josm.gui.MapScaler;
     38import org.openstreetmap.josm.gui.OptionPaneUtil;
    3839import org.openstreetmap.josm.gui.dialogs.ConflictDialog;
    3940import org.openstreetmap.josm.gui.layer.markerlayer.MarkerLayer;
     
    8182        Map<String, String> colorKeyList_layer = new TreeMap<String, String>();
    8283        for(String key : colorMap.keySet()) {
    83             if(key.startsWith("layer "))
     84            if(key.startsWith("layer ")) {
    8485                colorKeyList_layer.put(getName(key), key);
    85             else if(key.startsWith("mappaint."))
     86            } else if(key.startsWith("mappaint.")) {
    8687                colorKeyList_mappaint.put(getName(key), key);
    87             else
     88            } else {
    8889                colorKeyList.put(getName(key), key);
     90            }
    8991        }
    9092        for (Entry<String, String> k : colorKeyList.entrySet()) {
     
    155157                int sel = colors.getSelectedRow();
    156158                JColorChooser chooser = new JColorChooser((Color)colors.getValueAt(sel, 1));
    157                 int answer = JOptionPane.showConfirmDialog(gui, chooser,
    158                 tr("Choose a color for {0}", getName((String)colors.getValueAt(sel, 0))),
    159                 JOptionPane.OK_CANCEL_OPTION);
    160                 if (answer == JOptionPane.OK_OPTION)
     159                int answer = OptionPaneUtil.showConfirmationDialog(
     160                        gui, chooser,
     161                        tr("Choose a color for {0}", getName((String)colors.getValueAt(sel, 0))),
     162                        JOptionPane.OK_CANCEL_OPTION,
     163                        JOptionPane.PLAIN_MESSAGE);
     164                if (answer == JOptionPane.OK_OPTION) {
    161165                    colors.setValueAt(chooser.getColor(), sel, 1);
     166                }
    162167            }
    163168        });
     
    168173                String name = (String)colors.getValueAt(sel, 0);
    169174                Color c = Main.pref.getDefaultColor(name);
    170                 if (c != null)
     175                if (c != null) {
    171176                    colors.setValueAt(c, sel, 1);
     177                }
    172178            }
    173179        });
     
    177183                for(int i = 0; i < colors.getRowCount(); ++i)
    178184                {
    179                   String name = (String)colors.getValueAt(i, 0);
    180                   Color c = Main.pref.getDefaultColor(name);
    181                   if (c != null)
    182                       colors.setValueAt(c, i, 1);
     185                    String name = (String)colors.getValueAt(i, 0);
     186                    Color c = Main.pref.getDefaultColor(name);
     187                    if (c != null) {
     188                        colors.setValueAt(c, i, 1);
     189                    }
    183190                }
    184191            }
     
    257264    public boolean ok() {
    258265        Boolean ret = false;
    259         for(String d : del)
     266        for(String d : del) {
    260267            Main.pref.put("color."+d, null);
     268        }
    261269        for (int i = 0; i < colors.getRowCount(); ++i) {
    262270            String key = (String)colors.getValueAt(i, 0);
    263271            if(Main.pref.putColor(key, (Color)colors.getValueAt(i, 1)))
    264272            {
    265                 if(key.startsWith("mappaint."))
     273                if(key.startsWith("mappaint.")) {
    266274                    ret = true;
     275                }
    267276            }
    268277        }
  • trunk/src/org/openstreetmap/josm/gui/preferences/PluginPreference.java

    r1742 r1865  
    2222import javax.swing.Scrollable;
    2323
     24import org.openstreetmap.josm.Main;
     25import org.openstreetmap.josm.gui.OptionPaneUtil;
    2426import org.openstreetmap.josm.plugins.PluginDownloader;
    2527import org.openstreetmap.josm.plugins.PluginSelection;
     
    7880        p.add(new JLabel(tr("Add JOSM Plugin description URL.")), GBC.eol());
    7981        final DefaultListModel model = new DefaultListModel();
    80         for (String s : PluginDownloader.getSites())
     82        for (String s : PluginDownloader.getSites()) {
    8183            model.addElement(s);
     84        }
    8285        final JList list = new JList(model);
    8386        p.add(new JScrollPane(list), GBC.std().fill());
     
    8588        buttons.add(new JButton(new AbstractAction(tr("Add")){
    8689            public void actionPerformed(ActionEvent e) {
    87                 String s = JOptionPane.showInputDialog(gui, tr("Add JOSM Plugin description URL."));
    88                 if (s != null)
     90                String s = OptionPaneUtil.showInputDialog(
     91                        gui,
     92                        tr("Add JOSM Plugin description URL."),
     93                        tr("Enter URL"),
     94                        JOptionPane.QUESTION_MESSAGE
     95                );
     96                if (s != null) {
    8997                    model.addElement(s);
     98                }
    9099            }
    91100        }), GBC.eol().fill(GBC.HORIZONTAL));
     
    93102            public void actionPerformed(ActionEvent e) {
    94103                if (list.getSelectedValue() == null) {
    95                     JOptionPane.showMessageDialog(gui, tr("Please select an entry."));
     104                    OptionPaneUtil.showMessageDialog(
     105                            gui,
     106                            tr("Please select an entry."),
     107                            tr("Warning"),
     108                            JOptionPane.WARNING_MESSAGE
     109                    );
    96110                    return;
    97111                }
    98                 String s = JOptionPane.showInputDialog(gui, tr("Edit JOSM Plugin description URL."), list.getSelectedValue());
     112                String s = (String)OptionPaneUtil.showInputDialog(
     113                        Main.parent,
     114                        tr("Edit JOSM Plugin description URL."),
     115                        tr("JOSM Plugin description URL"),
     116                        JOptionPane.QUESTION_MESSAGE,
     117                        null,
     118                        null,
     119                        list.getSelectedValue()
     120                );
    99121                model.setElementAt(s, list.getSelectedIndex());
    100122            }
     
    103125            public void actionPerformed(ActionEvent event) {
    104126                if (list.getSelectedValue() == null) {
    105                     JOptionPane.showMessageDialog(gui, tr("Please select an entry."));
     127                    OptionPaneUtil.showMessageDialog(
     128                            gui,
     129                            tr("Please select an entry."),
     130                            tr("Warning"),
     131                            JOptionPane.WARNING_MESSAGE
     132                    );
    106133                    return;
    107134                }
     
    110137        }), GBC.eol().fill(GBC.HORIZONTAL));
    111138        p.add(buttons, GBC.eol());
    112         int answer = JOptionPane.showConfirmDialog(gui, p, tr("Configure Plugin Sites"), JOptionPane.OK_CANCEL_OPTION);
     139        int answer = OptionPaneUtil.showConfirmationDialog(
     140                gui,
     141                p,
     142                tr("Configure Plugin Sites"), JOptionPane.OK_CANCEL_OPTION,
     143                JOptionPane.PLAIN_MESSAGE);
    113144        if (answer != JOptionPane.OK_OPTION)
    114145            return;
    115146        Collection<String> sites = new LinkedList<String>();
    116         for (int i = 0; i < model.getSize(); ++i)
     147        for (int i = 0; i < model.getSize(); ++i) {
    117148            sites.add((String)model.getElementAt(i));
     149        }
    118150        PluginDownloader.setSites(sites);
    119151    }
  • trunk/src/org/openstreetmap/josm/gui/preferences/PreferenceDialog.java

    r1743 r1865  
    2222
    2323import org.openstreetmap.josm.Main;
     24import org.openstreetmap.josm.gui.OptionPaneUtil;
    2425import org.openstreetmap.josm.plugins.PluginHandler;
    2526import org.openstreetmap.josm.tools.BugReportExceptionHandler;
     
    9596        for (PreferenceSetting setting : settings)
    9697        {
    97             if(setting.ok())
     98            if(setting.ok()) {
    9899                requiresRestart = true;
     100            }
    99101        }
    100         if (requiresRestart)
    101             JOptionPane.showMessageDialog(Main.parent,tr("You have to restart JOSM for some settings to take effect."));
     102        if (requiresRestart) {
     103            OptionPaneUtil.showMessageDialog(
     104                    Main.parent,
     105                    tr("You have to restart JOSM for some settings to take effect."),
     106                    tr("Warning"),
     107                    JOptionPane.WARNING_MESSAGE
     108            );
     109        }
    102110        Main.parent.repaint();
    103111    }
     
    139147    public <T>  T getSetting(Class<? extends T> clazz) {
    140148        for (PreferenceSetting setting:settings) {
    141             if (clazz.isAssignableFrom(setting.getClass())) {
     149            if (clazz.isAssignableFrom(setting.getClass()))
    142150                return (T)setting;
    143             }
    144151        }
    145152        return null;
  • trunk/src/org/openstreetmap/josm/gui/preferences/StyleSources.java

    r1757 r1865  
    3030
    3131import org.openstreetmap.josm.Main;
     32import org.openstreetmap.josm.gui.OptionPaneUtil;
    3233import org.openstreetmap.josm.io.MirroredInputStream;
    3334import org.openstreetmap.josm.tools.GBC;
     
    6263        {
    6364            String s = tr("Short Description: {0}", getName()) + "<br>" + tr("URL: {0}", url);
    64             if(author != null) s += "<br>" + tr("Author: {0}", author);
    65             if(link != null) s += "<br>" + tr("Webpage: {0}", link);
    66             if(description != null) s += "<br>" + tr("Description: {0}", description);
    67             if(version != null) s += "<br>" + tr("Version: {0}", version);
     65            if(author != null) {
     66                s += "<br>" + tr("Author: {0}", author);
     67            }
     68            if(link != null) {
     69                s += "<br>" + tr("Webpage: {0}", link);
     70            }
     71            if(description != null) {
     72                s += "<br>" + tr("Description: {0}", description);
     73            }
     74            if(version != null) {
     75                s += "<br>" + tr("Version: {0}", version);
     76            }
    6877            return "<html>" + s + "</html>";
    6978        }
     79        @Override
    7080        public String toString()
    7181        {
     
    7686    class MyCellRenderer extends JLabel implements ListCellRenderer {
    7787        public Component getListCellRendererComponent(JList list, Object value,
    78         int index, boolean isSelected, boolean cellHasFocus)
     88                int index, boolean isSelected, boolean cellHasFocus)
    7989        {
    8090            String s = value.toString();
     
    107117
    108118        Collection<String> sources = Main.pref.getCollection(pref, null);
    109         if(sources != null)
    110             for(String s : sources)
     119        if(sources != null) {
     120            for(String s : sources) {
    111121                ((DefaultListModel)sourcesList.getModel()).addElement(s);
     122            }
     123        }
    112124
    113125        JButton iconadd = null;
     
    119131            iconsList = new JList(new DefaultListModel());
    120132            sources = Main.pref.getCollection(iconpref, null);
    121             if(sources != null)
    122                 for(String s : sources)
     133            if(sources != null) {
     134                for(String s : sources) {
    123135                    ((DefaultListModel)iconsList.getModel()).addElement(s);
     136                }
     137            }
    124138
    125139            iconadd = new JButton(tr("Add"));
    126140            iconadd.addActionListener(new ActionListener(){
    127141                public void actionPerformed(ActionEvent e) {
    128                     String source = JOptionPane.showInputDialog(Main.parent, tr("Icon paths"));
    129                     if (source != null)
     142                    String source = OptionPaneUtil.showInputDialog(
     143                            Main.parent,
     144                            tr("Icon paths"),
     145                            tr("Icon paths"),
     146                            JOptionPane.QUESTION_MESSAGE
     147                    );
     148                    if (source != null) {
    130149                        ((DefaultListModel)iconsList.getModel()).addElement(source);
     150                    }
    131151                }
    132152            });
     
    135155            iconedit.addActionListener(new ActionListener(){
    136156                public void actionPerformed(ActionEvent e) {
    137                     if (sourcesList.getSelectedIndex() == -1)
    138                         JOptionPane.showMessageDialog(Main.parent, tr("Please select the row to edit."));
    139                     else {
    140                         String source = JOptionPane.showInputDialog(Main.parent,
    141                         tr("Icon paths"), iconsList.getSelectedValue());
    142                         if (source != null)
     157                    if (sourcesList.getSelectedIndex() == -1) {
     158                        OptionPaneUtil.showMessageDialog(
     159                                Main.parent,
     160                                tr("Please select the row to edit."),
     161                                tr("Warning"),
     162                                JOptionPane.WARNING_MESSAGE
     163                        );
     164                    } else {
     165                        String source = (String)OptionPaneUtil.showInputDialog(
     166                                Main.parent,
     167                                tr("Icon paths"),
     168                                tr("Icon paths"),
     169                                JOptionPane.QUESTION_MESSAGE,
     170                                null,
     171                                null,
     172                                iconsList.getSelectedValue()
     173                        );
     174                        if (source != null) {
    143175                            ((DefaultListModel)iconsList.getModel()).setElementAt(source, iconsList.getSelectedIndex());
     176                        }
    144177                    }
    145178                }
     
    149182            icondelete.addActionListener(new ActionListener(){
    150183                public void actionPerformed(ActionEvent e) {
    151                     if (iconsList.getSelectedIndex() == -1)
    152                         JOptionPane.showMessageDialog(Main.parent, tr("Please select the row to delete."));
    153                     else {
     184                    if (iconsList.getSelectedIndex() == -1) {
     185                        OptionPaneUtil.showMessageDialog(
     186                                Main.parent, tr("Please select the row to delete."),
     187                                tr("Warning"),
     188                                JOptionPane.WARNING_MESSAGE);
     189                    } else {
    154190                        ((DefaultListModel)iconsList.getModel()).remove(iconsList.getSelectedIndex());
    155191                    }
     
    161197        add.addActionListener(new ActionListener(){
    162198            public void actionPerformed(ActionEvent e) {
    163                 String source = JOptionPane.showInputDialog(Main.parent, name);
    164                 if (source != null)
     199                String source = OptionPaneUtil.showInputDialog(
     200                        Main.parent,
     201                        name,
     202                        name,
     203                        JOptionPane.QUESTION_MESSAGE);
     204                if (source != null) {
    165205                    ((DefaultListModel)sourcesList.getModel()).addElement(source);
     206                }
    166207            }
    167208        });
     
    170211        edit.addActionListener(new ActionListener(){
    171212            public void actionPerformed(ActionEvent e) {
    172                 if (sourcesList.getSelectedIndex() == -1)
    173                     JOptionPane.showMessageDialog(Main.parent, tr("Please select the row to edit."));
    174                 else {
    175                     String source = JOptionPane.showInputDialog(Main.parent,
    176                     name, sourcesList.getSelectedValue());
    177                     if (source != null)
     213                if (sourcesList.getSelectedIndex() == -1) {
     214                    OptionPaneUtil.showMessageDialog(
     215                            Main.parent, tr("Please select the row to edit."),
     216                            tr("Warning"), JOptionPane.WARNING_MESSAGE);
     217                } else {
     218                    String source = (String)OptionPaneUtil.showInputDialog(
     219                            Main.parent,
     220                            name,
     221                            name,
     222                            JOptionPane.QUESTION_MESSAGE,
     223                            null,
     224                            null,
     225                            sourcesList.getSelectedValue()
     226                    );
     227                    if (source != null) {
    178228                        ((DefaultListModel)sourcesList.getModel()).setElementAt(source, sourcesList.getSelectedIndex());
     229                    }
    179230                }
    180231            }
     
    184235        delete.addActionListener(new ActionListener(){
    185236            public void actionPerformed(ActionEvent e) {
    186                 if (sourcesList.getSelectedIndex() == -1)
    187                     JOptionPane.showMessageDialog(Main.parent, tr("Please select the row to delete."));
    188                 else {
     237                if (sourcesList.getSelectedIndex() == -1) {
     238                    OptionPaneUtil.showMessageDialog(Main.parent, tr("Please select the row to delete."),
     239                            tr("Warning"), JOptionPane.WARNING_MESSAGE);
     240                } else {
    189241                    ((DefaultListModel)sourcesList.getModel()).remove(sourcesList.getSelectedIndex());
    190242                }
     
    195247        copy.addActionListener(new ActionListener(){
    196248            public void actionPerformed(ActionEvent e) {
    197                 if (sourcesDefaults.getSelectedIndex() == -1)
    198                     JOptionPane.showMessageDialog(Main.parent, tr("Please select the row to copy."));
    199                 else {
     249                if (sourcesDefaults.getSelectedIndex() == -1) {
     250                    OptionPaneUtil.showMessageDialog(
     251                            Main.parent, tr("Please select the row to copy."),
     252                            tr("Warning"), JOptionPane.WARNING_MESSAGE);
     253                } else {
    200254                    ((DefaultListModel)sourcesList.getModel()).addElement(
    201                     ((SourceInfo)sourcesDefaults.getSelectedValue()).url);
     255                            ((SourceInfo)sourcesDefaults.getSelectedValue()).url);
    202256                }
    203257            }
     
    213267                {
    214268                    ArrayList<String> l = new ArrayList<String>();
    215                     for (int i = 0; i < num; ++i)
     269                    for (int i = 0; i < num; ++i) {
    216270                        MirroredInputStream.cleanup((String)sourcesList.getModel().getElementAt(i));
     271                    }
    217272                }
    218273            }
     
    256311        {
    257312            ArrayList<String> l = new ArrayList<String>();
    258             for (int i = 0; i < num; ++i)
     313            for (int i = 0; i < num; ++i) {
    259314                l.add((String)sourcesList.getModel().getElementAt(i));
    260             if(Main.pref.putCollection(pref, l))
     315            }
     316            if(Main.pref.putCollection(pref, l)) {
    261317                changed = true;
    262         }
    263         else if(Main.pref.putCollection(pref, null))
     318            }
     319        }
     320        else if(Main.pref.putCollection(pref, null)) {
    264321            changed = true;
     322        }
    265323        if(iconsList != null)
    266324        {
     
    269327            {
    270328                ArrayList<String> l = new ArrayList<String>();
    271                 for (int i = 0; i < num; ++i)
     329                for (int i = 0; i < num; ++i) {
    272330                    l.add((String)iconsList.getModel().getElementAt(i));
    273                 if(Main.pref.putCollection(iconpref, l))
     331                }
     332                if(Main.pref.putCollection(iconpref, l)) {
    274333                    changed = true;
    275             }
    276             else if(Main.pref.putCollection(iconpref, null))
     334                }
     335            }
     336            else if(Main.pref.putCollection(iconpref, null)) {
    277337                changed = true;
     338            }
    278339        }
    279340        return changed;
     
    313374                            String key = m.group(1);
    314375                            String value = m.group(2);
    315                             if("author".equals(key) && last.author == null)
     376                            if("author".equals(key) && last.author == null) {
    316377                                last.author = value;
    317                             else if("version".equals(key))
     378                            } else if("version".equals(key)) {
    318379                                last.version = value;
    319                             else if("link".equals(key) && last.link == null)
     380                            } else if("link".equals(key) && last.link == null) {
    320381                                last.link = value;
    321                             else if("description".equals(key) && last.description == null)
     382                            } else if("description".equals(key) && last.description == null) {
    322383                                last.description = value;
    323                             else if("shortdescription".equals(key) && last.shortdescription == null)
     384                            } else if("shortdescription".equals(key) && last.shortdescription == null) {
    324385                                last.shortdescription = value;
    325                             else if((lang+"author").equals(key))
     386                            } else if((lang+"author").equals(key)) {
    326387                                last.author = value;
    327                             else if((lang+"link").equals(key))
     388                            } else if((lang+"link").equals(key)) {
    328389                                last.link = value;
    329                             else if((lang+"description").equals(key))
     390                            } else if((lang+"description").equals(key)) {
    330391                                last.description = value;
    331                             else if((lang+"shortdescription").equals(key))
     392                            } else if((lang+"shortdescription").equals(key)) {
    332393                                last.shortdescription = value;
     394                            }
    333395                        }
    334396                    }
  • trunk/src/org/openstreetmap/josm/gui/progress/PleaseWaitProgressMonitor.java

    r1863 r1865  
    1616
    1717import org.openstreetmap.josm.Main;
     18import org.openstreetmap.josm.gui.OptionPaneUtil;
    1819import org.openstreetmap.josm.gui.PleaseWaitDialog;
     20import static org.openstreetmap.josm.tools.I18n.tr;
    1921
    2022
     
    7375    }
    7476
     77    @Override
    7578    public void doBeginTask() {
    7679        doInEDT(new Runnable() {
     
    8083                } else if (dialogParent instanceof Dialog) {
    8184                    dialog = new PleaseWaitDialog((Dialog)dialogParent);
    82                 } else {
     85                } else
    8386                    throw new ProgressException("PleaseWaitDialog parent must be either Frame or Dialog");
    84                 }
    8587
    8688                dialog.cancel.setEnabled(true);
     
    9496    }
    9597
     98    @Override
    9699    public void doFinishTask() {
    97100        doInEDT(new Runnable() {
     
    103106                    dialog.cancel.removeActionListener(cancelListener);
    104107                    if (getErrorMessage() != null) {
    105                         JOptionPane.showMessageDialog(Main.parent, getErrorMessage());
     108                        OptionPaneUtil.showMessageDialog(
     109                                Main.parent, getErrorMessage(),
     110                                tr("Error"),
     111                                JOptionPane.ERROR_MESSAGE);
    106112                    }
    107113                    dialog = null;
     
    111117    }
    112118
     119    @Override
    113120    protected void updateProgress(double progressValue) {
    114121        final int newValue = (int)(progressValue * PROGRESS_BAR_MAX);
  • trunk/src/org/openstreetmap/josm/gui/tagging/TaggingPreset.java

    r1843 r1865  
    4444import org.openstreetmap.josm.data.osm.Way;
    4545import org.openstreetmap.josm.gui.ExtendedDialog;
     46import org.openstreetmap.josm.gui.OptionPaneUtil;
    4647import org.openstreetmap.josm.gui.QuadStateCheckBox;
    4748import org.openstreetmap.josm.io.MirroredInputStream;
     
    598599            } catch (IOException e) {
    599600                e.printStackTrace();
    600                 JOptionPane.showMessageDialog(Main.parent, tr("Could not read tagging preset source: {0}",source));
     601                OptionPaneUtil.showMessageDialog(
     602                        Main.parent,
     603                        tr("Could not read tagging preset source: {0}",source),
     604                        tr("Error"),
     605                        JOptionPane.ERROR_MESSAGE
     606                );
    601607            } catch (SAXException e) {
    602608                e.printStackTrace();
    603                 JOptionPane.showMessageDialog(Main.parent, tr("Error parsing {0}: ", source)+e.getMessage());
     609                OptionPaneUtil.showMessageDialog(
     610                        Main.parent,
     611                        tr("Error parsing {0}: ", source)+e.getMessage(),
     612                        tr("Error"),
     613                        JOptionPane.ERROR_MESSAGE
     614                );
    604615            }
    605616        }
  • trunk/src/org/openstreetmap/josm/tools/AudioPlayer.java

    r1685 r1865  
    1515
    1616import org.openstreetmap.josm.Main;
     17import org.openstreetmap.josm.gui.OptionPaneUtil;
    1718
    1819/**
     
    6869            interrupt();
    6970            while (result == Result.WAITING) { sleep(10); /* yield(); */ }
    70             if (result == Result.FAILED) { throw exception; }
     71            if (result == Result.FAILED)
     72                throw exception;
    7173        }
    7274        private void possiblyInterrupt() throws InterruptedException {
     
    229231            try {
    230232                switch (state) {
    231                 case INITIALIZING:
    232                     // we're ready to take interrupts
    233                     state = State.NOTPLAYING;
    234                     break;
    235                 case NOTPLAYING:
    236                 case PAUSED:
    237                     sleep(200);
    238                     break;
    239                 case PLAYING:
    240                     command.possiblyInterrupt();
    241                     for(;;) {
    242                         int nBytesRead = 0;
    243                         nBytesRead = audioInputStream.read(abData, 0, abData.length);
    244                         position += nBytesRead / bytesPerSecond;
     233                    case INITIALIZING:
     234                        // we're ready to take interrupts
     235                        state = State.NOTPLAYING;
     236                        break;
     237                    case NOTPLAYING:
     238                    case PAUSED:
     239                        sleep(200);
     240                        break;
     241                    case PLAYING:
    245242                        command.possiblyInterrupt();
    246                         if (nBytesRead < 0) { break; }
    247                         audioOutputLine.write(abData, 0, nBytesRead); // => int nBytesWritten
     243                        for(;;) {
     244                            int nBytesRead = 0;
     245                            nBytesRead = audioInputStream.read(abData, 0, abData.length);
     246                            position += nBytesRead / bytesPerSecond;
     247                            command.possiblyInterrupt();
     248                            if (nBytesRead < 0) { break; }
     249                            audioOutputLine.write(abData, 0, nBytesRead); // => int nBytesWritten
     250                            command.possiblyInterrupt();
     251                        }
     252                        // end of audio, clean up
     253                        audioOutputLine.drain();
     254                        audioOutputLine.close();
     255                        audioOutputLine = null;
     256                        audioInputStream.close();
     257                        audioInputStream = null;
     258                        playingUrl = null;
     259                        state = State.NOTPLAYING;
    248260                        command.possiblyInterrupt();
    249                     }
    250                     // end of audio, clean up
    251                     audioOutputLine.drain();
    252                     audioOutputLine.close();
    253                     audioOutputLine = null;
    254                     audioInputStream.close();
    255                     audioInputStream = null;
    256                     playingUrl = null;
    257                     state = State.NOTPLAYING;
    258                     command.possiblyInterrupt();
    259                     break;
     261                        break;
    260262                }
    261263            } catch (InterruptedException e) {
     
    265267                try {
    266268                    switch (command.command()) {
    267                     case PLAY:
    268                         double offset = command.offset();
    269                         speed = command.speed();
    270                         if (playingUrl != command.url() ||
    271                             stateChange != State.PAUSED ||
    272                             offset != 0.0)
    273                         {
    274                             if (audioInputStream != null) {
    275                                 audioInputStream.close();
    276                                 audioInputStream = null;
    277                             }
    278                             playingUrl = command.url();
    279                             audioInputStream = AudioSystem.getAudioInputStream(playingUrl);
    280                             audioFormat = audioInputStream.getFormat();
    281                             long nBytesRead = 0;
    282                             position = 0.0;
    283                             offset -= leadIn;
    284                             double calibratedOffset = offset * calibration;
    285                             bytesPerSecond = audioFormat.getFrameRate() /* frames per second */
     269                        case PLAY:
     270                            double offset = command.offset();
     271                            speed = command.speed();
     272                            if (playingUrl != command.url() ||
     273                                    stateChange != State.PAUSED ||
     274                                    offset != 0.0)
     275                            {
     276                                if (audioInputStream != null) {
     277                                    audioInputStream.close();
     278                                    audioInputStream = null;
     279                                }
     280                                playingUrl = command.url();
     281                                audioInputStream = AudioSystem.getAudioInputStream(playingUrl);
     282                                audioFormat = audioInputStream.getFormat();
     283                                long nBytesRead = 0;
     284                                position = 0.0;
     285                                offset -= leadIn;
     286                                double calibratedOffset = offset * calibration;
     287                                bytesPerSecond = audioFormat.getFrameRate() /* frames per second */
    286288                                * audioFormat.getFrameSize() /* bytes per frame */;
    287                             if (speed * bytesPerSecond > 256000.0)
    288                                 speed = 256000 / bytesPerSecond;
    289                             if (calibratedOffset > 0.0) {
    290                                 long bytesToSkip = (long)(
    291                                         calibratedOffset /* seconds (double) */ * bytesPerSecond);
    292                                 /* skip doesn't seem to want to skip big chunks, so
    293                                  * reduce it to smaller ones
    294                                  */
    295                                 // audioInputStream.skip(bytesToSkip);
    296                                 while (bytesToSkip > chunk) {
    297                                     nBytesRead = audioInputStream.skip(chunk);
    298                                     if (nBytesRead <= 0)
    299                                         throw new IOException(tr("This is after the end of the recording"));
    300                                     bytesToSkip -= nBytesRead;
     289                                if (speed * bytesPerSecond > 256000.0) {
     290                                    speed = 256000 / bytesPerSecond;
    301291                                }
    302                                 if (bytesToSkip > 0)
    303                                     audioInputStream.skip(bytesToSkip);
    304                                 position = offset;
    305                             }
    306                             if (audioOutputLine != null)
    307                                 audioOutputLine.close();
    308                             audioFormat = new AudioFormat(audioFormat.getEncoding(),
     292                                if (calibratedOffset > 0.0) {
     293                                    long bytesToSkip = (long)(
     294                                            calibratedOffset /* seconds (double) */ * bytesPerSecond);
     295                                    /* skip doesn't seem to want to skip big chunks, so
     296                                     * reduce it to smaller ones
     297                                     */
     298                                    // audioInputStream.skip(bytesToSkip);
     299                                    while (bytesToSkip > chunk) {
     300                                        nBytesRead = audioInputStream.skip(chunk);
     301                                        if (nBytesRead <= 0)
     302                                            throw new IOException(tr("This is after the end of the recording"));
     303                                        bytesToSkip -= nBytesRead;
     304                                    }
     305                                    if (bytesToSkip > 0) {
     306                                        audioInputStream.skip(bytesToSkip);
     307                                    }
     308                                    position = offset;
     309                                }
     310                                if (audioOutputLine != null) {
     311                                    audioOutputLine.close();
     312                                }
     313                                audioFormat = new AudioFormat(audioFormat.getEncoding(),
    309314                                        audioFormat.getSampleRate() * (float) (speed * calibration),
    310315                                        audioFormat.getSampleSizeInBits(),
     
    313318                                        audioFormat.getFrameRate() * (float) (speed * calibration),
    314319                                        audioFormat.isBigEndian());
    315                             DataLine.Info info = new DataLine.Info(SourceDataLine.class, audioFormat);
    316                             audioOutputLine = (SourceDataLine) AudioSystem.getLine(info);
    317                             audioOutputLine.open(audioFormat);
    318                             audioOutputLine.start();
    319                         }
    320                         stateChange = State.PLAYING;
    321                         break;
    322                     case PAUSE:
    323                         stateChange = State.PAUSED;
    324                         break;
     320                                DataLine.Info info = new DataLine.Info(SourceDataLine.class, audioFormat);
     321                                audioOutputLine = (SourceDataLine) AudioSystem.getLine(info);
     322                                audioOutputLine.open(audioFormat);
     323                                audioOutputLine.start();
     324                            }
     325                            stateChange = State.PLAYING;
     326                            break;
     327                        case PAUSE:
     328                            stateChange = State.PAUSED;
     329                            break;
    325330                    }
    326331                    command.ok(stateChange);
     
    335340
    336341    public static void audioMalfunction(Exception ex) {
    337         JOptionPane.showMessageDialog(Main.parent,
     342        OptionPaneUtil.showMessageDialog(Main.parent,
    338343                "<html><p>" + tr(ex.getMessage()) + "</p></html>",
    339344                tr("Error playing sound"), JOptionPane.ERROR_MESSAGE);
  • trunk/src/org/openstreetmap/josm/tools/BugReportExceptionHandler.java

    r1674 r1865  
    2020
    2121import org.openstreetmap.josm.Main;
    22 import org.openstreetmap.josm.actions.AboutAction;
    2322import org.openstreetmap.josm.actions.ShowStatusReportAction;
     23import org.openstreetmap.josm.gui.OptionPaneUtil;
    2424import org.openstreetmap.josm.plugins.PluginHandler;
    2525
     
    3939            if (e instanceof OutOfMemoryError) {
    4040                // do not translate the string, as translation may raise an exception
    41                 JOptionPane.showMessageDialog(Main.parent, "JOSM is out of memory. " +
     41                OptionPaneUtil.showMessageDialog(Main.parent, "JOSM is out of memory. " +
    4242                        "Strange things may happen.\nPlease restart JOSM with the -Xmx###M option,\n" +
    4343                        "where ### is the the number of MB assigned to JOSM (e.g. 256).\n" +
    44                         "Currently, " + Runtime.getRuntime().maxMemory()/1024/1024 + " MB are available to JOSM.");
     44                        "Currently, " + Runtime.getRuntime().maxMemory()/1024/1024 + " MB are available to JOSM.",
     45                        tr("Error"),
     46                        JOptionPane.ERROR_MESSAGE
     47                );
    4548                return;
    4649            }
     
    5053
    5154            Object[] options = new String[]{tr("Do nothing"), tr("Report Bug")};
    52             int answer = JOptionPane.showOptionDialog(Main.parent, tr("An unexpected exception occurred.\n\n" +
    53             "This is always a coding error. If you are running the latest\n" +
     55            int answer = OptionPaneUtil.showOptionDialog(Main.parent, tr("An unexpected exception occurred.\n\n" +
     56                    "This is always a coding error. If you are running the latest\n" +
    5457            "version of JOSM, please consider being kind and file a bug report."),
    5558            tr("Unexpected Exception"), JOptionPane.YES_NO_OPTION, JOptionPane.ERROR_MESSAGE,
    56             null, options, options[0]);
    57             if (answer == 1) {
     59            options, options[0]);
     60            if (answer == JOptionPane.YES_OPTION) {
    5861                try {
    5962                    StringWriter stack = new StringWriter();
     
    6568                    JPanel p = new JPanel(new GridBagLayout());
    6669                    p.add(new JLabel("<html>" + tr("Please report a ticket at {0}","http://josm.openstreetmap.de/newticket") +
    67                     "<br>" + tr("Include your steps to get to the error (as detailed as possible)!") +
    68                     "<br>" + tr("Try updating to the newest version of JOSM and all plugins before reporting a bug.") +
    69                     "<br>" + tr("Be sure to include the following information:") + "</html>"), GBC.eol());
     70                            "<br>" + tr("Include your steps to get to the error (as detailed as possible)!") +
     71                            "<br>" + tr("Try updating to the newest version of JOSM and all plugins before reporting a bug.") +
     72                            "<br>" + tr("Be sure to include the following information:") + "</html>"), GBC.eol());
    7073                    try {
    7174                        Toolkit.getDefaultToolkit().getSystemClipboard().setContents(new StringSelection(text), new ClipboardOwner(){
     
    8184                    p.add(new JScrollPane(info), GBC.eop());
    8285
    83                     JOptionPane.showMessageDialog(Main.parent, p);
     86                    OptionPaneUtil.showMessageDialog(Main.parent, p, tr("Warning"), JOptionPane.WARNING_MESSAGE);
    8487                } catch (Exception e1) {
    8588                    e1.printStackTrace();
  • trunk/src/org/openstreetmap/josm/tools/Shortcut.java

    r1415 r1865  
    44import static org.openstreetmap.josm.tools.I18n.tr;
    55import org.openstreetmap.josm.Main;
     6import org.openstreetmap.josm.gui.OptionPaneUtil;
    67
    78import java.awt.event.KeyEvent;
     
    3031 */
    3132public class Shortcut {
    32 //  public static final int SHIFT = KeyEvent.SHIFT_DOWN_MASK;
    33 //  public static final int CTRL = KeyEvent.CTRL_DOWN_MASK;
    34 //  public static final int SHIFT_CTRL = KeyEvent.SHIFT_DOWN_MASK|KeyEvent.CTRL_DOWN_MASK;
     33    //  public static final int SHIFT = KeyEvent.SHIFT_DOWN_MASK;
     34    //  public static final int CTRL = KeyEvent.CTRL_DOWN_MASK;
     35    //  public static final int SHIFT_CTRL = KeyEvent.SHIFT_DOWN_MASK|KeyEvent.CTRL_DOWN_MASK;
    3536    public static final int SHIFT_DEFAULT = 1;
    3637    private String shortText;        // the unique ID of the shortcut
     
    135136    public void setAssignedUser(boolean assignedUser) {
    136137        this.reset = (!this.assignedUser && assignedUser);
    137         if (assignedUser) assignedDefault = false;
     138        if (assignedUser) {
     139            assignedDefault = false;
     140        }
    138141        this.assignedUser = assignedUser;
    139142    }
     
    215218    // check if something collides with an existing shortcut
    216219    private static Shortcut findShortcut(int requestedKey, int modifier) {
    217         if (modifier == groups.get(GROUP_NONE)) {
     220        if (modifier == groups.get(GROUP_NONE))
    218221            return null;
    219         }
    220222        for (Shortcut sc : shortcuts.values()) {
    221             if (sc.isSame(requestedKey, modifier)) {
     223            if (sc.isSame(requestedKey, modifier))
    222224                return sc;
    223             }
    224225        }
    225226        return null;
     
    238239        for (int m : mods) {
    239240            for (int k = KeyEvent.VK_A; k < KeyEvent.VK_Z; k++) { // we'll limit ourself to 100% safe keys
    240                 if ( findShortcut(k, m) == null ) {
     241                if ( findShortcut(k, m) == null )
    241242                    return new Shortcut(shortText, longText, requestedKey, requestedGroup, k, m, false, false);
    242                 }
    243243            }
    244244        }
     
    281281        while (p != null) {
    282282            Shortcut sc = new Shortcut(p);
    283             if (sc.getAssignedUser()) registerShortcut(sc);
     283            if (sc.getAssignedUser()) {
     284                registerShortcut(sc);
     285            }
    284286            i++;
    285287            p = Main.pref.get("shortcut.shortcut."+i, null);
     
    290292        while (p != null) {
    291293            Shortcut sc = new Shortcut(p);
    292             if (!sc.getAssignedUser() && sc.getAssignedDefault()) registerShortcut(sc);
     294            if (!sc.getAssignedUser() && sc.getAssignedDefault()) {
     295                registerShortcut(sc);
     296            }
    293297            i++;
    294298            p = Main.pref.get("shortcut.shortcut."+i, null);
     
    299303        while (p != null) {
    300304            Shortcut sc = new Shortcut(p);
    301             if (!sc.getAssignedUser() && !sc.getAssignedDefault()) registerShortcut(sc);
     305            if (!sc.getAssignedUser() && !sc.getAssignedDefault()) {
     306                registerShortcut(sc);
     307            }
    302308            i++;
    303309            p = Main.pref.get("shortcut.shortcut."+i, null);
     
    307313    // shutdown handling
    308314    public static void savePrefs() {
    309 //      we save this directly from the preferences pane, so don't overwrite these values here
    310 //      for (int i = GROUP_NONE; i < GROUP__MAX+GROUPS_ALT2; i++) {
    311 //      Main.pref.put("shortcut.groups."+i, Groups.get(i).toString());
    312 //      }
     315        //      we save this directly from the preferences pane, so don't overwrite these values here
     316        //      for (int i = GROUP_NONE; i < GROUP__MAX+GROUPS_ALT2; i++) {
     317        //      Main.pref.put("shortcut.groups."+i, Groups.get(i).toString());
     318        //      }
    313319        int i = 0;
    314320        for (Shortcut sc : shortcuts.values()) {
    315 //          TODO: Remove sc.getAssignedUser() when we fixed all internal conflicts
     321            //          TODO: Remove sc.getAssignedUser() when we fixed all internal conflicts
    316322            if (!sc.getAutomatic() && !sc.getReset() && sc.getAssignedUser()) {
    317323                Main.pref.put("shortcut.shortcut."+i, sc.asPrefString());
     
    326332        // put a user configured shortcut in as-is -- unless there's a conflict
    327333        if(sc.getAssignedUser() && findShortcut(sc.getAssignedKey(),
    328         sc.getAssignedModifier()) == null)
     334                sc.getAssignedModifier()) == null) {
    329335            shortcuts.put(sc.getShortText(), sc);
    330         else
     336        } else {
    331337            registerShortcut(sc.getShortText(), sc.getLongText(), sc.getRequestedKey(),
    332             sc.getRequestedGroup(), sc.getAssignedModifier(), sc);
     338                    sc.getRequestedGroup(), sc.getAssignedModifier(), sc);
     339        }
    333340    }
    334341
     
    339346     */
    340347    public static Shortcut registerSystemShortcut(String shortText, String longText, int key, int modifier) {
    341         if (shortcuts.containsKey(shortText)) {
     348        if (shortcuts.containsKey(shortText))
    342349            return shortcuts.get(shortText);
    343         }
    344350        Shortcut potentialShortcut = findShortcut(key, modifier);
    345351        if (potentialShortcut != null) {
     
    391397        Integer defaultModifier = groups.get(requestedGroup + GROUPS_DEFAULT);
    392398        if(modifier != null) {
    393             if(modifier == SHIFT_DEFAULT)
     399            if(modifier == SHIFT_DEFAULT) {
    394400                defaultModifier |= KeyEvent.SHIFT_DOWN_MASK;
    395             else
     401            } else {
    396402                defaultModifier = modifier;
     403            }
    397404        }
    398405        else if (defaultModifier == null) { // garbage in, no shortcut out
     
    437444    // a lengthy warning message
    438445    private static void displayWarning(Shortcut conflictsWith, Shortcut potentialShortcut, String shortText, String longText) {
    439         JOptionPane.showMessageDialog(Main.parent,
     446        OptionPaneUtil.showMessageDialog(Main.parent,
    440447                tr("Setting the keyboard shortcut ''{0}'' for the action ''{1}'' ({2}) failed\n"+
    441448                        "because the shortcut is already taken by the action ''{3}'' ({4}).\n\n",
     
    447454                                    tr("Using the shortcut ''{0}'' instead.\n\n", potentialShortcut.getKeyText())
    448455                        )+
    449                         tr("(Hint: You can edit the shortcuts in the preferences.)")
     456                        tr("(Hint: You can edit the shortcuts in the preferences.)"),
     457                        tr("Error"),
     458                        JOptionPane.ERROR_MESSAGE
    450459        );
    451460    }
Note: See TracChangeset for help on using the changeset viewer.