Ignore:
Timestamp:
2013-07-25T03:26:37+02:00 (11 years ago)
Author:
donvip
Message:

[josm_directdownload] see #josm6355 - Move menu entry to GPS menu + code cleanup

Location:
applications/editors/josm/plugins/DirectDownload/src/org/openstreetmap/josm/plugins/directdownload
Files:
2 edited

Legend:

Unmodified
Added
Removed
  • applications/editors/josm/plugins/DirectDownload/src/org/openstreetmap/josm/plugins/directdownload/DirectDownload.java

    r29222 r29776  
    33import static org.openstreetmap.josm.tools.I18n.tr;
    44
     5import java.awt.event.ActionEvent;
    56import java.io.InputStream;
    6 import java.io.IOException;
    7 
    87import java.net.URL;
    98
    10 import java.util.List;
    11 
    12 import java.awt.event.ActionEvent;
     9import javax.swing.JOptionPane;
    1310
    1411import org.openstreetmap.josm.Main;
    1512import org.openstreetmap.josm.actions.JosmAction;
    16 
     13import org.openstreetmap.josm.gui.MainMenu;
     14import org.openstreetmap.josm.gui.layer.GpxLayer;
     15import org.openstreetmap.josm.gui.layer.markerlayer.MarkerLayer;
     16import org.openstreetmap.josm.io.GpxReader;
     17import org.openstreetmap.josm.io.OsmApi;
    1718import org.openstreetmap.josm.plugins.Plugin;
    1819import org.openstreetmap.josm.plugins.PluginInformation;
    19 
    20 import org.openstreetmap.josm.gui.download.DownloadSelection;
    21 
    22 import org.openstreetmap.josm.gui.layer.GpxLayer;
    23 import org.openstreetmap.josm.gui.layer.markerlayer.MarkerLayer;
    24 
    25 import org.openstreetmap.josm.io.GpxReader;
    26 
    27 import javax.swing.JOptionPane;
    28 
    2920import org.xml.sax.SAXException;
    3021
    3122public class DirectDownload extends Plugin {
    32     DownloadAction openaction;
     23    private DownloadAction openaction;
    3324
    34      /**
    35       * Will be invoked by JOSM to bootstrap the plugin
    36       *
    37       * @param info  information about the plugin and its local installation   
    38       */
    39       public DirectDownload(PluginInformation info) {
    40          super(info);
     25    /**
     26     * Will be invoked by JOSM to bootstrap the plugin
     27     *
     28     * @param info  information about the plugin and its local installation   
     29     */
     30    public DirectDownload(PluginInformation info) {
     31        super(info);
    4132
    42         openaction = new DownloadAction();
    43          Main.main.menu.fileMenu.add(openaction);
    44       }
     33        openaction = new DownloadAction();
     34        MainMenu.add(Main.main.menu.gpsMenu, openaction);
     35    }
    4536
    46     class DownloadAction extends JosmAction{
    47         public DownloadAction(){
    48             super(tr("Download Track ..."), "DownloadAction", tr("Download GPX track from openstreetmap.org"),
    49             null, false);
     37    class DownloadAction extends JosmAction {
     38        public DownloadAction() {
     39            super(tr("Download Track ..."), "DownloadAction",
     40                    tr("Download GPX track from openstreetmap.org"), null, false);
    5041        }
     42
    5143        public void actionPerformed(ActionEvent event) {
    5244            DownloadDataGui go = new DownloadDataGui();
    5345            go.setVisible(true);
    5446
    55             UserTrack track = go.getSelectedUserTrack();
     47            UserTrack track = go.getSelectedUserTrack();
    5648
    57             if ((go.getValue() == 1) && (track != null)) {
    58                 String apiBaseUrl = "http://api.openstreetmap.org/api/0.6/";
    59                 String urlString = apiBaseUrl + "gpx/" + track.id + "/data";
     49            if ((go.getValue() == 1) && (track != null)) {
     50                String urlString = OsmApi.getOsmApi().getBaseUrl() + "gpx/" + track.id + "/data";
    6051
    61                 try {
    62                     URL trackDataUrl = new URL(urlString);
    63                     InputStream is = trackDataUrl.openStream();
     52                try {
     53                    URL trackDataUrl = new URL(urlString);
     54                    InputStream is = trackDataUrl.openStream();
    6455
    65                     GpxReader r = new GpxReader(is);
    66                     boolean parsedProperly = r.parse(true);
    67                     GpxLayer gpxLayer = new GpxLayer(r.getGpxData(), track.filename, true);
     56                    GpxReader r = new GpxReader(is);
     57                    boolean parsedProperly = r.parse(true);
     58                    GpxLayer gpxLayer = new GpxLayer(r.getGpxData(), track.filename, true);
    6859
    6960                    if (r.getGpxData().hasRoutePoints() || r.getGpxData().hasTrackPoints()) {
     
    7869                    }
    7970                    if (!parsedProperly) {
    80                         JOptionPane.showMessageDialog(null, tr("Error occurred while parsing gpx file {0}. Only a part of the file will be available.", urlString));
     71                        JOptionPane.showMessageDialog(Main.parent,
     72                            tr("Error occurred while parsing gpx file {0}. Only a part of the file will be available.", urlString));
    8173                    }
    8274
    83                 } catch (java.net.MalformedURLException e) {
    84                     JOptionPane.showMessageDialog(null, tr("Invalid URL {0}", urlString));
    85                 } catch (java.io.IOException e) {
    86                     JOptionPane.showMessageDialog(null, tr("Error fetching URL {0}", urlString));
    87                 } catch (SAXException e) {
    88                     JOptionPane.showMessageDialog(null, tr("Error parsing data from URL {0}", urlString));
    89                 }
    90             }
     75                } catch (java.net.MalformedURLException e) {
     76                    JOptionPane.showMessageDialog(Main.parent,
     77                            tr("Invalid URL {0}", urlString));
     78                } catch (java.io.IOException e) {
     79                    JOptionPane.showMessageDialog(Main.parent,
     80                            tr("Error fetching URL {0}", urlString));
     81                } catch (SAXException e) {
     82                    JOptionPane.showMessageDialog(Main.parent,
     83                            tr("Error parsing data from URL {0}", urlString));
     84                }
     85            }
    9186        }
    9287    }
    93 
    9488}
    95 
  • applications/editors/josm/plugins/DirectDownload/src/org/openstreetmap/josm/plugins/directdownload/DownloadDataGui.java

    r23585 r29776  
    33import static org.openstreetmap.josm.tools.I18n.tr;
    44
    5 import java.io.InputStream;
    6 import java.io.IOException;
    7 
     5import java.awt.BorderLayout;
     6import java.awt.Component;
     7import java.awt.Dimension;
    88import java.net.URL;
    9 
    109import java.util.ArrayList;
    1110import java.util.LinkedList;
    1211import java.util.List;
    13 import java.util.StringTokenizer;
    14 
    15 import org.openstreetmap.josm.Main;
    16 import org.openstreetmap.josm.gui.ExtendedDialog;
    17 
    18 import java.awt.BorderLayout;
    19 import java.awt.Component;
    20 import java.awt.Dimension;
    2112
    2213import javax.swing.BorderFactory;
    23 import javax.swing.DefaultListModel;
    2414import javax.swing.DefaultListSelectionModel;
    2515import javax.swing.JLabel;
    26 import javax.swing.JList;
    2716import javax.swing.JOptionPane;
    2817import javax.swing.JPanel;
     
    3120import javax.swing.ListSelectionModel;
    3221import javax.swing.UIManager;
    33 
    3422import javax.swing.event.ListSelectionEvent;
    3523import javax.swing.event.ListSelectionListener;
    36 
    3724import javax.swing.table.DefaultTableColumnModel;
    3825import javax.swing.table.DefaultTableModel;
    3926import javax.swing.table.TableCellRenderer;
    4027import javax.swing.table.TableColumn;
    41 
    42 import org.xml.sax.*;
    43 import org.xml.sax.helpers.*;
    44 
    45 import javax.xml.parsers.SAXParserFactory;
    4628import javax.xml.parsers.ParserConfigurationException;
    4729import javax.xml.parsers.SAXParser;
    48 
     30import javax.xml.parsers.SAXParserFactory;
     31
     32import org.openstreetmap.josm.Main;
     33import org.openstreetmap.josm.gui.ExtendedDialog;
     34import org.openstreetmap.josm.io.OsmApi;
     35import org.xml.sax.Attributes;
     36import org.xml.sax.SAXException;
     37import org.xml.sax.helpers.DefaultHandler;
    4938
    5039public class DownloadDataGui extends ExtendedDialog {
    51     private String apiBaseUrl = "http://api.openstreetmap.org/api/0.6/";
    52 
    53     // User for log in when downloading trace
    54     private String username = Main.pref.get("osm-server.username");
    55     private String password = Main.pref.get("osm-server.password");
    5640
    5741    private NamedResultTableModel model;
     
    6246        // Initalizes ExtendedDialog
    6347        super(Main.parent,
    64               tr("Download Track"),
    65               new String[] {tr("Download Track"), tr("Cancel")},
    66               true
    67               );
    68 
    69         JPanel panel = new JPanel();
    70         panel.setLayout(new BorderLayout());
    71        
     48          tr("Download Track"),
     49          new String[] {tr("Download Track"), tr("Cancel")},
     50          true
     51          );
     52
     53        JPanel panel = new JPanel();
     54        panel.setLayout(new BorderLayout());
     55   
    7256        DefaultListSelectionModel selectionModel = new DefaultListSelectionModel();
    7357        model = new NamedResultTableModel(selectionModel);
     
    8064        panel.add(scrollPane, BorderLayout.CENTER);
    8165
    82         model.setData(getTrackList());
    83 
    84         setContent(panel);
    85         setupDialog();
     66    model.setData(getTrackList());
     67
     68    setContent(panel);
     69    setupDialog();
    8670    }
    8771
    8872    private static class TrackListHandler extends DefaultHandler {
    8973        private LinkedList<UserTrack> data = new LinkedList<UserTrack>();
    90         private String cdata = new String();
    91 
    92         @Override
    93         public void startElement(String namespaceURI, String localName, String qName, Attributes atts)
    94         throws SAXException {
    95             if (qName.equals("gpx_file")) {
    96                 UserTrack track = new UserTrack();
    97 
    98                 track.id       = atts.getValue("id");
    99                 track.filename = atts.getValue("name");
    100                 track.datetime = atts.getValue("timestamp").replaceAll("[TZ]", " "); // TODO: do real parsing and time zone conversion
    101                
    102                 data.addFirst(track);
    103             }
    104             cdata = new String();
    105         }
    106 
    107         public void characters(char ch[], int start, int length)
    108             throws SAXException {
    109             cdata += new String(ch, start, length);
    110         }
    111 
    112         public void endElement(String uri, String localName,
    113                                String qName)
    114             throws SAXException {
    115             if (qName.equals("description")) {
    116                 data.getFirst().description = cdata;
    117             }
    118             /*
    119             else if (qName.equals("tag")) {
    120                 data.getFirst().tags = cdata;
    121                 cdata = new String();
    122             }   
    123             */
    124         }
    125 
     74       
     75        private String cdata = new String();
     76   
     77        @Override
     78        public void startElement(String namespaceURI, String localName, String qName, Attributes atts) throws SAXException {
     79            if (qName.equals("gpx_file")) {
     80            UserTrack track = new UserTrack();
     81   
     82            track.id       = atts.getValue("id");
     83            track.filename = atts.getValue("name");
     84            track.datetime = atts.getValue("timestamp").replaceAll("[TZ]", " "); // TODO: do real parsing and time zone conversion
     85           
     86            data.addFirst(track);
     87            }
     88            cdata = new String();
     89        }
     90   
     91        public void characters(char ch[], int start, int length)
     92            throws SAXException {
     93            cdata += new String(ch, start, length);
     94        }
     95   
     96        public void endElement(String uri, String localName, String qName) throws SAXException {
     97            if (qName.equals("description")) {
     98            data.getFirst().description = cdata;
     99            }
     100            /*
     101            else if (qName.equals("tag")) {
     102            data.getFirst().tags = cdata;
     103            cdata = new String();
     104            }   
     105            */
     106        }
    126107
    127108        public List<UserTrack> getResult() {
     
    131112
    132113    private List<UserTrack> getTrackList() {
    133         String urlString = apiBaseUrl + "user/gpx_files";
    134 
    135         try {
    136             URL userTracksUrl = new URL(urlString);
    137 
    138             SAXParserFactory spf = SAXParserFactory.newInstance();
    139             TrackListHandler handler = new TrackListHandler();
    140 
    141             //get a new instance of parser
    142             SAXParser sp = spf.newSAXParser();
    143            
    144             //parse the file and also register this class for call backs
    145             sp.parse(userTracksUrl.openStream(), handler);
    146            
    147             return handler.getResult();
    148         } catch (java.net.MalformedURLException e) {
    149             JOptionPane.showMessageDialog(null, tr("Invalid URL {0}", urlString));
    150         } catch (java.io.IOException e) {
    151             JOptionPane.showMessageDialog(null, tr("Error fetching URL {0}", urlString));
    152         } catch (SAXException e) {
    153             JOptionPane.showMessageDialog(null, tr("Error parsing data from URL {0}", urlString));
    154         } catch(ParserConfigurationException pce) {
    155             JOptionPane.showMessageDialog(null, tr("Error parsing data from URL {0}", urlString));
    156         }
    157 
    158         return new LinkedList<UserTrack>();
     114        String urlString = OsmApi.getOsmApi().getBaseUrl() + "user/gpx_files";
     115
     116        try {
     117            URL userTracksUrl = new URL(urlString);
     118   
     119            SAXParserFactory spf = SAXParserFactory.newInstance();
     120            TrackListHandler handler = new TrackListHandler();
     121   
     122            //get a new instance of parser
     123            SAXParser sp = spf.newSAXParser();
     124           
     125            //parse the file and also register this class for call backs
     126            sp.parse(userTracksUrl.openStream(), handler);
     127           
     128            return handler.getResult();
     129        } catch (java.net.MalformedURLException e) {
     130            JOptionPane.showMessageDialog(null, tr("Invalid URL {0}", urlString));
     131        } catch (java.io.IOException e) {
     132            JOptionPane.showMessageDialog(null, tr("Error fetching URL {0}", urlString));
     133        } catch (SAXException e) {
     134            JOptionPane.showMessageDialog(null, tr("Error parsing data from URL {0}", urlString));
     135        } catch(ParserConfigurationException pce) {
     136            JOptionPane.showMessageDialog(null, tr("Error parsing data from URL {0}", urlString));
     137        }
     138
     139        return new LinkedList<UserTrack>();
    159140    }
    160141
     
    167148            this.selectionModel = selectionModel;
    168149        }
     150       
    169151        @Override
    170152        public int getRowCount() {
     
    187169            fireTableDataChanged();
    188170        }
     171       
    189172        @Override
    190173        public boolean isCellEditable(int row, int column) {
     
    200183
    201184    public UserTrack getSelectedUserTrack() {
    202         return model.getSelectedUserTrack();
    203     }
    204    
     185        return model.getSelectedUserTrack();
     186    }
    205187
    206188    static class NamedResultTableColumnModel extends DefaultTableColumnModel {
     
    234216
    235217            // column 3 - tags
    236             /*
     218        /*
    237219            col = new TableColumn(3);
    238220            col.setHeaderValue(tr("Tags"));
     
    241223            col.setCellRenderer(renderer);
    242224            addColumn(col);
    243             */
     225        */
    244226        }
    245227
     
    286268            switch(column) {
    287269            case 0:
    288                 setText(sr.datetime);
     270                setText(sr.datetime);
    289271                break;
    290272            case 1:
    291273                setText(sr.filename);
    292                 break;         
    293             case 2:
     274                break;       
     275            case 2:
    294276                setText(sr.description);
    295277                break;
    296                 /*
     278        /*
    297279            case 3:
    298280                setText(sr.tags);
    299281                break;
    300                 */
     282        */
    301283            }
    302284            return this;
    303285        }
    304286    }
    305 
    306287}
Note: See TracChangeset for help on using the changeset viewer.