DroneDeploy
Search
K

Map

What many developers think of as a map is known as a plan inside the API. Plans refer to information about the users flights or processed data. Please see Plans for information about how to modify and access plan information.
The map api exposes methods for developers to interact with the map on the user's screen.
Note: You must .subscribe() to methods that draw onto the map. When unsubscribe is called the map changes will be removed.
var sub = dronedeployApi.Map.addPolygon(latLng)
.subscribe(() => {
// This will remove your change from the map.
sub.unsubscribe();
});
Additionally, when you App is removed from the dom all pending subscriptions are destroyed which will in return remove any map change made.

Map.addImageOverlay

Overview
var imageUrl = String;
var bounds = [{ lat: Number, lng: Number }, ....];
dronedeployApi.Map.addImageOverlay(imageUrl, bounds)
.subscribe(function(overlay){ console.log(overlay) });
Response
.subscribe(function(overlay){
overlay.bringToBack();
overlay.bringToFront();
overlay.remove();
overlay.setOpacity(0.4);
overlay.setUrl(imageUrl);
});

Map.panTo

var location = LatLng;
var optionalOptions = {zoom: 20};
dronedeployApi.Map.panTo(location, optionalOptions);

Map.addTileLayer

Overview
var urlTemplate = String;
var optionalOptions = {
errorTileUrl: String,
maxZoom: Number,
minZoom: Number,
};
dronedeployApi.Map.addTileLayer(urlTemplate, optionalOptions);
Response
.subscribe(function(tileLayer){
tileLayer.bringToBack();
tileLayer.bringToFront();
tileLayer.remove();
tileLayer.setOpacity(0.4);
tileLayer.setUrl(tileTemplate);
});
Example
var urlTemplate = 'https://api.mapbox.com/styles/v1/mapbox/dark-v9/tiles/256/{z}/{x}/{y}';
var blankImage = '';
dronedeployApi.Map.addtileLayer(urlTemplate, {
errorTileUrl: blankImage,
maxZoom: 25,
minZoom: 18,
});

Map.addPolygon

Overview
var latLngs = [{lat: Number, lng: Number}, ...];
var optionalOptions = {
color: String,
fill: Boolean,
fillColor: String,
opacity: Number,
weight: Number,
};
dronedeployApi.Map.addPolygon(latLngs, optionalOptions)
.subscribe(function(annotation){ console.log(annotation) });
Response
.subscribe(function(polygon){
polygon.bringToBack();
polygon.bringToFront();
polygon.getCenter().then(function(latLng){ console.log(latLng) });
polygon.getLatLngs().then(function(latLngs){ console.log(latLngs) });
polygon.remove();
polygon.setLatLngs([{lat: 3, lng: 3}, ...]);
polygon.setOpacity(0.4);
});

Map.addGeoJson

Overview
var geoJSON = { [name: string]: any };
var styleCallback = function() {
console.log("styleCallback");
}
var filterCallback = function() {
console.log("filterCallback");
}
dronedeployApi.Map.addGeoJson(geoJSON, styleCallback, filterCallback)
.subscribe(function(geoJSONLayer){ console.log(geoJSONLayer) });
Response
.subscribe(function(geoJSONLayer){
polygon.bringToBack();
polygon.bringToFront();
polygon.center()
polygon.hide();
polygon.remove();
polygon.show();
});

Map.new

Overview
var planId = string;
var filesUrlsOrZipFile = [string, string[]];
var callbackFunc = function(planId, filesUrlsOrZipFile) {
console.log("callbackFunc");
}
dronedeployApi.Map.new(callback, [planId, filesUrlsOrZipFile])
.subscribe(function(func){ });
Response
.subscribe(function(response) {
console.log(response)
});
Last modified 5mo ago