Search results

Markers in Angular Maps component

21 Oct 2021 / 13 minutes to read

Markers are notes that are used to leave a message on the Maps. It indicates or marks a specific location with desired symbols on the Maps. It can be enabled by setting the visible property of the markerSettings to true.

Adding marker

To add the markers, the dataSource property of the markerSettings has a list of objects that contains the data for markers. Using this property, any number of markers can be added to the layers of the Maps. By default, it displays the markers based on the specified latitude and longitude in the given data source. Each data source object contains the following list of properties.

  • latitude - The latitude point which determines the X location of the marker.
  • longitude - The longitude point which determines the Y location of the marker.
Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'  >
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [{
        visible: true,
        height: 20,
        width: 20,
        dataSource: [
            { latitude: 49.95121990866204, longitude: 18.468749999999998 },
            { latitude: 59.88893689676585, longitude: -109.3359375 },
            { latitude: -6.64607562172573, longitude: -55.54687499999999 }
        ],
        animationDuration: 0,
    }]
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Adding marker template

The Marker can be added as a template in the Maps component. The template property of the markerSettings is used to set the HTML string or id of an element as a template.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'  >
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [
        {
            visible: true,
            template: '<div id="marker4" class="markerTemplate">Europe' +
                    '</div>',
            dataSource: [
                { latitude: 49.95121990866204, longitude: 18.468749999999998 }
            ],
            animationDuration: 0,
        },
        {
            visible: true,
            template: '<div id="marker5" class="markerTemplate" style="width:50px">North America' +
                    '</div>',
            dataSource: [
                { latitude: 59.88893689676585, longitude: -109.3359375 }
            ],
            animationDuration: 0
        },
        {
            visible: true,
            template: '<div id="marker6" class="markerTemplate" style="width:50px">South America' +
                    '</div>',
            dataSource: [
                { latitude: -6.64607562172573, longitude: -55.54687499999999 }
            ],
            animationDuration: 0
        }
    ]
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Customization

The following properties are available in markerSettings to customize the Markers of the Maps component.

  • border - To customize the color, width and opacity of the border for the markers in Maps.
  • fill - To apply the color for markers in Maps.
  • dashArray - To define the pattern of dashes and gaps that is applied to the outline of the markers in Maps.
  • height - To customize the height of the markers in Maps.
  • width - To customize the width of the markers in Maps.
  • offset - To customize the position of the markers in Maps.
  • opacity - To customize the transparency of the markers in Maps.
  • animationDelay - To change the time delay in the transition for markers.
  • animationDuration - To change the time duration of animation for markers.
Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'  >
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [{
        visible: true,
        border: {
            color: 'green',
            width: 2
        },
        fill: 'red',
        dashArray: '1',
        height: 20,
        width: 20,
        opacity: 0.9,
        animationDelay: 100,
        animationDuration: 1000,
        shape: 'Balloon',
        dataSource: [
            { latitude: 37.0000, longitude: -120.0000, city: 'California' },
            { latitude: 40.7127, longitude: -74.0059, city: 'New York' },
            { latitude: 42, longitude: -93, city: 'Iowa' }
        ]
    }]
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Marker shapes

The Maps component supports the following marker shapes. To set the shape of the marker, the shape property in markerSettings is used.

  • Balloon
  • Circle
  • Cross
  • Diamond
  • Image
  • Rectangle
  • Start
  • Triangle
  • VerticalLine
  • HorizontalLine

Rendering marker shape as image

To render a marker as an image in Maps, set the shape property of markerSettings as Image and specify the path of the image to imageUrl property. There is another way to render a marker as an image using the imageUrlValuePath property of the markerSettings. Bind the field name that contains the path of the image in the data source to the imageUrlValuePath property.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'>
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [{
        visible: true,
        shape: 'Image',
        imageUrl: 'maps/default-map/datetime/ballon.png',
        height: 10,
        width: 10,
        dataSource: [
            { latitude: 37.0000, longitude: -120.0000, city: 'California' },
            { latitude: 40.7127, longitude: -74.0059, city: 'New York' },
            { latitude: 42, longitude: -93, city: 'Iowa' }
        ]
    }]
}
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Multiple marker groups

Multiple groups of markers can be added to the Maps using the markerSettings in which the properties of markers are added as an array. The customization for the markers can be done with the markerSettings.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'  >
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [{
        visible: true,
        shape: 'Diamond',
        height: 15,
        fill: "green",
        width: 15,
        dataSource: [
            {
                latitude: 37.0000, longitude: -120.0000, name:'California',
            },
            {
                latitude: 40.7127, longitude: -74.0059, name:"New York"
            },
            {
                latitude: 42, longitude: -93, name:'Iowa'
            }
        ]
    },
    {
        visible: true,
        dataSource: [{
            latitude: 19.228825, longitude: 72.854118, name: "Mumbai"
        }, {
            latitude: 28.610001, longitude: 77.230003, name: "Delhi"
        }, {
            latitude: 13.067439, longitude: 80.237617, name: "Chennai"
        }],
        shape: 'Circle',
        fill: "blue",
        height: 10,
        width: 10
    }]
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Customize marker shapes from data source

