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);
});