只有国家边界的传单地图

问题描述 投票:0回答:1

OpenStreetMap 默认显示大量带有区域语言标签的详细信息。我在只需要国家边界、他们的名字和地图上的一些标记的情况下使用传单。是否有提供仅显示国家/地区的传单的提供商?

我也想知道这些地图是否可以用 svg tiles 而不是图像来渲染。

leaflet openstreetmap
1个回答
0
投票

2023 年你好🚀 这里jsFiddle 演示 绘制国家边界和名称:

我的 Javascript 代码被赋予三个 2 个字母的国家代码(“es”、“de”、“lv”)并从 Nominatim 获取它们的边界和显示名称。然后它将它们绘制在 Leaflet.js 地图上:

'use strict';

function processNominatimReply(data) {
  data.features.forEach(function(feature) {
    bordersGroup.addData(feature);
  });

  var bbox = data.features[0].bbox;
  var topLeft = L.latLng(bbox[1], bbox[0]);
  var bottomRight = L.latLng(bbox[3], bbox[2]);
  var countryBounds = L.latLngBounds(topLeft, bottomRight);

  var name = data.features[0].properties.display_name;
  var tooltip = L.tooltip()
    .setLatLng(countryBounds.getCenter())
    .setContent(name)
    .addTo(namesGroup);

  myMap.flyToBounds(countryBounds);
}

function sendNominatimRequest(countryCode) {
  var url = 'https://nominatim.openstreetmap.org/search?polygon_geojson=1&format=geojson&polygon_threshold=0.1&country=' + countryCode;

  var request = new XMLHttpRequest();
  request.open('GET', url, false);
  request.onload = function() {
    if (this.status >= 200 && this.status < 400) {
      var data = JSON.parse(this.response);
      processNominatimReply(data);
    }
  };
  request.send();
}

var startPosition = [51.4661, 7.2491];
var myMap = L.map('myMap').setView(startPosition, 14);
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
  attribution: '&copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
}).addTo(myMap);

var namesGroup = L.layerGroup();
myMap.addLayer(namesGroup);
var bordersGroup = L.geoJSON();
myMap.addLayer(bordersGroup);

var overlays = {
  'Show country names': namesGroup,
  'Show country borders': bordersGroup
};

L.control.layers(null, overlays, {
  collapsed: false
}).addTo(myMap);

var countries = ['es', 'de', 'lv'];
countries.forEach(function(item) {
  sendNominatimRequest(item);
});
html, body { 
  margin: 0;
  padding: 0;
}

#myMap {
  position: absolute;
  width: 100%;
  height: 100%;
}
<link type="text/css" rel="stylesheet" href="https://cdn.jsdelivr.net/npm/leaflet@1/dist/leaflet.min.css">
<script src="https://cdn.jsdelivr.net/npm/leaflet@1/dist/leaflet-src.min.js"></script>

<div id="myMap"></div>

建议的解决方案不需要任何 API 密钥或付款,我的演示源代码是免费的(许可证:公共领域)。

如果您打算在生产中使用它,您应该安装自己的 Nominatim 实例

© www.soinside.com 2019 - 2024. All rights reserved.