AmCharts v4全球地图不移动自定义标记
创始人
2024-09-30 06:01:40
0

AmCharts v4是一个用于创建交互式图表和地图的JavaScript库。以下是一个示例代码,展示如何使用AmCharts v4创建一个全球地图,并添加不会随着地图移动而移动的自定义标记。

首先,确保你已经引入了AmCharts v4库的脚本文件。然后,创建一个HTML元素来容纳地图。例如:

接下来,使用以下JavaScript代码创建并配置地图:

// 导入必要的模块
am4core.useTheme(am4themes_animated);
am4core.useTheme(am4themes_material);

// 创建地图实例
var chart = am4core.create("chartdiv", am4maps.MapChart);

// 设置地图的投影和背景颜色
chart.projection = new am4maps.projections.Miller();
chart.background.fill = am4core.color("#ffffff");

// 创建地图系列
var polygonSeries = chart.series.push(new am4maps.MapPolygonSeries());

// 设置地图数据
polygonSeries.useGeodata = true;
polygonSeries.geodata = am4geodata_worldLow;

// 设置地图区域的样式
var polygonTemplate = polygonSeries.mapPolygons.template;
polygonTemplate.fill = am4core.color("#74B266");

// 添加自定义标记
var imageSeries = chart.series.push(new am4maps.MapImageSeries());
var imageSeriesTemplate = imageSeries.mapImages.template;
var circle = imageSeriesTemplate.createChild(am4core.Circle);
circle.radius = 8;
circle.fill = am4core.color("#FF0000");
circle.stroke = am4core.color("#FFFFFF");
circle.strokeWidth = 2;
circle.nonScaling = true;
circle.tooltipText = "{title}";

// 设置标记的位置和标题
var marker1 = imageSeriesTemplate.createChild(am4core.Image);
marker1.width = 20;
marker1.height = 20;
marker1.nonScaling = true;
marker1.horizontalCenter = "middle";
marker1.verticalCenter = "middle";
marker1.tooltipText = "{title}";
marker1.href = "path/to/your/custom/icon.png";
marker1.setStateOnChildren = true;
marker1.states.create("hover");

// 添加标记的坐标和标题
imageSeries.data = [{
  "latitude": 48.8566,
  "longitude": 2.3522,
  "title": "Paris"
}, {
  "latitude": 40.7128,
  "longitude": -74.0060,
  "title": "New York"
}, {
  "latitude": 51.5074,
  "longitude": -0.1278,
  "title": "London"
}];

// 设置地图的初始缩放级别和中心
chart.homeZoomLevel = 3;
chart.homeGeoPoint = {
  "latitude": 35.6895,
  "longitude": 139.6917
};

以上代码将创建一个全球地图,并在巴黎、纽约和伦敦添加了自定义标记。这些标记不会随着地图的移动而移动。

请注意,在实际使用中,你需要将path/to/your/custom/icon.png替换为你自己的自定义标记图标的路径。另外,你还可以根据需要自定义标记的样式和其他属性。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...