Overlays
An Overlay
is an additional map layer, either default or user-defined, with data stored on Magic Lane servers, accessible in online and offline modes, with few exceptions.
In order to define overlay data you can use the Magic Lane Map Studio. It allows uploading data regarding the POIs and their corresponding categories and binary information (via GeoJSON
format). An Overlay
can have multiple associated categories and subcategories. A single item from an overlay is called an overlay item.
If the corresponding map region has been downloaded locally, overlays will not be available in offline mode, except if they are downloaded too. See the Downloading overlays guide for more details.
Most overlay features can be used only when a GemMap
widget is created and a style containing the overlay is applied.
OverlayInfo
OverlayInfo structure
The class that contains information about an overlay is OverlayInfo
. It has the following structure:
Method | Description | Type |
---|---|---|
uid | Gets the unique ID of the overlay. | int |
categories | Gets the categories of the overlay. | List<OverlayCategory> |
getCategory | Gets a category by its ID. | OverlayCategory? |
img | Gets the image of the overlay. | Img |
name | Gets the name of the overlay. | String |
hasCategories | Checks if the category has subcategories. | bool |
Retrieving overlays
To get all overlays which are available for the current map style, the OverlayService.getAvailableOverlays()
method is used in the following way:
final Completer<GemError> completer = Completer<GemError>();
final (OverlayCollection, bool) availableOverlays =
OverlayService.getAvailableOverlays(onCompleteDownload: (error) {
completer.complete(error);
});
await completer.future;
OverlayCollection collection = availableOverlays.$1;
The OverlayCollection
class contains methods and getters such as:
- size: returns the size of the collection.
- getOverlayAt: returns the
OverlayInfo
at a specified index and null if it doesn't exist. - getOverlayById: returns an
OverlayInfo
by a given id.
The returned OverlayCollection
contains all the overlays available for the current map style: alerts (CommonOverlayId.safety
), speed cameras (CommonOverlayId.socialReports
), public transit stops (CommonOverlayId.publicTransport
).
It is possible that information for certain overlays is unavailable and needs to be downloaded when a network connection is accessible. As a result, the method returns a record of type (OverlayCollection, bool)
, where the boolean value in the second element is false, indicating that the information is currently unavailable. In this case, the onCompleteDownload
callback needs to be awaited.
Usage
The primary function of the OverlayInfo
class is to provide the categories within an overlay. It also provides the uid
of the overlay which can be used to filter the results of search and also can be used to toggle the visibility of the overlay on the map. Other fields can be displayed on the UI.
OverlayCategory
The OverlayCategory
class represents hierarchical data related to overlay categories.
OverlayCategory structure
The OverlayCategory
has the following structure:
Property / Method | Description | Type |
---|---|---|
uid | The category ID. | int |
overlayuid | The parent overlay ID. Refers to the id of the OverlayInfo object | int |
img | The category icon. | Img |
name | The category name. | String |
subcategories | The subcategories of the category. | List<OverlayCategory> |
hasSubcategories | Checks if the category has subcategories. | bool |
Usage
The OverlayCategory
class provides the category uid
, which can be utilized in various search functionalities to filter results. Additionally, the uid
can be used to filter and manage overlay items that trigger alerts within the AlarmService
.
OverlayItem
The OverlayItem
represents a single element from the overlay.
OverlayItem structure
The OverlayItem
has the following structure:
Property / Method | Description | Type |
---|---|---|
categoryId | Gets the OverlayItem's category ID. May be 0 if the item does not belong to a specfic category. Gives the id of the root category which may not be the direct parent category. | int |
coordinates | Gets the coordinates of the OverlayItem. | Coordinates |
hasPreviewExtendedData | Checks if the OverlayItem has preview extended data (dynamic data). Available only for overlays predefined. | bool |
img | Gets the image of the OverlayItem. | Img |
name | Gets the name of the OverlayItem. | String |
uid | Gets the unique ID of the OverlayItem within the overlay. | int |
overlayInfo | Gets the parent OverlayInfo. | OverlayInfo |
previewData | Gets the OverlayItem preview data as a parameters list. | SearchableParameterList |
previewUrl | Gets the preview URL for the item (if any). | String |
overlayUid | Gets the parent overlay UID. | int |
getPreviewExtendedData | Asynchronously gets the OverlayItem preview extended data. | ProgressListener |
cancelGetPreviewExtendedData | Cancels the asynchronous getPreviewExtendedData operation. | void |
The previewData
returned is not available if the parent map tile is disposed.
Please get the preview data before further interactions with the map.
Avoid confusing the uid of OverlayInfo
, OverlayCategory
, and OverlayItem
, as they each serve distinct purposes.
To check if a OverlayItem
belongs to a OverlayInfo
, use the overlayUid
property, or retrieve the whole OverlayInfo
object via the overlayInfo
property.
The previewData
getter which provides more information structured inside a SearchableParametersList
, information which depend on the overlay type.
We can iterate through all the parameters (which are of type GemParameter
) within a SearchableParameterList
in the following way:
SearchableParameterList parameters = overlayItem.previewDataParameterList;
for (GemParameter param in parameters){
// Unique for every parameter
String? key = param.key;
// Used for display on UI - might change depending on language
String? name = param.name;
// The type of param.value
ValueType valueType = param.type;
// The parameter value
dynamic value = param.value;
}
In order to obtain preview data in a more structured way, you can use the getPreviewParametersAs
getter, which allows you to retrieve the data as a specific class based on the overlay type. Below is an example of how to use it for different overlay types:
if (overlayItem.overlayUid == CommonOverlayId.publicTransport.id) {
PublicTransportParameters? parameters =
overlays.first.getPreviewParametersAs<PublicTransportParameters>();
if (parameters == null) {
print("Parameters are null");
return;
}
String? name = parameters.name;
DateTime? createStamp = parameters.createStampUtc;
int? iconId = parameters.iconId;
bool? streetDirectionFlag = parameters.strDrivingDirectionFlag;
}
if (overlayItem.overlayUid == CommonOverlayId.safety.id) {
SafetyParameters? parameters =
overlays.first.getPreviewParametersAs<SafetyParameters>();
if (parameters == null) {
print("Parameters are null");
return;
}
String? countryName = parameters.country;
int? speedValue = parameters.speedValue;
// other fields...
}
if (overlayItem.overlayUid == CommonOverlayId.socialReports.id) {
SocialReportParameters? parameters =
overlays.first.getPreviewParametersAs<SocialReportParameters>();
if (parameters == null) {
print("Parameters are null");
return;
}
int? title = parameters.score;
String? description = parameters.description;
DateTime? createStamp = parameters.createStampUtc;
// other fields...
}
The categoryId
getter returns the ID of the root category, which may not necessarily be the direct parent category of the OverlayItem
.
To obtain the direct parent category, you can use the following snippet:
final int parentCategoryId = overlayItem.previewDataParameterList.findParameter('icon').value as int;
Use the getCategory
method from the parent OverlayInfo
class to retrieve the OverlayCategory
object corresponding to this ID.
Usage
OverlayItems
can be selected from the map or be provided by the AlarmService
on approach. Other fields and information can be displayed on the UI.
Classification
There are a few types of predefined overlays:
- Safety overlay
- Public transport overlay
- Social reports overlay
The CommonOverlayId
enum contains information about the ids of the predefined overlay categories.
Safety Overlay
These overlays represent speed limit cameras, red light controls and so on.
For a speed limit, previewData
might include information searchable by keys like:
eStrDrivingDirection
: the driving direction on which the overlay item applies as string, eg. "Both Ways"speedValue
: value of maximum allowed speed as integer, eg. 50speedUnit
: measure unit of speed as string, eg "km/h"Country
: country name where the overlay is reported as string, eg "FRA"
Public Transport Overlay
This overlay is responsible for displaying public transport stations.
For a bus station, previewData
might include information searchable by keys like:
id
: unique overlay id as integercreate_stamp_utc
: unix epoch time when overlay has been created as integericon
: an array of 8-bit integeres representing icon data as Uint8Listname
: name of bus station as a string
There are two types of public transport stops available on the map:
- Bus station with schedule information, available on the map as overlay items.
- Bus station without schedule information, available on the map as landmarks.
Social Reports Overlay
This overlay is responsible for displaying fixed cameras, construction sites and more.
For a construction report, previewData
includes information searchable by keys like:
longitude
: value for longitude coordinate as doublelatitude
: value for latitude coordinates as doubleowner_name
: user's name that reported the event as stringscore
: likes (confirmations) offered by other userslocation_address
: address of reported location as string, it contains street, city and country
The SocialOverlay
static class is responsible for generating, updating, and deleting social reports. It includes several static methods designed to perform these operations efficiently.
Interaction with Overlays
Selecting overlay items
Overlay items are selectable. When user taps or clicks, you can identify specific overlay items programmatically (e.g., through the function cursorSelectionOverlayItems()
). Please refer to the Map Selection Functionality guide for more details.
Searching overlay items
Overlays are searchable. This can be done in multiple ways, the most common being to set the right properties in the search preferences when performing a regular search. More details can be found within the Get started with Search guide.
Calculating route with overlay items
Overlay items are not designed for route calculation and navigation.
Create a new landmark using the overlay item's relevant coordinates and a representative name, then utilize this object for routing purposes.
Get notifications when approaching overlay items
Alarms can be configured to notify users when they approach specific overlay items from selected overlays. See the Landmarks and overlay alarms guide for more details about implementing this feature.
Activate highlights
Overlay Items can be highlighted using the activateHighlightOverlayItems
method provided by the GemMapController
class.