@amcharts/amcharts4
Version:
amCharts 4
81 lines (63 loc) • 2.55 kB
JavaScript
/**
* This is a demo for MapChart.
*
* Refer to the following link(s) for reference:
* @see {@link https://www.amcharts.com/docs/v4/chart-types/map/}
*/
import * as am4core from "@amcharts/amcharts4/core";
import * as am4maps from "@amcharts/amcharts4/maps";
import am4themes_animated from "@amcharts/amcharts4/themes/animated";
import am4geodata_worldLow from "@amcharts/amcharts4-geodata/worldLow";
// Set themes
am4core.useTheme(am4themes_animated);
// Create the map chart
let chart = am4core.create("chartdiv", am4maps.MapChart);
// Chech if proper geodata is loaded
try {
chart.geodata = am4geodata_worldLow;
}
catch (e) {
chart.raiseCriticalError(new Error("Map geodata could not be loaded. Please download the latest <a href=\"https://www.amcharts.com/download/download-v4/\">amcharts geodata</a> and extract its contents into the same directory as your amCharts files."));
}
// Set projection to be used
// @see {@link https://www.amcharts.com/docs/v4/reference/mapchart/#projection_property}
chart.projection = new am4maps.projections.Miller();
// Create polygon series
let polygonSeries = chart.series.push(new am4maps.MapPolygonSeries());
polygonSeries.useGeodata = true;
polygonSeries.exclude = ["AQ"]; // Exclude Antractica
polygonSeries.tooltip.fill = am4core.color("#000000");
let colorSet = new am4core.ColorSet();
// Configure polygons
let polygonTemplate = polygonSeries.mapPolygons.template;
polygonTemplate.tooltipText = "{name}";
polygonTemplate.togglable = true;
// Set events to apply "active" state to clicked polygons
let currentActive;
polygonTemplate.events.on("hit", (event) => {
// if we have some country selected, set default state to it
if (currentActive) {
currentActive.isActive = false;
}
chart.zoomToMapObject(event.target);
currentActive = event.target;
})
// Configure states
// @see {@link https://www.amcharts.com/docs/v4/concepts/states/}
// Configure "hover" state
let hoverState = polygonTemplate.states.create("hover");
hoverState.properties.fill = colorSet.getIndex(0);
// Configure "active" state
let activeState = polygonTemplate.states.create("active");
activeState.properties.fill = colorSet.getIndex(4);
// Create a Small map control
/*
let smallMap = new maps.SmallMap();
chart.smallMap = smallMap;
let smallMapPolygonSeries = smallMap.series.push(new maps.MapPolygonSeries());
smallMapPolygonSeries.copyFrom(polygonSeries);
*/
// Create a zoom control
let zoomControl = new am4maps.ZoomControl();
chart.zoomControl = zoomControl;
zoomControl.slider.height = 100;