Bind different colors and shapes to the marker from data source

Using the shapeValuePath and colorValuePath properties, the color and shape of the marker can be applied from the given data source. Bind the data source to the dataSource property of the markerSettings and set the field names that contains the shape and color values in the data source to the shapeValuePath and colorValuePath properties.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container' >
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [{
        visible: true,
        shapeValuePath:'shape',
        colorValuePath:'color',
        dataSource: [
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe', color:'red', shape:'Triangle' },
            { latitude: 59.88893689676585, longitude: -109.3359375, name:'North America',
            color:'blue', shape:'Pentagon' },
            { latitude: -6.64607562172573, longitude: -55.54687499999999, name:'South America',
            color:'green', shape:'InvertedTriangle' }
        ]
    }];
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Setting value path from the data source

The latitude and longitude values are used to determine the location of each marker in the Maps. The latitudeValuePath and longitudeValuePath properties are used to specify the value path that presents in the data source of the marker. In the following example, the field name from the data source is set to the latitudeValuePath and longitudeValuePath properties.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'  >
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [{
        visible: true,
        latitudeValuePath: 'latitude',
        longitudeValuePath: 'longitude',
        dataSource: [
            { latitude: 49.95121990866204, longitude: 18.468749999999998 },
            { latitude: 59.88893689676585, longitude: -109.3359375},
            { latitude: -6.64607562172573, longitude: -55.54687499999999 }
        ]
    }]
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Marker zooming

The Maps can be initially scaled to the center value based on the marker distance. This can be achieved by setting the shouldZoomInitially property in zoomSettings as true.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker, Zoom } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker, Zoom);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'  [zoomSettings] ='zoomSettings'>
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
public zoomSettings: object
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [
    {
        visible: true,
        dataSource: [
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 59.88893689676585, longitude: -109.3359375, name:'North America' },
            { latitude: -6.64607562172573, longitude: -55.54687499999999, name:'South America'}
        ],
    },
    ];
    this.zoomSettings = {
        enable: true,
        horizontalAlignment:'Near',
        shouldZoomInitially: true
}
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Marker clustering

Maps provide support to cluster the markers when they overlap each other. The number on a cluster indicates how many overlapped markers it contains. If zooming is performed on any of the cluster locations in Maps, the number on the cluster will decrease, and the individual markers will be seen on the map. When zooming out, the overlapping marker will increase. So that it can cluster again and increase the count over the cluster.

To enable clustering in markers, set the allowClustering property of markerClusterSettings as true and customization of clustering can be done with the markerClusterSettings.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, ViewEncapsulation, ViewChild, OnInit  } from '@angular/core';
import { Maps, Marker, MapsTooltip, Zoom } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
import { cluster } from 'marker-location.ts';
Maps.Inject(Marker, MapsTooltip, Zoom);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container' [zoomSettings] = 'zoomSettings' [layers] = 'layers'>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public zoomSettings: object;
public layers: object;
ngOnInit(): void {
    this.zoomSettings = {
        enable: true
    };
    this.layers = [{
        shapeData: world_map,
        shapeSettings: { fill: '#C1DFF5' },
        markerClusterSettings: {
            allowClustering: true,
            shape: 'Circle',
            height: 40,
            width: 40,
            labelStyle: { color: 'white' },
        },
        markerSettings: [{
            dataSource: cluster,
            visible: true,
            animationDuration: 0,
            shape: 'Balloon',
            height: 20,
            width: 20,
            tooltipSettings: {
                visible: true,
                valuePath: 'area',
            }
        }]
    }];
}
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Customization of marker cluster

