public interface DownloadTask
Modifier and Type | Method and Description |
---|---|
String |
acceptsDocumentationSummary()
Returns a short HTML documentation string, describing acceptable URLs.
|
boolean |
acceptsUrl(String url)
Returns true if the task is able to open the given URL, false otherwise.
|
void |
cancel()
Cancels the asynchronous download task.
|
Future<?> |
download(boolean newLayer,
Bounds downloadArea,
ProgressMonitor progressMonitor)
Asynchronously launches the download task for a given bounding box.
|
String |
getConfirmationMessage(URL url)
Replies the HTML-formatted confirmation message to be shown to user when the given URL needs to be confirmed before loading.
|
List<Object> |
getErrorObjects()
Replies the error objects of the task.
|
String[] |
getPatterns()
Returns regular expressions that match the URLs
|
String |
getTitle()
Returns human-readable description of the task
|
Future<?> |
loadUrl(boolean newLayer,
String url,
ProgressMonitor progressMonitor)
Asynchronously launches the download task for a given bounding URL.
|
Future<?> download(boolean newLayer, Bounds downloadArea, ProgressMonitor progressMonitor)
progressMonitor
to null, if the task should create, open, and close a progress monitor.
Set progressMonitor to NullProgressMonitor.INSTANCE
if progress information is to
be discarded.
You can wait for the asynchronous download task to finish by synchronizing on the returned
Future
, but make sure not to freeze up JOSM. Example:
Future> future = task.download(...); // DON'T run this on the Swing EDT or JOSM will freeze future.get(); // waits for the dowload task to completeThe following example uses a pattern which is better suited if a task is launched from the Swing EDT:
final Future> future = task.download(...); Runnable runAfterTask = new Runnable() { public void run() { // this is not strictly necessary because of the type of executor service // Main.worker is initialized with, but it doesn't harm either // future.get(); // wait for the download task to complete doSomethingAfterTheTaskCompleted(); } } Main.worker.submit(runAfterTask);
newLayer
- true, if the data is to be downloaded into a new layer. If false, the task
selects one of the existing layers as download layer, preferably the active layer.downloadArea
- the area to downloadprogressMonitor
- the progressMonitorFuture<?> loadUrl(boolean newLayer, String url, ProgressMonitor progressMonitor)
NullProgressMonitor.INSTANCE
if progress information is to
be discarded.newLayer
- newLayer true, if the data is to be downloaded into a new layer. If false, the task
selects one of the existing layers as download layer, preferably the active layer.url
- the url to download fromprogressMonitor
- the progressMonitordownload(boolean, Bounds, ProgressMonitor)
boolean acceptsUrl(String url)
url
- the url to download fromString acceptsDocumentationSummary()
String getTitle()
String[] getPatterns()
List<Object> getErrorObjects()
String
s with error messages or Exception
s.void cancel()
String getConfirmationMessage(URL url)
url
- The URL to be confirmed