Geometry Module

The Geometry Module in the TomTom Maps SDK enables displaying and visualizing geographic shapes and polygons on maps. This module provides comprehensive functionality for rendering complex geometries, administrative boundaries, and custom geographic data with customizable styling.

import type { BBox, Places } from '@tomtom-org/maps-sdk/core';
import { TomTomConfig } from '@tomtom-org/maps-sdk/core';
import {
    calculateFittingBBox,
    GeometriesModule,
    type GeometryBeforeLayerConfig,
    type StandardStyleID,
    standardStyleIDs,
    TomTomMap,
} from '@tomtom-org/maps-sdk/map';
import { geocode, geometryData } from '@tomtom-org/maps-sdk/services';
import type { LngLatBoundsLike } from 'maplibre-gl';
import type { Config } from './placeConfiguration';
import { namedConfigs } from './placeConfiguration';
import './style.css';
import { API_KEY } from './config';

// (Set your own API key when working in your own environment)
TomTomConfig.instance.put({ apiKey: API_KEY, language: 'en-GB' });

(async () => {
    const map = new TomTomMap({
        mapLibre: {
            container: 'sdk-map',
        },
    });
    const geometryModule = await GeometriesModule.get(map);
    let placeSubdivisions: Places;

    const placeBBox = () =>
        calculateFittingBBox({
            map,
            toBeContainedBBox: placeSubdivisions.bbox as BBox,
            surroundingElements: ['#sdk-example-panel'],
        }) as LngLatBoundsLike;

    const updateMap = async (config: Config) => {
        placeSubdivisions = await geocode({ limit: 100, query: '', ...config.searchConfig });
        map.mapLibreMap.fitBounds(placeBBox());
        const geometries = await geometryData({ geometries: placeSubdivisions, zoom: 14 });
        geometryModule.applyConfig(config.geometryConfig);
        geometryModule.show(geometries);
    };

    const listenToUIEvents = async () => {
        const placeSelector = document.getElementById('sdk-example-place-selector') as HTMLSelectElement;
        placeSelector.addEventListener('change', (event) =>
            updateMap(namedConfigs[(event.target as HTMLInputElement).value]),
        );

        const options = document.querySelectorAll<HTMLInputElement>('input[type=radio][name=layerOption]');
        options.forEach((option) => {
            option.addEventListener('change', () =>
                geometryModule.moveBeforeLayer(option.value as GeometryBeforeLayerConfig),
            );
        });

        const stylesSelector = document.querySelector('#sdk-example-mapStyles') as HTMLSelectElement;
        standardStyleIDs.forEach((id) => stylesSelector.add(new Option(id)));
        stylesSelector.addEventListener('change', (event) =>
            map.setStyle((event.target as HTMLOptionElement).value as StandardStyleID),
        );

        document
            .querySelector('#sdk-example-reCenter')
            ?.addEventListener('click', () => placeSubdivisions && map.mapLibreMap.fitBounds(placeBBox()));
    };

    await updateMap(namedConfigs.france);
    await listenToUIEvents();
})();

Purpose and Functionality

The Geometry Module serves as the primary interface for:

  • Displaying polygon geometries from TomTom services and custom data
  • Visualizing administrative boundaries such as countries, states, and cities
  • Rendering custom geographic shapes with configurable styling options
  • Managing geometry layers with visibility controls and interaction handling
  • Integrating geometry data from search results and external sources

Core Concepts

Geometry Data Types

The module supports various types of geographic geometries:

Supported Geometry Types:

  • Polygons: Closed shapes representing areas like administrative boundaries
  • MultiPolygons: Complex shapes with multiple disconnected areas
  • Administrative boundaries: Country, state, city, and district boundaries
  • Custom shapes: User-defined geographic areas and regions

Data Sources

Geometries can come from multiple sources:

  • TomTom Geometry Data Service: Official administrative boundaries and places
  • Search results: Geographic data from place searches
  • Custom GeoJSON: User-provided geometric data
  • External APIs: Third-party geographic data sources

Basic Geometry Display

Initializing Geometry Module

import { TomTomConfig } from '@tomtom-org/maps-sdk/core';
import { TomTomMap, GeometriesModule } from '@tomtom-org/maps-sdk/map';
// Configure SDK and create map
TomTomConfig.instance.put({ apiKey: 'YOUR_API_KEY' });
const map = new TomTomMap({ mapLibre: { container: 'map' } });
// Initialize geometry module with default styling
const geometryModule = await GeometriesModule.get(map);

Displaying Administrative Boundaries

import { geocode, geometryData } from '@tomtom-org/maps-sdk/services';
// Get geometry for a specific place
const place = (await geocode({ query: 'Amsterdam, Netherlands' })).features[0];
const geometryResponse = await geometryData({ geometries: [place] });
// Display the geometry on the map
geometryModule.show(geometryResponse);

Custom Styling Configuration

// Initialize with custom styling
const geometryModule = await GeometriesModule.get(map, {
colorConfig: {
fillColor: '#007cbf', // Fill color for polygons
fillOpacity: 0.3 // Fill transparency
},
lineConfig: {
lineColor: '#005a8b', // Border color
lineWidth: 2, // Border width
lineOpacity: 0.8 // Border transparency
},
beforeLayerConfig: 'road-labels' // Layer positioning
});

Advanced Geometry Features

Multiple Geometry Layers

// Create multiple geometry modules for different data sets
const countryGeometryModule = await GeometriesModule.get(map, {
colorConfig: { fillColor: '#ff6b6b', fillOpacity: 0.2 },
lineConfig: { lineColor: '#ff0000', lineWidth: 3 }
});
const cityGeometryModule = await GeometriesModule.get(map, {
colorConfig: { fillColor: '#4ecdc4', fillOpacity: 0.4 },
lineConfig: { lineColor: '#00a896', lineWidth: 2 }
});
// Display different geometry types
countryGeometryModule.show(countryBoundaries);
cityGeometryModule.show(cityBoundaries);

Dynamic Geometry Management

// Add and remove geometries dynamically
const geometryModule = await GeometriesModule.get(map);
// Show new geometry data
function displayGeometry(newGeometryData) {
geometryModule.clear(); // Clear existing geometries
geometryModule.show(newGeometryData);
}
// Toggle geometry visibility
let geometryVisible = true;
function toggleGeometry() {
if (geometryVisible) {
geometryModule.clear();
} else {
geometryModule.show(currentGeometryData);
}
geometryVisible = !geometryVisible;
}

Layer Positioning and Styling

// Advanced styling with layer control
const geometryModule = await GeometriesModule.get(map, {
beforeLayerConfig: 'road-labels', // Position below road labels
colorConfig: {
fillColor: '#87CEEB',
fillOpacity: 0.5
},
lineConfig: {
lineColor: '#4682B4',
lineWidth: 1.5,
lineOpacity: 1
}
});

Multiple Module Instances

You can create multiple independent instances of the Geometry module, each with its own configuration and styling. This is useful for displaying different geometry layers with distinct visual styles.

// Create separate instances for different geometry types
const countryBorders = await GeometriesModule.get(map, {
colorConfig: { fillColor: '#E74C3C', fillOpacity: 0.2 },
lineConfig: { lineColor: '#C0392B', lineWidth: 3 }
});
const cityBounds = await GeometriesModule.get(map, {
colorConfig: { fillColor: '#3498DB', fillOpacity: 0.3 },
lineConfig: { lineColor: '#2980B9', lineWidth: 2 }
});
// Each instance manages its own geometries independently
countryBorders.show(countryData);
cityBounds.show(cityData);

Services Integration