Map (v2.1.x - Android)
Map view
Creating the Map View
In order to add the map view to your activity, insert the following code into the layout file:
<com.navmii.sdk.map.MapView
android:id="@+id/map_view"
android:layout_width="match_parent"
android:layout_height="match_parent" />
Then start the SDK with the Sdk.initSdkAsync
static method and after successful initialization pass the map view to it using the setActiveMapView
method. After MapView
is no longer active you must call setActiveMapView(null)
.
@Override
public void onStart() {
super.onStart();
MapView mapView = (MapView) findViewById(R.id.map_view);
if (Sdk.getInstance().getState() == Sdk.State.INITIALIZED) {
Sdk.getInstance().setActiveMapView(mapView);
}
}
@Override
public void onStop() {
super.onStop();
if (Sdk.getInstance().getState() == Sdk.State.INITIALIZED) {
Sdk.getInstance().setActiveMapView(null);
}
}
GPS Coordinates – Screen Position Transformation
You can transform Point
representing a screen position of a point on the map to MapCoordinates
object representing corresponding GPS location using MapView.getProjection
method, which returns an instance of the MapProjection
class, and the following code:
MapCoordinates coordinates = mapView.getProjection().mapCoordinatesFromScreenPosition(point);
The reverse operation can be performed by MapProjection.screenPositionFromMapCoordinates
:
For example, to retrieve current GPS position relative to the screen, you can use the following code:
Note: south hemisphere latitudes are represented by negative values.
Working with Camera
Typically, you want to adjust the area presented on the map on your app's events. You can do it by using MapView.getCameraController
method, which returns an instance of the CameraController
class, that can be used to move camera to a desired position. The camera position itself is represented in Navmii SDK as CameraPosition
. CameraPosition
and CameraController
allow you to perform the following operations:
Setting map rotation via
setHeading
methodSetting map center via
setTargetLocation
methodSetting map zoom via
setZoom
methodSetting map tilt via
setTilt
method
The CameraPosition
is instantiated with a builder:
To move the camera to a position without animation use the CameraController.moveCamera
method:
Alternatively, you can set the desired camera position with animation, using one of the three overloaded animateCamera
methods. The first one only takes the position. The second one allows you to provide a listener implementing the CameraAnimationListener
interface, which will be notified when the animation ends. The last method additionally takes the duration
parameter, allowing you to specify the duration of the animation. The default duration is 0.3 seconds.
To stop current animation use the MapView.stopAnimation
method:
Handling Camera Events
The SDK can inform you about camera movements, if you have a class implementing the CameraMovementListener
interface and have added an instance of this class to CameraController
object's listeners.
There can be three possible reasons for camera movement, defined in the CameraMovementReason
enum:
gesture;
internal animation performed by the SDK (for example, during auto zoom);
animation requested by user (see Working with Camera for details).
You also can add multiple listeners to a CameraController
instance. To detach a listener use the removeCameraMovementListener
method.
Map gestures
Gestures with Predefined Behaviour
After being created and added to the view hierarchy, MapView
is ready to receive the user's touch events. The map reacts to the following gestures as described with no extra code needed.
Pan gesture. To drag the map, touch the screen with one finger and hold. Move the finger in the desired direction.
Swipe gesture. To move the map with inertia, swipe the screen with one finger. The map will proceed to move in the same direction for a period of time depending on the velocity of the gesture.
Pinch gesture. Touch the screen with two fingers and hold. Increase and decrease the distance between them to zoom in and zoom out respectively. Depending on the velocity of the gesture the map can have zoom inertia.
Rotation gesture. Touch the screen with two fingers and hold. Rotate the fingers relative to the screen. This gesture also has inertia behaviour.
Tilt gesture. Touch the screen with two fingers and move them simultaneously up or down to change the camera tilt.
If you want to handle these gestures in your code please refer to Handling Camera Events section.
Gestures without Predefined Behaviour
MapView
recognizes the following gestures without a predefined behaviour.
Single Tap Gesture. Tap the map with one finger once.
Double Tap Gesture. Tap the map with one finger twice.
Long Press Gesture. Touch the screen with one finger and hold for a period of time.
To process these gesture events make one your classes implement the MapTapListener
interface and add it to MapView
map tap listeners using the following code:
You can add multiple map tap listeners to a MapView
instance.
This way your object or objects will be notified on these gesture events via the following methods:
Geo Items
Navmii SDK provides an easy way to present custom images on the map and to draw polylines. Children classes of GeoObject
abstract class represent these custom images (GeoMarker
) and polylines (GeoPolyline
) in the SDK. MapView
instance is responsible for creating and handling this type of objects.
Creating Markers on the Map
To present a marker on the map at some coordinates, instantiate an object of GeoMarker
class specifying the coordinates as an object of MapCoordinates
class, image as a file (java.io.File
) or drawable(android.graphics.drawable.Drawable
) and anchor point as android.graphics.PointF
. Anchor point represents a point in relative coordinates of the image. The marker will be located on the map so that the anchor point of its image matches the coordinates specified. Once instantiated, pass the object to the MapView.addGeoObject
method:
Creating Images on the Map
To add an image to the map at the specified coordinates, instantiate an object of GeoImage class specifying the path to the image and an array of coordinates, one for each corner of the image in the following order: leftTop, leftBottom, rightTop, rightBottom. The image resolution must be power of 2 for mipmap generation. Once instantiated, pass the object to the MapView.addGeoObject
method.
Drawing Polylines
To draw a polyline on the map, instantiate an object of GeoPolyline
class specifying a list of MapCoordinates
representing polyline vertices. Once instantiated, pass the object to the MapView.addGeoObject
method.
Working with Polylines
You can insert and remove a point or multiple points into and from a polyline, using GeoPolyline
's addVertex
, removeVertex
, removeLastVertex
and removeAllVertices
methods. To retrieve overall vertices count use the getVertexCount
method. To get a copy of all vertices, use the getVertices
method.
The way the polyline is rendered on the map is also customizable. You can change the polyline's color and width using GeoPolyline
's setColor
and setWidth
methods. The width property is a float
value representing polyline's width in density-independent pixels (dp units).
Drawing Polygons on the Map
To draw a polygon on the map, instantiate an object of GeoPolygon
class specifying a list of MapCoordinates
representing polygon vertices. Once instantiated, pass the object to the MapView.addGeoObject
method.
In addition to methods for vertex manipulation, which are identical to those for polylines, there are also methods that allow changing the fill color, stroke color, and stroke width:
Drawing Circles on the Map
To draw a circle on the map, instantiate an object of GeoCircle
class with the following parameters:
- Center of the circle (MapCoordinates
)
- Radius in meters
- Circle fill color
- Stroke color and stroke width in pixels.
Then add it to the map:
Interacting with Geo Objects
Editing geo objects
Circles and polygons can be made editable using setEditable(boolean)
method. An editable object will be displayed with handles, which can be dragged in order to edit the object:
Listening to geo object events
There are four types of user events related to GeoObject
recognized by the SDK:
single tap on a geo object
double tap on a geo object
long press on a geo object
modifying an editable geo object by dragging the handles displayed on it by the SDK
The first three events will only be called for clickable geo objects (markers, circles and polygons, for which setClickable(true)
method has been called).
The last event will only be called for editable geo objects (circles and polygon, for which setEditable(true)
method has been called). This event is called once when a user stops interacting with the object.
To be able to handle these events make one of your classes implement the GeoObjectListener
interface and add an instance of this class to the map view's geo object listeners. Methods onGeoObjectClick
, onGeoObjectPress
, onGeoObjectRelease
, onGeoObjectLongPress
and onGeoObjectChanged
will be called on these events:
Offline maps
Please check out the How to get offline maps article to find out how to obtain offline maps.
On how to make the SDK working with offline maps please refer to SDK setup (v2.1.x - Android) | SDKConfigurationSettings.