• Optimization
  • Navigation
  • Tracking
  • Maps
  • Places

Query Features in box

This example shows how to Query features in the box on MapView

  • Query features about existing layer id and filter

  • Query features about custom layer id

Query Features in box

For all code examples, refer to Android Maps SDK Code Examples

activity_query_feature_and_symbol.xml view source

1<?xml version="1.0" encoding="utf-8"?>
2<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
3 xmlns:app="http://schemas.android.com/apk/res-auto"
4 android:layout_width="match_parent"
5 android:layout_height="match_parent">
6
7 <ai.nextbillion.maps.core.MapView
8 android:id="@+id/mapView"
9 android:layout_width="match_parent"
10 android:layout_height="match_parent"
11 app:nbmap_cameraTargetLat="52.0907"
12 app:nbmap_cameraTargetLng="5.1214"
13 app:nbmap_cameraZoom="16" />
14
15 <FrameLayout
16 android:id="@+id/selection_box"
17 android:layout_width="150dp"
18 android:layout_height="150dp"

QueryFeatureAndSymbolActivity view source

1package ai.nextbillion;
2
3import android.graphics.Bitmap;
4import android.graphics.BitmapFactory;
5import android.graphics.Color;
6import android.graphics.RectF;
7import android.os.Bundle;
8import android.view.View;
9import android.widget.Toast;
10
11import java.io.IOException;
12import java.util.List;
13
14import ai.nextbillion.kits.geojson.Feature;
15import ai.nextbillion.kits.geojson.FeatureCollection;
16import ai.nextbillion.maps.camera.CameraPosition;
17import ai.nextbillion.maps.camera.CameraUpdateFactory;
18import ai.nextbillion.maps.core.MapView;

The given code is an Android activity that demonstrates how to initialize a MapView, query features on a map, and display the results.

Initializing the MapView:

  • The onCreate method initializes the MapView by setting the content view and obtaining a reference to it using findViewById.

  • The onCreate method also calls mapView.onCreate(savedInstanceState) to create the MapView and mapView.getMapAsync(this) to get a reference to the NextbillionMap instance when it is ready.

Querying Features of an Existing Layer:

  • The code sets up a map and adds a layer called "highlighted-shapes-layer" with a source named "highlighted-shapes-source".

  • The selectionBox view is used to define a rectangular area on the map.

  • When the selectionBox is clicked, the queryRenderedFeatures method is called to query the features within the defined area.

  • The queried features are filtered based on a condition (in this case, the height is less than 10) using an Expression.

  • The queried features are displayed in a toast message.

Querying Features of a Custom Layer:

  • The code adds a custom symbol layer to the map, which is based on a GeoJSON source named "symbols-source".

  • The addSymbolLayer method reads GeoJSON data from a resource file and adds it as a source and layer to the map style.

  • The queryRenderedFeatures method is used to query the features within the defined area for the "symbols-layer" specifically.

  • The queried features are displayed in a toast message.

Other Lifecycle Methods: The code also includes various lifecycle methods (onStart, onResume, onPause, onStop, onSaveInstanceState, onDestroy, onLowMemory) that should be implemented when using the MapView to properly manage its lifecycle and handle configuration changes.

Note: The code uses the Nextbillion Maps SDK and NextbillionMap class to handle map-related operations. It also utilizes the Style class to define the map's visual style, GeoJsonSource class to add data sources, and various layer classes to display map features.

Have Questions ?