The following properties are available to customize the marker clustering in the Maps component.

  • border - To customize the color, width and opacity of the border of cluster in Maps.
  • connectorLineSettings - To customize the connector line in cluster separating the markers.
  • dashArray - To customize the dash array for the marker cluster in Maps.
  • fill - Applies the color of the cluster in Maps.
  • height - To customize the height of the marker cluster in Maps.
  • imageUrl - To customize the URL path for the marker cluster when the cluster shape is set as image in Maps.
  • labelStyle - To customize the text in marker cluster.
  • offset - To customize the offset position for the marker cluster in Maps.
  • opacity - To customize the opacity of the marker cluster.
  • shape - To customize the shape for the cluster of markers.
  • width - To customize the width of the marker cluster in Maps.
Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, ViewEncapsulation, ViewChild, OnInit  } from '@angular/core';
import { Maps, Marker, MapsTooltip, Zoom, Point} from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
import { cluster } from 'marker-location.ts';
Maps.Inject(Marker, MapsTooltip, Zoom);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container' [zoomSettings] = 'zoomSettings' [layers] = 'layers'>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public zoomSettings: object;
public layers: object;
ngOnInit(): void {
    this.zoomSettings = {
        enable: true
    };
    this.layers = [{
        shapeData: world_map,
        shapeSettings: { fill: '#C1DFF5' },
        markerClusterSettings: {
            allowClustering: true,
            allowClusterExpand: true,
            shape: 'Circle',
            height: 40,
            width: 40,
            labelStyle : { color: 'white'},
            offset: new Point(10, 20),
            opacity: 0.9,
            fill: 'green',
            connectorLineSettings: {
                color: 'orange',
                opacity: 0.8,
                width: 2
            }
        },
        markerSettings: [{
            dataSource: cluster,
            visible: true,
            animationDuration: 0,
            shape: 'Balloon',
            height: 20,
            width: 20,
            tooltipSettings: {
                visible: true,
                valuePath: 'area',
            }
        }]
    }];
}
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Expanding the marker cluster

The cluster is formed by grouping an identical and non-identical marker from the surrounding area. By clicking on the cluster and setting the allowClusterExpand property in markerClusterSettings as true to expand the identical markers. If zooming is performed in any of the locations of the cluster, the number on the cluster will decrease and the overlapping marker will be split into an individual marker on the map. When performing zoom out, it will increase the marker count and then cluster it again.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker, Legend, Zoom } from '@syncfusion/ej2-angular-maps';
import { world_map } from 'world-map.ts';
Maps.Inject(Marker, Legend, Zoom);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'  [zoomSettings] ='zoomSettings'  >
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings' [markerClusterSettings] = 'markerClusterSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
public zoomSettings: object;
public markerClusterSettings: object;
ngOnInit(): void {
    this.shapeData = world_map;
    this.markerSettings = [{
        visible: true,
        dataSource: [
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 49.95121990866204, longitude: 18.468749999999998, name:'Europe' },
            { latitude: 59.88893689676585, longitude: -109.3359375, name:'North America' },
            { latitude: -6.64607562172573, longitude: -55.54687499999999, name:'South America'}
        ]
    }];
    this.zoomSettings = {
        enable: true,
        mouseWheelZoom : true,
    },
    this.markerClusterSettings = {
        allowClustering: true,
        allowClusterExpand: true,
        shape: 'Circle',
        height: 40,
        width: 40,
        labelStyle : { color: 'white'},
    }
}
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);

Tooltip for marker

Tooltip is used to display more information about a marker on mouse over or touch end event. This can be enabled separately for marker by setting the visible property of tooltipSettings to true. The valuePath property in the tooltipSettings takes the field name that presents in data source and displays that value as tooltip text.

Source
Preview
app.component.ts
app.module.ts
main.ts
Copied to clipboard
import { Component, OnInit } from '@angular/core';
import { Maps, Marker } from '@syncfusion/ej2-angular-maps';
import { usa_map } from 'usa.ts';
Maps.Inject(Marker);
@Component({
selector: 'app-container',
template:
`<ejs-maps id='rn-container'>
<e-layers>
<e-layer  [shapeData]= 'shapeData' [markerSettings] = 'markerSettings'></e-layer>
</e-layers>
</ejs-maps>`
})

export class AppComponent implements OnInit {
public shapeData: object;
public markerSettings: object;
ngOnInit(): void {
    this.shapeData = usa_map;
    this.markerSettings = [{
        dataSource: [
            { latitude: 40.7424509, longitude: -74.0081468, city: 'New York' }
        ],
        visible:true,
        shape:'Circle',
        fill:'white',
        width:3,
        animationDuration:0,
        border: { width:2, color:'green'},
        tooltipSettings: {
            visible: true,
            valuePath:'city'
        }
    }]
   }
}
Copied to clipboard
import { NgModule } from '@angular/core';
import { BrowserModule } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import { MapsModule } from '@syncfusion/ej2-angular-maps';
import { LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService, SelectionService, AnnotationsService, ZoomService } from '@syncfusion/ej2-angular-maps';
/**
 * Module
 */
@NgModule({
    imports: [
        BrowserModule, MapsModule
    ],
    declarations: [AppComponent],
    bootstrap: [AppComponent],
     providers: [LegendService, MarkerService, MapsTooltipService, DataLabelService, BubbleService, NavigationLineService , SelectionService, AnnotationsService, ZoomService]
   
})
export class AppModule { }
Copied to clipboard
import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { enableProdMode } from '@angular/core';
import { AppModule } from './app.module';

enableProdMode();
platformBrowserDynamic().bootstrapModule(AppModule);