source: josm/trunk/src/org/openstreetmap/josm/actions/DownloadPrimitiveAction.java@ 13632

Last change on this file since 13632 was 13106, checked in by Don-vip, 6 years ago

add some javadoc

  • Property svn:eol-style set to native
File size: 2.8 KB
Line 
1// License: GPL. For details, see LICENSE file.
2package org.openstreetmap.josm.actions;
3
4import static org.openstreetmap.josm.gui.help.HelpUtil.ht;
5import static org.openstreetmap.josm.tools.I18n.tr;
6
7import java.awt.event.ActionEvent;
8import java.awt.event.KeyEvent;
9import java.util.List;
10
11import org.openstreetmap.josm.data.osm.PrimitiveId;
12import org.openstreetmap.josm.gui.MainApplication;
13import org.openstreetmap.josm.gui.download.DownloadObjectDialog;
14import org.openstreetmap.josm.gui.io.DownloadPrimitivesWithReferrersTask;
15import org.openstreetmap.josm.gui.util.GuiHelper;
16import org.openstreetmap.josm.tools.Shortcut;
17
18/**
19 * Download an OsmPrimitive by specifying type and ID
20 *
21 * @author Matthias Julius
22 */
23public class DownloadPrimitiveAction extends JosmAction {
24
25 /**
26 * Action shortcut (ctrl-shift-O by default), made public in order to be used from {@code GettingStarted} page.
27 */
28 public static final Shortcut SHORTCUT = Shortcut.registerShortcut("system:download_primitive", tr("File: {0}", tr("Download object...")),
29 KeyEvent.VK_O, Shortcut.CTRL_SHIFT);
30
31 /**
32 * Constructs a new {@code DownloadPrimitiveAction}.
33 */
34 public DownloadPrimitiveAction() {
35 super(tr("Download object..."), "downloadprimitive", tr("Download OSM object by ID."),
36 SHORTCUT, true);
37 putValue("help", ht("/Action/DownloadObject"));
38 }
39
40 @Override
41 public void actionPerformed(ActionEvent e) {
42 DownloadObjectDialog dialog = new DownloadObjectDialog();
43 if (dialog.showDialog().getValue() != dialog.getContinueButtonIndex()) return;
44
45 processItems(dialog.isNewLayerRequested(), dialog.getOsmIds(), dialog.isReferrersRequested(), dialog.isFullRelationRequested());
46 }
47
48 /**
49 * Submits the download task for the given primitive ids.
50 * @param newLayer if the data should be downloaded into a new layer
51 * @param ids List of primitive id to download
52 * @param downloadReferrers if the referrers of the object should be downloaded as well, i.e., parent relations, and for nodes,
53 * additionally, parent ways
54 * @param full if the members of a relation should be downloaded as well
55 */
56 public static void processItems(boolean newLayer, final List<PrimitiveId> ids, boolean downloadReferrers, boolean full) {
57 final DownloadPrimitivesWithReferrersTask task =
58 new DownloadPrimitivesWithReferrersTask(newLayer, ids, downloadReferrers, full, null, null);
59 MainApplication.worker.submit(task);
60 MainApplication.worker.submit(() -> {
61 final List<PrimitiveId> downloaded = task.getDownloadedId();
62 if (downloaded != null) {
63 GuiHelper.runInEDT(() -> MainApplication.getLayerManager().getEditDataSet().setSelected(downloaded));
64 }
65 });
66 }
67}
Note: See TracBrowser for help on using the repository browser.