Release notes
12.0.0 (2024-08-19)
🌟 Features and improvements
-
Immersive roads of actual width are displayed in the navigation mode if:
- Map.graphicsPreset field is set to
IMMERSIVE
. HttpCache
is enabled using HttpOptions.useCache.
Roads of actual width are currently available in several large cities of Russia, UAE, and Saudi Arabia only.
- Map.graphicsPreset field is set to
-
Fog is displayed to cut off distant map objects when the map is tilted.
-
ru.dgis.sdk.androidauto
package for integrating the SDK into Android Auto. -
BaseCamera.viewportRestriction to set camera viewport.
-
MapOptions.graphicsPreset to set graphic mode via GraphicsPreset during map initialization.
-
Map.graphicsPreset to set graphic mode via GraphicsPreset for a created map.
-
Map.graphicsPresetHint to get the recommended graphic mode for the given device.
-
Enabled titling the map up to 70 degrees starting from the 18th zoon level.
-
RasterUrlTemplate to set URL template for requesting raster tiles. Can take two values: DefaultRasterUrlTemplate for a common template and WmsRasterUrlTemplate for raster tiles of the WMS standard.
-
MapLocationController.mapToNorthOrientation to force map orientation to the north.
-
RouteCamera.maxSpeedLimit - speed in m/s, exceeding which is captured by the camera.
-
NavigationFollowController.cameraBehaviour - camera mode for tracking geolocation marker in the navigator.
-
Terrain elevation is now considered when displaying road events and traffic jam data on route.
-
If the current position on route is more than 500 away from the next maneuver, the "Go straight" phrase is played.
-
Sound instructions for bicycle and scooter intersections are supported.
-
RouterType to set the search engine type in AlternativeRoutesProviderSettings to search for alternative routes.
-
toRoutePoint
parameter in the MillisecondsRouteAttribute.calculateDuration method to calculate duration of moving along the route part towards a particular point. -
TerritoryManager.findByPoint and TerritoryManager.findByRect methods to filter regions that are available for downloading offline by
GeoPoint
andGeoRect
.
❗ Breaking changes and backward compatibility
- Moved
KeySource
,KeyFromAsset
,KeyFromFile
, andKeyFromString
toru.dgis.sdk.platform
. - Moved
VendorConfig
,VendorConfigFromAsset
,VendorConfigFromFile
, andVendorConfigFromString
toru.dgis.sdk.platform
. - Moved
LogOptions
,LogLevel
,LogMessage
, andLogSink
toru.dgis.sdk.platform
. - Moved
HttpOptions
,Certificate
,CertificateFromAsset
,CertificateFromFile
,SystemCertificate
, andHttpProxyOptions
toru.dgis.sdk.platform
. - Removed
MyLocationController
andMapLocationController.myLocationIndicatorController
. To configure the marker geolocation source, use MyLocationControllerSettings. In the NavigationView, geolocation source is now not substituted. - Added the
GEO_POSITION
value to EventsProcessingSettings.rotationCenter and EventsProcessingSettings.scalingCenter to set the gesture operation mode relative to the geolocation. To set the position, relatively to which the gesture will be working, use the GestureManager.setTargetGeoPoint method. - Moved Meter from
ru.dgis.sdk.map
toru.dgis.sdk
. - Removed the
CameraState.FOLLOW_POSITION
value. Instead, see the Camera.behaviour value. - Extended values for SuggestedType, SuggestorType, and ObjectType so that they now correspond to Places API results.
- Removed the
createRasterTileDataSource
method. Added a new source of raster tiles RasterTileSource, which enables setting transparency for raster tiles. - Removed
AudioVolume
. You can now set instructions volume from 0 to 100 using AudioSettings.volume. - RouteMapObjectDisplayFlag.IMMERSIVE_ROUTE_PARTS - flag to use immersive geometry on route parts.
🛠 Bug fixes
- Optimized caching of road events when displaying them on the map.
- Fixed artifacts of screen rotation when enabling
Vulkan
. - Fixed issues that prevented displaying route variants if an invalid variant was included into the list of public transport routes.
- Fixed the record of the covered distance along an alternative route.
- Improved the display of stops on public transport routes.
- Improved erasing of the route when the route finish point is reached.
- Fixed the active route display in poor GPS signal conditions.
- Voice instructions are now not played during navigation in poor GPS signal conditions.
- Distance to the next camera is not considered if it is less than 150 meters.
- Voice instructions are not played when navigation starts.
- Distance to intersection control cameras, public transport lanes, and road markings is not voiced.
- Distance left on route is not voiced if other instructions are expected further on route.
- Pedestrian obstacles and road subtypes for non-pedestrian routes are not voiced.
🗺 Map style updates
- Added layers with immersive roads of actual width.
- Improved various layers so that they are displayed properly if immersive roads of actual width are present on the map.
- Updated geolocation marker designs in normal and navigation modes. Made the marker display in light and dark themes consistent.
- Supported new Moscow Metro line MCD-4A.
- Fixed styles of Moscow Metro lines MCD-3, MCD-4, MCD-4A, and MCD-5.
- Added stop captions on public transport routes.
- Enabled displaying stop captions when viewing the full route of a selected public transport.
Migration from versions 10.x to 12.х
For all types of Mobile SDK:
- Styles must be exported again.
- To ensure proper display of the geolocation marker, copy corresponding layers.
- Moved
KeySource
,KeyFromAsset
,KeyFromFile
, andKeyFromString
toru.dgis.sdk.platform
. - Moved
VendorConfig
,VendorConfigFromAsset
,VendorConfigFromFile
, andVendorConfigFromString
toru.dgis.sdk.platform
. - Moved
LogOptions
,LogLevel
,LogMessage
, andLogSink
toru.dgis.sdk.platform
. - Moved
HttpOptions
,Certificate
,CertificateFromAsset
,CertificateFromFile
,SystemCertificate
, andHttpProxyOptions
toru.dgis.sdk.platform
. - Removed
MyLocationController
andMapLocationController.myLocationIndicatorController
. To configure the marker geolocation source, use MyLocationControllerSettings. In the NavigationView, geolocation source is now not substituted. - Added the
GEO_POSITION
value to EventsProcessingSettings.rotationCenter and EventsProcessingSettings.scalingCenter to set the gesture operation mode relative to the geolocation. To set the position, relatively to which the gesture will be working, use the GestureManager.setTargetGeoPoint method. - Moved Meter from
ru.dgis.sdk.map
toru.dgis.sdk
. - Removed the
CameraState.FOLLOW_POSITION
value. Instead, see the Camera.behaviour value. - Extended values for SuggestedType, SuggestorType, and ObjectType so that they now correspond to Places API results.
- Removed the
createRasterTileDataSource
method. Added a new source of raster tiles RasterTileSource, which enables setting transparency for raster tiles.
Additionally for the full version:
- To ensure that immersive roads of actual width are displayed and other objects interact with them properly in the navigation mode, export latest Mobile SDK styles and apply your settings.
- Removed
AudioVolume
. You can now set instructions volume from 0 to 100 using AudioSettings.volume. - RouteMapObjectDisplayFlag.IMMERSIVE_ROUTE_PARTS - flag to use immersive geometry on route parts.
10.7.0 (2024-08-13)
🌟 Features and improvements
- CustomDashboardButton and DashboardButtonAbsent to configure the button for adding road events in the navigator dashboard.
10.6.0 (2024-08-07)
🌟 Features and improvements
- PackageInfo.finalSizeOnDisk - size of the disk space that the territory takes after installation, in bytes.
- PackageInfo.currentSizeOnDisk - size of the disk space that currently installed territory files take, in bytes.
🛠 Bug fixes
- Fixed the process of updating a position in the clustering tree using MapObjectManager.withClustering when a marker position changes.
- Updated the copyright design of a map snapshot created using the MapView.takeSnapshot method.
- In the NavigationView, the speedometer UI control is now displayed during bicycle navigation.
- In the NavigationView, the position tracking UI control is now not hidden during pedestrian navigation.
10.5.0 (2024-06-05)
🌟 Features and improvements
- You can now set a cascaded
appId
in the key settings. This allows you to link the key not to a particular application, but to a group of applications with the same identifier pattern. - Updated the copyright design.
- Added TiltSettings.maxParallelsDeviationDeg to configure a map tilt gesture.
🛠 Bug fixes
- Fixed the MapView.fpsChannel channel operation.
- When displaying markers using Marker, text labels do not overlap.
- Fixed the display of the geolocation marker when a direction sensor stops providing data.
10.4.0 (2024-05-20)
🌟 Features and improvements
- Added DGis.initialize with a parameter to redefine the audio driver for playing SDK sounds. Added the AudioDriver interface for setting a platform implementation of the audio driver.
- ZoomFollowSettings.speedRangeToStyleZoomFreeRoamSequence became a setter.
🛠 Bug fixes
- Fixed an issue that led to a situation when changing a floor via IndoorBuilding.activeLevelIndex did not influence the IndoorControl display.
- Fixed gesture handling when the map is working in the background.
- In NavigationView, the geolocation source is now changed to the source with a navigator controller only when the navigation starts.
❗ Breaking changes and backward compatibility
- You can now add only one source of the current location (MyLocationMapObjectSource) to a Map object.
10.3.0 (2024-05-06)
🌟 Features and improvements
- Information about traffic jams in regions is now updated regardless of the update of the SDK configuration file.
- With the zoom level higher than 2, you now cannot move the map to display empty lanes at the top and bottom.
- Added an Arabic voice package for the navigation.
🛠 Bug fixes
- Fixed clustering via MapObjectManager.withClustering. Now the cluster hierarchy is rebuilt if the position of one marker is changed using Marker.position.
- Fixed incorrect handling of taps in Marker with the Lottie animation.
- Map.dataLoadingStateChannel does not freeze in the
loading
state in the geolocation following mode. - Fixed an issue that caused rendering an empty
sources.jar
in a release package. - Fixed rendering of the dashboard in the NavigationView in the
FreeRoam
mode.
10.2.0 (2024-03-07)
🌟 Features and improvements
- CircleOptions.dashedStrokeOptions and Circle.dashedStrokeOptions options for creating a dashed circle or adding a dashed outline for an existing circle.
- RoadEventSource.setHighlighted method for highlighting road events with IDs from RoadEventMapObject.id.
- calculateClosestPoint function for obtaining the closes point on the map relative to the given point.
🛠 Bug fixes
- Fixes performance issues of
layedId
defined in MapObjectManager: now it impacts the display of clustered markers.
🗺 Map style updates
- Download styles again to ensure valid operation of dashed circles.
10.1.0 (2024-01-16)
🌟 Features and improvements
- Added the DirectoryObject.buildingInfo structure with reference information about a building:
buildingName
,purposeName
,purposeCode
, andbuildingLevels
. DirectoryObject.buildingLevels is marked asdeprecated
and will be removed in the future major releases. - Added DirectoryObject.address.fiasCode - the FIAS (Federal Information Address System) code of a directory object.
- Added the
fiasCode
field (the FIAS code of the street) to DirectoryObject.address.components in AddressComponent.streetAddress and AddressComponent.number structures.
10.0.0 (2023-12-29)
🌟 Features and improvements
- Started supporting Vulkan. If Vulkan is unavailable on the device, OpenGL version 3 is used. By default, OpenGL is enabled because Vulkan support is under development and is an experimental feature.
- Enabled immersive trees to be displayed on the map by default.
- Supported a new model for displaying the current location marker. To override the current location icon, pass MyLocationMapObjectMarkerType.SVG_ICON to the MyLocationMapObjectSource and edit a corresponding layer in styles.
- Added the BaseCamera.changePosition method for changing only certain parameters of camera position. The method takes a new CameraPositionChange structure.
- Added the Camera.move method for launching animated map movement with a possibility to reset tilt following.
- Added the
styleZoomToTiltRelation
parameter for calcPosition and zoomOutToFit functions. The parameter represents a function of camera tilt angle dependence on the style zoom level. - Added the createDefaultStyleZoomToTiltRelation function for getting the dependence of the camera tilt angle on the style zoom level for the standard tilt following controller.
- Added the BearingSource enum, a source of direction.
- Enabled overriding the network client in DGis.initialize using the HttpClient interface.
- Added MarkerOptions.iconAnimationMode and Marker.iconAnimationMode to enable setting animation modes in markers. The mode can be normal or looped.
- Added SearchResult.actionWidgets and SearchResult.mainWidgets for dynamic filtering of the obtained search results. Added the Widget class that works as a widget for filtering search results.
- Added
locales
andsystemLocales
methods and corresponding channels to LocaleManager for getting all locales of an application and system locales. - Added the createDefaultMaxTiltRestriction function for getting the default dependence of the tilt angle restriction on the scale. By default, this dependence is set during map creation: BaseCamera.maxTiltRestriction.
- Added the IndoorManager.setIndoorState method for managing the display of floor plans on the map.
- Added the LocationService interface for getting the latest value of the user geolocation in a convenient way.
- Added the new SearchLayout UI control that implements the search engine logic: search, suggestions, display of search results.
- Added the PackedMapState.cameraBehaviour field for serializing the camera tracking mode.
- Added the
error
field to PackageInfo: an error that occurs during an attempt to download and/or install a package. - Added the NavigationManager.alternativeRouteSelector field for selecting an alternative route.
- Added the Route.bicycleLanes field: an indication of a dedicated cycle lane.
- Added the RoutePointKind.BICYCLE_LANE value: the beginning and end of a cycle lane.
- Added the PedestrianRouteSearchOptions.avoidUnderpassesAndOverpasses flag: avoid pedestrian underpasses and overpasses.
- Added the RouteMapObjectSource.replaceObject for replacing one route object in source with another.
- Added the NavigationFollowController.mapLocationController field. MapLocationController is a controller to manage map positioning in the navigator.
- Added the NavigationFollowController.cameraBehaviour field to enable changing the mode of map following the geolocation marker.
- Added the ZoomFollowSettings.speedRangeToStyleZoomFreeRoamSequence field: a sequence of speed ranges and corresponding scales in the FreeRoam navigation mode.
❗ Breaking changes and backward compatibility
-
Changed working with FollowController:
- Removed
createRawMyLocationController
andcreateSmoothMyLocationController
methods. Added the MyLocationController constructor for creating controllers of geolocation marker movements. - Removed
FollowBearing.SATELLITE
andFollowBearing.MAGNETIC
values because now you do not need to specify the direction source. Added the FollowBearing.ON value for enabling the following mode (the source is selected automatically). - Removed the
FollowPosition.tilt
field. Now you need to enable tilt following separately. Added a newtilt
parameter to the CameraBehaviour constructor for tilt following. - Removed
FollowValue.SATELLITE_BEARING
,FollowValue.MAGNETIC_BEARING
, andFollowValue.ACCURACY
values. Instead, added the FollowValue.BEARING value with automatic selection of the source. - Removed
satelliteBearing
,magneticBearing
, andaccuracy
methods from the CustomFollowController interface. Added the CustomFollowController.bearing method instead. - Removed
setClock
,satelliteBearing
,magneticBearing
, andaccuracy
methods from FollowController. AddedonAddedToMap
,onRemovedFromMap
, andbearing
methods instead. - Removed the
FollowController.nextTimestampChannel
channel. Added FollowController.changedChannel instead. - Changed the signature of the FollowController.updateValues method.
- Removed the
PlatformLocationFollowController
controller. Instead, added BearingFollowController and CoordinatesFollowController controllers for following the map direction and map position coordinates respectively. - Changed the constructor of the StyleZoomFollowController controller. Removed the
StyleZoomFollowController.setAnimationDuration
method. - Changed the constructor of the TiltFollowController controller. Removed
TiltFollowController.setTilt
andTiltFollowController.setAnimationDuration
methods. - Replaced parameters of the FollowController.setThresholds with the typed ones.
- Removed the
FollowControllerClock
class. Changed the type of the FollowController.setClock method parameter to timestamp. - Removed
TransitionType
. The MyLocationControlModel constructor does not taketransitionType
now. Removed theCameraBehaviour.transitionType
field. Removed thetransitionType
parameter from the CameraBehaviour constructor. - Removed
MyLocationDirectionBehaviour
. The MyLocationMapObjectSource constructor of a geolocation source does not takedirectionBehaviour
now. Removed theMyLocationMapObjectSource.setDirectionBehaviour
method.
- Removed
-
Removed the
BaseCamera.styleZoomToTiltRelation
field. -
Renamed the
MagneticHeadingProvider
class toHeadingProvider
. -
Updated the LocaleManager.overrideLocales method to take a list of structures
Locale
with separatelanguage
andregion
fields. -
Removed PackageManager and Package from the SDK Map build. The product size has reduced.
-
Updated Voice.playWelcome to return Future, which becomes ready when sample playing is finished.
-
Removed the
RoadSubtype.STAIRWAY
field. Instead, added RoadSubtype.STAIRWAY_UP and RoadSubtype.STAIRWAY_DOWN fields for using stairways with explicit direction. -
Removed the
NavigationFollowController.mapTiltController
field. -
Enabled throwing an exception when attempting to start the navigator in the guidance or simulation mode with a public transport route.
-
Disabled cashing of
FreeRoam
tiles during navigation. -
Updated MyLocationMapObjectSource for the navigator to be installed inside NavigationView.
-
Removed
lightTheme
anddarkTheme
fields from MapOptions. To set the theme, use the MapTheme class in MapOptions.setTheme and MapView.setTheme methods.
❗ Known Issues
- When dynamic objects are updated frequently (around 100 FPS), the map freezes.
🛠 Bug fixes
-
Optimized re-rending of map frames after any changes.
-
Fixed the way traffic jams are displayed on the map depending on the zoom level.
-
Improved the smoothness of geolocation marker update.
-
Fixed the behavior of the SimpleClusterObject.setIcon method during the first call.
-
Improved creating of map snapshots using the MapView.takeShapshot method: now the state of map loading (
loaded
value of Map.dataLoadingState) is considered. -
Fixed clustering via MapObjectManager.withClustering that worked incorrectly with fractional values of
minZoom
andmaxZoom
. -
Updated the company logo in the copyright and map snapshots.
-
Fixed the exception returned if corrupted styles are loaded into the map.
-
Fixed the display of UI elements from DefaultNavigationControls in the Arabic locale.
-
Improved the calculation of the distance for playing preliminary instructions for a maneuver: now lanes are considered.
-
Improved the playing of the final phrase in the navigation mode: now pedestrian route is considered.
-
Fixed an issue that prevented lane callouts from displaying the route direction.
-
Fixed the creation of lane callouts: now speed limits are not considered.
-
Fixed the display of callouts for bus lanes going straight with "No entry" sign for other vehicles.
-
Fixed the display of route suggestions:
- Suggested better route is now not removed if a user explicitly declined switching to it.
- Alternative routes are now removed from the map when the interchange with them is too far from the following position even if they can still be attracted.
- Alternative routes that branch from the main route in the same point and are equally directed are now disregarded.
- Suggestion of a better route is now revoked when the route is not considered a better one anymore after updating the traffic jam data for the route.
-
Fixed camera warnings: now notifications of camera dummies are not voiced.
-
Fixed the NavigationView behavior to display only the remaining part of the route when requested to display the full route.
-
Disabled cashing of
FreeRoam
tiles during navigation by default. This is done to reduce the number of backend requests.
🗺 Map style updates
- Added styles for traffic lights.
- Added immersive models of trees and buildings.
- Added support of new lines of Moscow Metro: MCD-3 and MCD-4.
- Optimized immersive models of trees.
- Added a new model for displaying the current location marker.
Migration from versions 7.x to 10.х
For all types of Mobile SDK:
-
Styles must be downloaded again.
-
Changed the process of working with FollowController:
- Removed
createRawMyLocationController
andcreateSmoothMyLocationController
methods. Added the MyLocationController constructor for creating controllers of geolocation marker movements. - Removed
FollowBearing.SATELLITE
andFollowBearing.MAGNETIC
values because now you do not need to specify the direction source. Added the FollowBearing.ON value for enabling the following mode (the source is selected automatically). - Removed the
FollowPosition.tilt
field. Now you need to enable tilt following separately. Added a newtilt
parameter to the CameraBehaviour constructor for tilt following. - Removed
FollowValue.SATELLITE_BEARING
,FollowValue.MAGNETIC_BEARING
, andFollowValue.ACCURACY
values. Instead, added the FollowValue.BEARING value with automatic selection of the source. - Removed
satelliteBearing
,magneticBearing
, andaccuracy
methods from the CustomFollowController interface. Added the CustomFollowController.bearing method instead. - Removed
setClock
,satelliteBearing
,magneticBearing
, andaccuracy
methods from FollowController. AddedonAddedToMap
,onRemovedFromMap
, andbearing
methods instead. - Removed the
FollowController.nextTimestampChannel
channel. Added FollowController.changedChannel instead. - Changed the signature of the FollowController.updateValues method.
- Removed the
PlatformLocationFollowController
controller. Instead, added BearingFollowController and CoordinatesFollowController controllers for following the map direction and map position coordinates respectively. - Changed the constructor of the StyleZoomFollowController controller. Removed the
StyleZoomFollowController.setAnimationDuration
method. - Changed the constructor of the TiltFollowController controller. Removed
TiltFollowController.setTilt
andTiltFollowController.setAnimationDuration
methods. - Replaced parameters of the FollowController.setThresholds with the typed ones.
- Removed the
FollowControllerClock
class. Changed the type of the FollowController.setClock method parameter to timestamp. - Removed
TransitionType
. The MyLocationControlModel constructor does not taketransitionType
now. Removed theCameraBehaviour.transitionType
field. Removed thetransitionType
parameter from the CameraBehaviour constructor. - Removed
MyLocationDirectionBehaviour
. The MyLocationMapObjectSource constructor of a geolocation source does not takedirectionBehaviour
now. Removed theMyLocationMapObjectSource.setDirectionBehaviour
method.
- Removed
-
Removed the
BaseCamera.styleZoomToTiltRelation
field. -
Renamed the
MagneticHeadingProvider
class toHeadingProvider
. -
Updated the LocaleManager.overrideLocales method to take a list of structures
Locale
with separatelanguage
andregion
fields. -
Removed PackageManager and Package from the SDK Map build. The product size has reduced.
-
Removed
lightTheme
anddarkTheme
fields from MapOptions. To set the theme, use the MapTheme class in MapOptions.setTheme and MapView.setTheme methods.
Additionally for the full version:
- Updated Voice.playWelcome to return Future, which becomes ready when sample playing is finished.
- Removed the
RoadSubtype.STAIRWAY
field. Instead, added RoadSubtype.STAIRWAY_UP and RoadSubtype.STAIRWAY_DOWN fields for using stairways with explicit direction. - Removed the
NavigationFollowController.mapTiltController
field. - Enabled throwing an exception when attempting to start the navigator in the guidance or simulation mode with a public transport route.
- Disabled cashing of
FreeRoam
tiles during navigation. - Updated MyLocationMapObjectSource for the navigator to be installed inside NavigationView.